/* ============================================
   PulseTemplate Base Layout Styles
   ============================================ */

/* Base */

html,
body {
  background: black;
  color: white;
  font-family: "Poppins", sans-serif;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: #2eed77;
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: #2eed77;
}

/* Surfaces & Cards */

.card,
.pulse-modal,
.pulse-cart {
  background: rgba(41, 45, 41, 0.47);
  border: 1px solid rgba(58, 199, 54, 0.1);
  border-radius: 8px;
  padding: 16px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Buttons */

.btn,
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0.9rem 1.2rem;
  color: #ffffff;
  background: #2eed77;
  border: 1px solid #2eed77;
  border-radius: 8px;
  font-weight: 500;
  transition: all 0.25s ease;
  cursor: pointer;
}

.btn:hover,
.button:hover {
  background: rgb(18.3964757709, 213.6035242291, 93.0044052863);
  border-color: rgb(18.3964757709, 213.6035242291, 93.0044052863);
  box-shadow: 0 0 20px 0 #2eed77;
  transform: translateY(-1px);
}

.btn:active,
.button:active {
  transform: translateY(0);
}

.btn.btn-secondary,
.button.btn-secondary {
  background: #2eed77;
  border-color: #2eed77;
}

.btn.btn-secondary:hover,
.button.btn-secondary:hover {
  background: rgb(18.3964757709, 213.6035242291, 93.0044052863);
  border-color: rgb(18.3964757709, 213.6035242291, 93.0044052863);
}

.btn.btn-accent,
.button.btn-accent {
  background: #2eed77;
  border-color: #2eed77;
}

.btn.btn-accent:hover,
.button.btn-accent:hover {
  background: rgb(18.3964757709, 213.6035242291, 93.0044052863);
  border-color: rgb(18.3964757709, 213.6035242291, 93.0044052863);
}

.btn.btn-outline,
.button.btn-outline {
  background: transparent;
  color: #2eed77;
  border-color: #2eed77;
}

.btn.btn-outline:hover,
.button.btn-outline:hover {
  background: #2eed77;
  color: #ffffff;
}

.box-info.bg-white {
  background-color: rgb(19, 21, 19);
  border: 1px solid #2eed77;
  border-radius: 8px;
  padding: 16px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

a.btn_1.gradient,
.btn_1.gradient {
  background-size: 100%;
  background-image: linear-gradient(to right, #3bffac, #050603);
  position: relative;
  z-index: 1;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

#place-menu:not(.holder-left):before {
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.02) 0%, rgb(23, 182, 101) 100%);
  position: absolute;
  right: -1px;
  top: 0;
  content: "";
  z-index: 1;
  background-repeat: no-repeat;
  background-size: 3rem;
  background-position: center;
  padding: 0;
  width: 3rem;
  height: 100%;
}

.top-bar.success {
  background: #111211;
  color: green;
}

#mobile-menu .btn_hero {
  background-color: #2eed77;
}

#mobile-menu > .content {
  background: rgba(0, 0, 0, 0.9019607843);
}

#place-menu > .item,
.btn-group label {
  color: white;
}

.btn-group label.active {
  background-color: #47e578;
}

.modal-open .modal {
  background-color: #141614;
}

.container_check input:checked ~ .checkmark {
  background-color: #2eed77;
}

.numbers-row .button_inc {
  color: #2eed77;
}

#addToCart1 button {
  background-color: #2eed77;
}

.item-offer-horizontal > .info > p,
.mb-2,
.my-2,
#modalDescription,
box- {
  color: white;
}

.modal-content,
.modal-header {
  background-color: #100f0f;
}

.modal-footer {
  background-color: #000000;
}

#place-menu > .item,
.btn-group label {
  display: inline-flex;
  font-weight: var(--font-weight-medium);
  position: relative;
  white-space: nowrap;
  color: #444;
  border-radius: 2rem;
  background-color: rgba(28, 28, 28, 0.82);
  padding: 0.5rem 1rem;
  margin: 0rem 0.5rem 0 0;
  margin-top: 5px;
}

nav a {
  color: #ffffff;
}

.nav-menu {
  border-top: 1px solid black;
  padding: 1rem 0;
  z-index: 99;
  box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.05);
  position: relative;
  background-color: black;
}

@media (max-width: 991px) {
  .btn_reserve_fixed {
    display: block;
    background-color: #000000;
  }
}

h3 {
  color: #67dfa7;
}

h6.title {
  font-weight: 600;
  text-transform: capitalize;
  color: #67dfa7;
}

.menu-link.active {
  color: #2eed77;
  font-weight: bold;
  font-size: 15px;
}

section.section-place-content {
  background: var(--color-background-shadow) #000000;
}

/* Header Styles */

.header,
.pulse-header {
  background: rgba(41, 45, 41, 0.47);
  border-bottom: 1px solid rgba(58, 199, 54, 0.1);
  padding: 16px 24px;
}

.header .logo,
.pulse-header .logo {
  color: #2eed77;
}

.header .nav-link,
.pulse-header .nav-link {
  color: white;
}

.header .nav-link:hover,
.header .nav-link.active,
.pulse-header .nav-link:hover,
.pulse-header .nav-link.active {
  color: #2eed77;
}

.box-info > .head,
.holder-right {
  position: static;
  top: 69px;
  z-index: 2;
  background-color: rgba(55, 55, 55, 0.4392156863);
}

/* Category Navigation */

.category-bar,
.category-scroll {
  background: transparent;
  border-bottom: 1px solid rgba(58, 199, 54, 0.1);
}

.category-bar .menu-link,
.category-scroll .menu-link {
  color: white;
  border: 1px solid rgba(58, 199, 54, 0.1);
  border-radius: 8px;
  padding: 0.6rem 0.9rem;
  transition: all 0.2s ease;
}

.category-bar .menu-link:hover,
.category-scroll .menu-link:hover {
  color: white;
  border-color: #2eed77;
}

.category-bar .menu-link.active,
.category-scroll .menu-link.active {
  color: #2eed77;
  border-color: #2eed77;
  box-shadow: 0 0 15px 0 #2eed77;
}

/* Item Cards */

.item-card {
  background: rgba(41, 45, 41, 0.47);
  border: 1px solid rgba(58, 199, 54, 0.1);
  border-radius: 8px;
  overflow: hidden;
  transition: all 0.3s ease;
}

.item-card:hover {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-2px);
  border-color: #2eed77;
}

.item-card .item-title {
  color: white;
  font-weight: 600;
}

.item-card .item-description {
  color: white;
}

.item-card .item-price {
  color: #2eed77;
  font-weight: 600;
}

/* Product Item Horizontal (Item Offer) */

.item-offer-horizontal {
  display: grid;
  align-items: center;
  justify-content: space-between;
  color: white;
  padding: 16px;
  background-color: #272728;
  border-radius: 8px;
  border: 1px solid rgba(58, 199, 54, 0.1);
  grid-template-rows: 1fr;
  grid-template-columns: minmax(100px, 1fr) 100px;
  position: relative;
  gap: 0.5rem;
  transition: all 0.3s ease;
}

.item-offer-horizontal:hover {
  text-decoration: none;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  border-color: #2eed77;
  transform: translateY(-2px);
}

.item-offer-horizontal:hover h4,
.item-offer-horizontal:hover h6,
.item-offer-horizontal:hover .title {
  color: #2eed77;
}

.item-offer-horizontal > .info > p {
  color: white;
  margin-bottom: 1rem;
  font-size: 0.875rem;
  display: block;
  font-weight: 400;
  text-transform: capitalize;
  padding-left: 15px;
}

.item-offer-horizontal > .info > .extras {
  display: flex;
  gap: 16px;
  align-items: center;
}

.item-offer-horizontal > .info > .extras > .price {
  color: white;
  font-weight: 600;
}

.item-offer-horizontal picture {
  overflow: hidden;
  display: flex;
  border-radius: 0.5rem;
  border: 1px solid rgba(58, 199, 54, 0.1);
  width: 100px;
  max-height: 100px;
  aspect-ratio: 1/1;
  min-width: 100px;
  right: 0;
  position: relative;
}

.item-offer-horizontal picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0.5rem;
}

.item-offer-horizontal.disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}

@media only screen and (max-width: 768px) {
  .item-offer-horizontal {
    grid-template-columns: minmax(80px, 1fr) 80px;
    gap: 0.5rem;
    padding: 8px;
  }

  .item-offer-horizontal > .info {
    width: calc(100% - 80px - 0.5rem);
  }

  .item-offer-horizontal picture {
    width: 80px;
    max-height: 80px;
    min-width: 80px;
  }
}

/* Forms */

input,
textarea,
select {
  background: rgba(41, 45, 41, 0.47);
  border: 1px solid rgba(58, 199, 54, 0.1);
  border-radius: 8px;
  color: white;
  padding: 0.75rem;
  transition: all 0.2s ease;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: #2eed77;
  box-shadow: 0 0 0 3px rgba(46, 237, 119, 0.1);
}

/* Order Summary / Cart Styles */

.info {
  display: block;
  width: 100%;
}

.holder-right {
  position: relative;
}

.holder-right .info {
  margin-bottom: 16px;
}

#order-summary {
  display: block;
  visibility: visible;
  opacity: 1;
}

.box-info .head {
  padding: 16px;
  border-bottom: 1px solid rgba(58, 199, 54, 0.1);
  margin-top: 10px;
}

.box-info .head h6 {
  color: white;
  font-weight: 600;
  margin: 0;
}

.box-info .content {
  padding: 16px;
}

.box-info .content:not(.grid) {
  max-height: 400px;
  overflow-y: auto;
}

.box-info .box-order {
  margin-bottom: 0;
}

/* Cart Items */

.items {
  padding: 8px 0;
  border-bottom: 1px solid rgba(58, 199, 54, 0.1);
}

.items:last-child {
  border-bottom: none;
}

.product-item_title {
  color: white;
  font-weight: 500;
}

.product-item_title:hover {
  color: #2eed77;
}

.product-item_price {
  color: #2eed77;
  font-weight: 600;
}

.product-item_quantity {
  color: white;
  font-weight: 400;
}

/* Empty Cart */

.empty-cart {
  padding: 24px;
  text-align: center;
  color: white;
}

/* Actions Cart */

.actionsCart {
  padding: 16px;
  border-top: 1px solid rgba(58, 199, 54, 0.1);
}

.actionsCart .button.full-button {
  width: 100%;
  justify-content: space-between;
}

.actionsCart .button.full-button .ammount {
  font-weight: 600;
}

/* Category Products - Remove Scrolling */

.box-info .content.grid {
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
  max-height: none !important;
  height: auto !important;
}

.box-info .content {
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
  max-height: none !important;
  height: auto !important;
}

/* Grid Layout for Products */

.content.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 16px;
  overflow: visible !important;
  max-height: none !important;
}

/* Add more layout styles as needed */

/* ============================================
   PulseTemplate Responsive Styles
   ============================================ */

/* Mobile First Approach */

/* Small devices (phones, 576px and up) */

@media (max-width: 575.98px) {
  html,
  body {
    font-size: 14px;
  }

  .header,
  .pulse-header {
    padding: 8px 16px;
  }

  .btn,
  .button {
    padding: 0.75rem 1rem;
    font-size: 14px;
  }

  .item-card {
    margin-bottom: 16px;
  }

  .category-scroll {
    padding: 8px;
  }

  .category-scroll .menu-link {
    padding: 0.5rem 0.75rem;
    font-size: 13px;
  }
}

/* Medium devices (tablets, 768px and up) */

@media (min-width: 576px) and (max-width: 767.98px) {
  .container {
    max-width: 540px;
  }
}

/* Large devices (desktops, 992px and up) */

@media (min-width: 768px) and (max-width: 991.98px) {
  .container {
    max-width: 720px;
  }
}

/* Extra large devices (large desktops, 1200px and up) */

@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}

/* Extra extra large devices (larger desktops, 1400px and up) */

@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }
}

/* Landscape orientation adjustments */

@media (orientation: landscape) and (max-height: 500px) {
  .header,
  .pulse-header {
    padding: 4px 16px;
  }
}

/* Print styles */

@media print {
  .header,
  .pulse-header,
  .category-bar {
    display: none;
  }

  body {
    background: #ffffff;
    color: #000000;
  }
}

