.elementor-29132 .elementor-element.elementor-element-5f9c06d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-29132 .elementor-element.elementor-element-5f9c06d.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-29132 .elementor-element.elementor-element-cd2b363{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-29132 .elementor-element.elementor-element-3c30b4f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}@media(min-width:769px){.elementor-29132 .elementor-element.elementor-element-5f9c06d{--width:100.168%;}}/* Start custom CSS for html, class: .elementor-element-08b7414 *//* =========================================
   CATERING HERO - WOODMART LIGHT THEME
   ========================================= */

.gs-catering-hero {
  width: 100%;
  padding: 80px 0;
  background-color: #ffffff; /* Matches your white site */
  font-family: "Lato", sans-serif;
}

.gs-catering-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.gs-catering-header {
  text-align: center;
  margin-bottom: 60px;
}

.gs-eyebrow {
  display: block;
  font-family: "Playfair Display", serif;
  font-style: italic;
  color: #7a824a; /* Your Olive Green */
  font-size: 20px;
  margin-bottom: 10px;
}

.gs-catering-title {
  font-family: "Playfair Display", serif;
  font-size: clamp(32px, 5vw, 48px);
  color: #242424;
  font-weight: 400;
  margin: 0;
}

.gs-divider {
  width: 60px;
  height: 2px;
  background: #7a824a;
  margin: 25px auto 15px;
}

.gs-sub-tag {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #999;
}

/* Gallery Grid */
.gs-catering-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
  margin-bottom: 50px;
}

.gs-gallery-item img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: 4px; /* Matches Woodmart sharp/soft edge mix */
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
  transition: transform 0.5s ease;
}

/* Floating effect for middle image */
.gs-item-focus {
  transform: translateY(-20px);
}

.gs-gallery-item:hover img {
  transform: scale(1.03);
}

/* Footer Description */
.gs-catering-footer {
  max-width: 850px;
  margin: 0 auto;
  text-align: center;
  border-top: 1px solid #f0f0f0;
  padding-top: 40px;
}

.gs-catering-description {
  font-size: 19px;
  line-height: 1.8;
  color: #666;
}

.gs-catering-description strong {
  color: #242424;
  font-weight: 700;
}

/* Responsive */
@media (max-width: 768px) {
  .gs-catering-gallery {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .gs-item-focus {
    transform: none;
  }
  .gs-catering-hero {
    padding: 50px 0;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-53f7ebe *//* Layout Basics */
.nt-services-detailed { padding: 100px 0; background-color: #fdfdfd; }
.nt-page-title { color: #0b2c5a; font-size: 2.5rem; text-align: center; margin-bottom: 15px; }
.nt-section-divider.nt-center { margin: 0 auto 60px auto; width: 50px; height: 3px; background: #c9a24a; }

.nt-service-cat { margin-bottom: 80px; }
.nt-cat-title {
    color: #0b2c5a;
    font-size: 1.6rem;
    margin-bottom: 40px;
    padding-left: 15px;
    border-left: 4px solid #c9a24a;
    font-weight: 700;
}

/* Grid & Cards */
.nt-detailed-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.nt-service-card {
    background: #ffffff;
    padding: 40px;
    border-radius: 12px;
    border: 1px solid #f0f0f0;
    position: relative;
    transition: all 0.4s ease;
    box-shadow: 0 4px 6px rgba(0,0,0,0.02);
}

.nt-icon-box {
    width: 55px;
    height: 55px;
    background: #f8f9fb;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 25px;
}

.nt-icon-box i {
    font-size: 1.4rem;
    color: #0b2c5a;
}

.nt-service-card h4 {
    color: #0b2c5a;
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 15px;
}

.nt-service-card p {
    color: #6a737d;
    line-height: 1.7;
    font-size: 0.95rem;
    margin: 0;
}

/* Premium Hover (No Link Effect) */
.nt-service-card:hover {
    transform: translateY(-5px);
    border-color: #c9a24a;
    box-shadow: 0 15px 35px rgba(11, 44, 90, 0.06);
}

.nt-service-card:hover .nt-icon-box {
    background: #0b2c5a;
}

.nt-service-card:hover .nt-icon-box i {
    color: #ffffff;
}

/* Responsive */
@media (max-width: 992px) {
    .nt-detailed-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 650px) {
    .nt-detailed-grid { grid-template-columns: 1fr; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2377e65 */.nt-services-extra {
    padding: 60px 0 100px 0;
    background-color: #ffffff;
}

.nt-info-block {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 50px;
    align-items: flex-start;
    margin-bottom: 50px;
}

.nt-info-content h3 {
    color: #0b2c5a;
    font-size: 1.8rem;
    margin-bottom: 20px;
}

.nt-feature-list {
    list-style: none;
    padding: 0;
    margin-top: 20px;
}

.nt-feature-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
    color: #4a5568;
    font-size: 1rem;
}

.nt-feature-list i {
    color: #c9a24a;
    font-size: 0.9rem;
}

/* The Highlight Box on the Right */
.nt-highlight-box {
    background: #f8f9fb;
    padding: 40px;
    border-radius: 12px;
    border: 1px dashed #cbd5e0;
}

.nt-highlight-box h4 {
    color: #0b2c5a;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Bottom Notice */
.nt-notice-simple {
    background: #fff5f5;
    border: 1px solid #fed7d7;
    padding: 20px 30px;
    border-radius: 8px;
    color: #c53030;
    font-size: 0.9rem;
    text-align: center;
}

/* Mobile responsive */
@media (max-width: 992px) {
    .nt-info-block { grid-template-columns: 1fr; }
}/* End custom CSS */