/*
Template: generatepress
Theme Name: PelekisTheme
Author: Paris Papadopoulos
Version: 0.0.1
*/

@import url("./css/mobile-menu.css");

/* padding of menu */
.main-navigation .main-nav ul li a {
  padding-left: 15px;
  padding-right: 15px;
  line-height: normal;
  font-size: 18px;
}

/* Gap between main nav items */
.main-navigation .main-nav > ul > li {
  margin: 0 10px;
}

.main-navigation.has-branding .inside-navigation.grid-container,
.main-navigation.has-branding.grid-container
  .inside-navigation:not(.grid-container) {
  padding: 0px;
}
/* padding of menu */

/* sub menu underline a tag */
.main-navigation ul ul a:hover {
  text-decoration: none;
}
/* sub menu underline a tag */

/* ============================================
   GLOBAL MENU FIXES - Safeline Style
   ============================================ */

/* Remove ALL arrows from main menu items (Elevator Dept, LED Dept, etc.) */
.main-navigation .main-nav > ul > li.menu-item-has-children > a .dropdown-menu-toggle,
.main-navigation .main-nav > ul > li.menu-item-has-children > a > .gp-icon,
.main-navigation .main-nav > ul > li > a .dropdown-menu-toggle,
.main-navigation .sf-menu > li.menu-item-has-children > a > span.dropdown-menu-toggle,
.main-navigation .menu-item-has-children > a > .dropdown-menu-toggle {
  display: none !important;
}

/* Hide GeneratePress dropdown arrows on main nav */
.main-navigation .main-nav ul li.menu-item-has-children > a > span {
  display: none !important;
}

/* Remove text-transform from ALL menu items - let WordPress handle capitalization */
.main-navigation .main-nav ul li a,
.main-navigation ul ul a,
nav .main-nav .mega-menu > ul > li > a,
nav .main-nav .mega-menu ul .sub-menu a {
  text-transform: none !important;
}

/* Red hover for ALL links in mega menu */
nav .main-nav .mega-menu ul a:hover,
nav .main-nav .mega-menu > ul a:hover,
nav .main-nav .mega-menu .sub-menu a:hover {
  color: #c41e3a !important;
}

/* ============================================
   END GLOBAL MENU FIXES
   ============================================ */

/* ============================================
   REGULAR DROPDOWN MENUS - Safeline Style
   ============================================ */
@media (min-width: 769px) {
  /* Dropdown panel styling - exclude mega menu */
  .main-navigation ul ul:not(.mega-menu > ul):not(.mega-menu ul) {
    background: #ffffff;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border-radius: 0;
    border-top: none;
    padding: 20px 0;
    min-width: 240px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(0);
    transition: opacity 0.25s ease, visibility 0.25s ease;
  }

  /* Hover bridge for regular dropdowns - exclude mega menu */
  .main-navigation ul ul:not(.mega-menu > ul)::before {
    content: '';
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    height: 15px;
    background: transparent;
  }

  /* Show dropdown on hover - exclude mega menu */
  .main-navigation ul li:not(.mega-menu):hover > ul {
    opacity: 1;
    visibility: visible;
  }

  /* Mega menu stays visible when open - no hover/opacity effects */
  .main-navigation .mega-menu.mega-menu-open > ul {
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* Prevent hover from affecting mega menu */
  .main-navigation .mega-menu:hover > ul {
    opacity: inherit;
    visibility: inherit;
  }

  /* Dropdown items */
  .main-navigation ul ul li {
    padding: 0;
    margin: 0;
  }

  .main-navigation ul ul a {
    padding: 8px 25px;
    font-size: 15px;
    color: #555;
    display: block;
    transition: color 0.2s ease;
    border-left: none;
  }

  .main-navigation ul ul a:hover {
    background: transparent;
    color: #c41e3a;
    border-left: none;
    text-decoration: none;
  }

  /* Nested dropdowns (3rd level) */
  .main-navigation ul ul ul {
    left: 100%;
    top: 0;
    margin-left: 0;
    border-radius: 0;
  }

  /* Arrow indicator for items with children */
  .main-navigation ul ul .menu-item-has-children > a::after {
    content: '';
    display: inline-block;
    width: 5px;
    height: 5px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(-45deg);
    margin-left: auto;
    float: right;
    margin-top: 6px;
    opacity: 0.6;
  }

  /* Main nav item hover effect */
  .main-navigation .main-nav > ul > li > a {
    position: relative;
    transition: color 0.2s ease;
  }

  .main-navigation .main-nav > ul > li > a:hover {
    color: #1a1a1a;
  }

  /* Navy blue underline on hover for nav items */
  .main-navigation .main-nav > ul > li > a::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 20px;
    width: calc(100% - 40px);
    height: 3px;
    background: #1a3a5c;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.2s ease;
  }

  .main-navigation .main-nav > ul > li > a:hover::after,
  .main-navigation .main-nav > ul > li.current-menu-item > a::after {
    transform: scaleX(1);
  }

  /* Keep underline visible when mega menu is open */
  .main-navigation .main-nav > ul > li.mega-menu-open > a::after {
    transform: scaleX(1);
  }
}
/* ============================================
   END REGULAR DROPDOWN MENUS
   ============================================ */

/* MOBILE CENTER LOGO */
.site-logo.mobile-header-logo {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  margin-left: 0px !important;
}

#mobile-header .menu-toggle {
  order: -1;
  margin-right: auto;
} /* MOBILE CENTER LOGO */

/* ============================================
   MEGA MENU - Safeline Style (Click-based)
   ============================================ */

@media (min-width: 769px) {
  /* Base mega menu container */
  nav .main-nav .mega-menu {
    position: static;
  }

  /* Active state - navy blue underline on menu item when open */
  nav .main-nav .mega-menu.mega-menu-open > a {
    color: #1a1a1a;
  }

  nav .main-nav .mega-menu.mega-menu-open > a::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 20px;
    width: calc(100% - 40px);
    height: 3px;
    background: #1a3a5c;
  }

  nav .main-nav .mega-menu > a {
    position: relative;
    cursor: pointer;
  }

  /* Mega menu dropdown panel - hidden by default */
  nav .main-nav .mega-menu > ul {
    position: fixed;
    width: 100%;
    left: 0 !important;
    top: 110px;
    display: none;
    flex-wrap: wrap;
    padding: 40px 80px 60px;
    background: #ffffff;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border-top: none;
    z-index: 1000;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    margin-top: 0;
  }

  /* Show when open class is added (via JavaScript) */
  nav .main-nav .mega-menu.mega-menu-open > ul {
    display: flex;
  }

  /* Mega menu header row */
  .mega-menu-header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
    padding-bottom: 0;
  }

  /* "Show all products" link */
  .mega-menu-show-all {
    font-size: 28px !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
    text-decoration: underline !important;
    text-underline-offset: 6px;
  }

  a.mega-menu-show-all {
    font-size: 28px !important;
  }

  .mega-menu-show-all:hover {
    color: #c41e3a;
  }

  /* Close button */
  .mega-menu-close {
    font-size: 20px !important;
    font-weight: 400;
    color: #1a1a1a;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: none;
    padding: 0;
  }

  .mega-menu-close:hover {
    color: #c41e3a;
  }

  .mega-menu-close-x {
    font-size: 26px;
    line-height: 1;
  }

  /* Column layout - 4 columns */
  nav .main-nav .mega-menu > ul > li {
    display: inline-block;
    width: 25%;
    vertical-align: top;
    padding: 0 30px 30px 0;
    border-right: none;
  }

  nav .main-nav .mega-menu > ul > li:last-child {
    padding-right: 0;
  }

  /* Hide header li from column width calculation */
  nav .main-nav .mega-menu > ul > li.mega-menu-header-item {
    width: 100%;
    padding: 0;
  }

  /* Column variations */
  nav .main-nav .mega-menu.mega-menu-col-2 > ul > li:not(.mega-menu-header-item) {
    width: 50%;
  }

  nav .main-nav .mega-menu.mega-menu-col-3 > ul > li:not(.mega-menu-header-item) {
    width: 33.3333%;
  }

  nav .main-nav .mega-menu.mega-menu-col-5 > ul > li:not(.mega-menu-header-item) {
    width: 20%;
  }

  /* Category headers (top level items) - Bold, bigger */
  nav .main-nav .mega-menu > ul > li > a {
    font-weight: 700;
    font-size: 17px;
    color: #1a1a1a;
    text-transform: none;
    letter-spacing: 0;
    padding: 0 0 12px;
    margin-bottom: 10px;
    border-bottom: none;
    display: block;
    transition: color 0.2s ease;
    line-height: 1.4;
  }

  nav .main-nav .mega-menu > ul > li > a:hover {
    color: #c41e3a !important;
    text-decoration: none !important;
  }

  /* Remove arrow icons from category headers */
  nav .main-nav .mega-menu > ul > li.menu-item-has-children > a::after {
    display: none;
  }

  /* Sub-menu items */
  nav .main-nav .mega-menu ul .sub-menu {
    position: static;
    display: block;
    opacity: 1;
    visibility: visible;
    width: 100%;
    box-shadow: none;
    left: 0;
    height: auto;
    pointer-events: auto;
    transform: none;
    padding: 0;
    background: transparent;
    border-top: none;
    border-radius: 0;
  }

  nav .main-nav .mega-menu ul .sub-menu li {
    padding: 0;
    margin: 0;
  }

  /* Subcategory links - Clean gray, red on hover */
  nav .main-nav .mega-menu ul .sub-menu a {
    font-size: 15px;
    font-weight: 400;
    color: #555555;
    padding: 6px 0;
    display: block;
    transition: color 0.2s ease;
    border-left: none;
    padding-left: 0;
    margin-left: 0;
    line-height: 1.5;
  }

  nav .main-nav .mega-menu ul .sub-menu a:hover {
    color: #c41e3a !important;
    text-decoration: none !important;
    border-left: none;
    background: transparent !important;
  }

  /* Nested sub-menus (3rd level) */
  nav .main-nav .mega-menu > ul ul ul {
    position: static;
    display: block;
    float: none;
    padding-left: 0;
    margin-top: 5px;
  }

  nav .main-nav .mega-menu > ul ul ul a {
    font-size: 14px;
    color: #777;
    padding-left: 12px;
  }

  nav .main-nav .mega-menu > ul ul ul a:hover {
    color: #c41e3a !important;
  }

  /* Remove hover backgrounds from inherited styles */
  nav .main-nav .mega-menu > ul > li:hover > a,
  nav .main-nav .mega-menu > ul > li:focus > a,
  nav .main-nav .mega-menu > ul > li[class*="current-"] > a,
  nav .main-nav .mega-menu ul ul {
    background-color: transparent !important;
  }

  nav .main-nav .mega-menu ul.toggled-on .sub-menu {
    pointer-events: auto;
  }

  nav .main-nav .mega-menu .sub-menu .menu-item-has-children .dropdown-menu-toggle {
    display: none;
  }

  /* Fix positioning context */
  .main-navigation:not(.is_stuck) .inside-navigation {
    position: initial;
  }

  .inside-header {
    position: relative;
  }

  /* Overlay behind mega menu when open - below header */
  .mega-menu-overlay {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.75);
    z-index: 998;
  }

  .mega-menu-overlay.active {
    display: block;
  }
}

/* When mega menu is open - lock header and prevent scroll */
body.mega-menu-active {
  overflow: hidden;
}

body.mega-menu-active .site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0;
  right: 0;
  z-index: 1001;
  background: #fff;
}

/* Remove any shadow/border from header when mega menu is open */
body.mega-menu-active .site-header,
body.mega-menu-active .site-header *,
body.mega-menu-active .inside-header,
body.mega-menu-active .main-navigation {
  box-shadow: none !important;
  border-bottom: none !important;
}

/* ============================================
   END MEGA MENU
   ============================================ */

/*mobile nav padding */

/* Site header css */

/* BLOG COLUMNS MOBILE */
@media (max-width: 767px) {
  .generate-columns.mobile-grid-100 {
    clear: none;
    width: 50%;
  }
} /* BLOG COLUMNS MOBILE */

/* sidebar right projects category */
.sidebarprojects {
  margin: 0;
} /* sidebar right projects category */

/* sticky nav */
.navigation-stick.is_stuck {
  background-color: white;
}
/* sticky nav */

/* espa img css */
@media (min-width: 1025px) {
  /* Add styles to your container and the image */

  .espa-img img {
    width: 300px;
    position: fixed;
    top: 90%;
    left: 5%;
    opacity: 1; /* Initially visible */
    transition: opacity 0.5s ease; /* Add a transition for a smooth effect */
  }
}

/* espa img css */

/* Form css */
.wpforms-form input[type="submit"],
.wpforms-form button[type="submit"] {
  background-color: white !important;
  border: 1px solid #29539f !important;
  color: var(--contrast) !important;
  border: none !important;
  font-size: 1em;
}

.wpforms-form input[type="submit"]:hover,
.wpforms-form input[type="submit"]:active,
.wpforms-form button[type="submit"]:hover,
.wpforms-form button[type="submit"]:active,
.wpforms-form .wpforms-page-button:hover,
.wpforms-form .wpforms-page-button:active {
  background-color: 29539F !important; /* Darker grey background */
  border: 1px solid 29539F !important; /* Lighter grey border */
  text-decoration: underline;
}

div.wpforms-container-full .wpforms-form input[type="email"] {
  background-color: #fff;
  box-sizing: border-box;
  border-radius: 6px !important;
  color: black !important;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  display: block;
  float: none;
  font-size: 16px;
  border: 1px solid rgba(12, 8, 47, 0.2) !important;
  padding: 22px 10px !important;
  height: 38px;
  width: 100%;
  line-height: 1.3;
}

#wpforms-2452-field_0 {
  background-color: #fff;
  box-sizing: border-box;
  border-radius: 6px !important;
  color: black !important;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  display: block;
  float: none;
  font-size: 16px;
  border: 1px solid rgba(12, 8, 47, 0.2) !important;
  padding: 22px 10px !important;
  height: 38px;
  width: 100%;
  line-height: 1.3;
}

#wpforms-2254 {
  margin-bottom: 0;
}

/* Form css */

/* hero section*/
.herobg,
.page-hero-section {
  background: linear-gradient(
    0deg,
    rgb(250, 251, 252) 0%,
    rgb(234, 236, 239) 100%
  );
}

/* .eledepart {
	background: linear-gradient(0deg, rgb(250, 251, 252) 0%, rgb(234, 236, 239) 100%);
} */

/* single post style*/

.single-post .inside-article {
  box-shadow: 0px 0px 22px rgb(0 0 0 / 7%);

  overflow: hidden;
  word-wrap: break-word;
  background-clip: border-box;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.125);
  border-color: #ebebeb;
  border-radius: 0.25rem;
  margin-bottom: 50px;
} /* single post style*/

/* Elevator Department Taxonomies */
ul.parent-taxonomy {
  margin: 0;
  padding: 0;
  list-style: none;
}

ul.child-taxonomy {
  margin: 0;
  padding: 0;
  list-style: none;
  margin-left: 1em;
}

ul.parent-taxonomy li {
  margin: 0;
  padding: 0;
  margin-bottom: 0.5em;
}

ul.child-taxonomy li {
  margin: 0;
  padding: 0;
  margin-bottom: 0.25em;
}

ul.parent-taxonomy a {
  font-weight: bold;
}

ul.child-taxonomy a {
  font-weight: normal;
}

/* Categiries Filter CSS */
.off-canvas {
  position: fixed;
  top: 0;
  left: -300px; /* or however wide you want the off-canvas menu to be */
  width: 300px; /* or however wide you want the off-canvas menu to be */
  height: 100%;
  background-color: #fff; /* or whatever background color you want */
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  transition: left 0.3s ease-in-out;
  z-index: 9998;
}
.off-canvas.show {
  left: 0;
}

.close-button {
  position: absolute;
  top: 10px;
  right: 10px;
}

/* Categiries Filter CSS */

#generate-slideout-menu.offside,
#generate-slideout-menu.offside--left {
  left: calc(var(--gp-slideout-width) * -1);
}

h2.gb-headline-bcaac8a4,
.gb-container-c68a6e6e {
  padding-top: 50px;
}

/* lang switcher topbar */
.hasHoverBackgroundColor {
  border: 1px solid var(--base);
  border-radius: 0.3125em !important;
}

/* Makes the product blocks the same size */
.product-block {
  height: 100%;
}

.product-block .gb-headline {
  height: 100px;
}

.p-accordion-categories-left .gb-accordion__toggle {
  background: transparent;
}

.woocommerce-product-attributes .woocommerce-product-attributes-item__label {
  text-align: left;
}

td.woocommerce-product-attributes-item__value {
  font-size: smaller;
  font-style: normal !important;
  padding-left: 10px !important;
}

.woocommerce table.shop_attributes th {
  font-size: 17px;
}

li.type-product {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.products .type-product .woocommerce-loop-product__title {
  text-align: center;
  font-size: 0.8em !important;
  padding: 0;
  height: 80px;
  overflow: visible;
}

.woocommerce-ordering {
  display: none;
}

.type-product .button {
  font-size: 85% !important;
}

#trp-floater-ls {
  right: 3% !important;
}

.wc-tabs > li {
  background: transparent !important;
  border: none !important;
}

.wc-tabs > li::before,
.wc-tabs > li::after {
  content: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before {
  content: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
  border: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-top: 2px solid rgba(0, 0, 0, 0.1);
  border-bottom: 2px solid rgba(0, 0, 0, 0.1);
  display: flex;
  justify-content: center;
  gap: 50px;
  padding: 10px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-weight: normal !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  font-weight: bold !important;
}

.woocommerce table.shop_attributes th {
  width: auto;

  @media (min-width: 769px) {
    white-space: nowrap;
  }
}

.woocommerce img,
.woocommerce-page img {
  max-width: 85%;
}

.inside-navigation.grid-container,
.gb-container-02b15f89 {
  max-width: 1650px !important;
  padding-left: 40px;
}

@media (min-width: 769px) {
  .main-navigation ul li:nth-child(3) {
    margin-left: unset;
  }

  .main-navigation ul li:nth-child(4) {
    margin-left: auto;
  }
}

ul.sidebar-category-list {
  margin: 0 2em;
}

li.sidebar-category-child {
  /* list-style-type: "- "; */
  font-size: medium;
  margin: 0.1em 0;
}

.cta-button {
  background-color: var(--accent);
  color: white !important;
  padding: 10px 30px;
  text-decoration: none !important;
  border-radius: 4px;
}

.cta-button .gb-icon {
  display: none !important;
}

.cta-button:hover {
  filter: brightness(110%) !important;
  color: white !important;
  text-decoration: none !important;
}

.cta-button:active {
  transform: scale(0.95) !important;
}

.external-link {
  display: flex;
  align-items: center;
  padding-right: 15px;
}

.external-link a {
  padding-right: 5px !important;
}

.external-link::after {
  content: url("data:image/svg+xml,%3Csvg%20aria-hidden%3D%22true%22%20height%3D%2224%22%20width%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M19.5%204.5h-7V6h4.44l-5.97%205.97%201.06%201.06L18%207.06v4.44h1.5v-7Zm-13%201a2%202%200%200%200-2%202v10a2%202%200%200%200%202%202h10a2%202%200%200%200%202-2v-3H17v3a.5.5%200%200%201-.5.5h-10a.5.5%200%200%201-.5-.5v-10a.5.5%200%200%201%20.5-.5h3V5.5h-3Z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E");
  display: inline-block;
  width: 24px;
  height: 24px;
}

.woocommerce-loop-category__title {
  font-size: 0.8em !important;
}

.woocommerce-loop-category__title mark {
  display: none;
}

.woocommerce-product-gallery__trigger {
  display: none !important;
}

.woocommerce-product-gallery__image {
  pointer-events: none !important;
}

.alignfull {
  width: var(--available-width) !important;
  max-width: var(--available-width) !important;
  margin-left: calc(var(--available-width) * -1 / 2 + 100% / 2) !important;
  margin-right: calc(var(--available-width) * -1 / 2 + 100% / 2) !important;
}

.library-viewer--folder .entry-title {
  font-size: 16px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================
   COP ARCHIVE PAGE STYLES
   ============================================ */

/* BASE - Only apply to COP archive page */
.post-type-archive-cop .site-content { display: block !important; }
.premium-cop-main { background: #fff; }

/* HERO */
.premium-hero {
  position: relative;
  min-height: 400px;
  background: url('/wp-content/uploads/2025/11/pelekis.jpg') center/cover fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.premium-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,0.7), rgba(0,0,0,0.4));
}
.premium-hero-content {
  position: relative;
  z-index: 2;
  padding: 40px;
}
.premium-hero-title {
  font-size: 3rem;
  font-weight: 900;
  color: #fff;
  margin: 0 0 15px;
  text-transform: uppercase;
  letter-spacing: 4px;
}
.premium-hero-subtitle {
  font-size: 1.2rem;
  color: rgba(255,255,255,0.9);
  font-weight: 300;
  letter-spacing: 2px;
}

/* NAVIGATION */
.premium-nav {
  background: #1a1a1a;
  padding: 20px 0;
  position: sticky;
  top: 0;
  z-index: 100;
}
.premium-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 15px;
}
.premium-nav-list a {
  display: inline-block;
  padding: 12px 30px;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  border: 2px solid rgba(255,255,255,0.3);
  transition: all 0.3s;
}
.premium-nav-list a:hover {
  background: #fff;
  color: #1a1a1a;
}

/* SECTIONS */
.product-section {
  padding: 80px 40px;
}
.product-section.alt-bg {
  background: #f5f5f5;
}
.section-header {
  text-align: center;
  margin-bottom: 60px;
}
.section-title {
  font-size: 2rem;
  font-weight: 800;
  color: #1a1a1a;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 3px;
  position: relative;
  display: inline-block;
}
.section-title::after {
  content: '';
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 3px;
  background: #333;
}

/* PRODUCTS SHOWCASE */
.products-showcase {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 100px;
  max-width: 1400px;
  margin: 0 auto;
}

/* Product Group */
.product-group {
  text-align: center;
}

.product-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 20px;
  letter-spacing: 1px;
  position: relative;
  display: inline-block;
}
.product-title::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 2px;
  background: #333;
}

/* COP + LOP container */
.product-items {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 0;
}

/* COP - larger */
.item-cop {
  display: flex;
  align-items: flex-end;
  margin: 0;
  padding: 0;
}
.item-cop a {
  display: block;
  margin: 0;
  padding: 0;
  line-height: 0;
}
.item-cop img {
  height: auto;
  width: auto;
  max-height: 1000px;
  max-width: 470px;
  object-fit: contain;
  transition: transform 0.3s;
  display: block;
  margin: 0;
  padding: 0;
}
.item-cop a:hover img {
  transform: scale(1.03);
}

/* LOP - smaller */
.item-lop {
  display: flex;
  align-items: flex-end;
  margin: 0;
  padding: 0;
}
.item-lop a {
  display: block;
  margin: 0;
  padding: 0;
  line-height: 0;
}
.item-lop img {
  height: auto;
  width: auto;
  max-height: 500px;
  max-width: 250px;
  object-fit: contain;
  transition: transform 0.3s;
  display: block;
  margin: 0;
  padding: 0;
}
.item-lop a:hover img {
  transform: scale(1.05);
}

/* PANELS SECTION */
.panels-section {
  padding: 100px 40px;
  background: linear-gradient(180deg, #e8e8e8 0%, #fff 100%);
}

.panels-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  max-width: 1500px;
  margin: 0 auto;
}

.panel-item {
  text-align: center;
}

.panel-name {
  font-size: 0.85rem;
  font-weight: 700;
  color: #333;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 20px;
  padding: 8px 20px;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  display: inline-block;
}

.panel-image-wrapper {
  display: flex;
  justify-content: center;
}

.panel-image-wrapper img {
  max-height: 800px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  transition: transform 0.3s;
}

.panel-image-wrapper a:hover img {
  transform: scale(1.02);
}

/* COP ARCHIVE RESPONSIVE */
@media (max-width: 1200px) {
  .products-showcase {
    gap: 60px;
  }
  .panels-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 900px) {
  .products-showcase {
    flex-direction: column;
    align-items: center;
    gap: 60px;
  }
  .product-items {
    gap: 0;
  }
  .item-cop img {
    max-height: 800px;
    max-width: 380px;
  }
  .item-lop img {
    max-height: 400px;
    max-width: 200px;
  }
}

@media (max-width: 768px) {
  .premium-hero { min-height: 300px; background-attachment: scroll; }
  .premium-hero-title { font-size: 2rem; }
  .premium-nav-list { flex-wrap: wrap; gap: 8px; }
  .premium-nav-list a { padding: 10px 18px; font-size: 0.8rem; }
  .product-section { padding: 60px 20px; }
  .section-title { font-size: 1.5rem; }
  .panels-section { padding: 60px 20px; }
  .panels-grid { grid-template-columns: 1fr; gap: 50px; }
}

@media (max-width: 480px) {
  .premium-hero-title { font-size: 1.5rem; }
  .product-items { gap: 0; }
  .item-cop img { max-height: 550px; max-width: 260px; }
  .item-lop img { max-height: 275px; max-width: 140px; }
}

/* ============================================
   END COP ARCHIVE PAGE STYLES
   ============================================ */

/* ============================================
   LIVE PRODUCT SEARCH - Safeline Style
   ============================================ */

/* Search toggle in menu */
.menu-item-search .pelekis-search-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 15px !important;
  cursor: pointer;
}

.menu-item-search .pelekis-search-toggle svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
}

.menu-item-search .pelekis-search-toggle:hover {
  color: #c41e3a;
}

.menu-item-search .pelekis-search-toggle:hover svg {
  stroke: #c41e3a;
}

/* Search bar - below header */
.pelekis-search-bar {
  display: none;
  width: 100%;
  background: #fff;
  z-index: 999;
  position: relative;
}

.pelekis-search-bar.active {
  display: block;
}

/* Dim overlay - positioned by JavaScript below search bar */
.pelekis-search-blur-overlay {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.75);
  z-index: 99;
  pointer-events: auto;
}

.pelekis-search-blur-overlay.active {
  display: block;
}

/* Search bar styling */
.pelekis-search-bar {
  position: relative;
  z-index: 100;
  background: #fff;
}

.pelekis-search-bar-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 25px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 2px solid #1a1a1a;
}

.pelekis-search-bar-input {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 15px;
}

.pelekis-search-bar-input svg {
  width: 28px;
  height: 28px;
  stroke: #1a1a1a;
  flex-shrink: 0;
}

.pelekis-search-bar-input input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 22px;
  font-weight: 400;
  color: #1a1a1a;
  background: transparent;
  padding: 5px 0;
}

.pelekis-search-bar-input input::placeholder {
  color: #999;
}

.pelekis-search-bar-close {
  background: none;
  border: none;
  font-size: 16px;
  color: #1a1a1a;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 0;
  margin-left: 30px;
}

.pelekis-search-bar-close span {
  font-size: 22px;
  line-height: 1;
}

.pelekis-search-bar-close:hover {
  color: #c41e3a;
}

/* Search results dropdown */
.pelekis-search-bar-results {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 40px;
  max-height: 70vh;
  overflow-y: auto;
  background: #fff;
}

.pelekis-search-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0;
  padding: 20px 0;
}

.pelekis-search-result-item {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px 20px;
  text-decoration: none;
  color: #1a1a1a;
  border-bottom: 1px solid #eee;
  transition: background 0.2s ease;
}

.pelekis-search-result-item:hover {
  background: #f8f8f8;
}

.pelekis-search-result-item img {
  width: 50px;
  height: 50px;
  object-fit: contain;
  background: #f5f5f5;
  border-radius: 4px;
}

.pelekis-search-result-details {
  flex: 1;
}

.pelekis-search-result-name {
  font-size: 15px;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 3px;
}

.pelekis-search-result-item:hover .pelekis-search-result-name {
  color: #c41e3a;
}

.pelekis-search-result-sku {
  font-size: 13px;
  color: #888;
}

.pelekis-search-no-results,
.pelekis-search-loading {
  padding: 40px;
  text-align: center;
  color: #666;
  font-size: 16px;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .pelekis-search-bar-inner {
    padding: 20px;
  }

  .pelekis-search-bar-input input {
    font-size: 18px;
  }

  .pelekis-search-bar-input svg {
    width: 22px;
    height: 22px;
  }

  .pelekis-search-bar-results {
    padding: 0 20px;
  }

  .pelekis-search-results-grid {
    grid-template-columns: 1fr;
  }

  .menu-item-search .pelekis-search-toggle span {
    display: none;
  }
}

/* ============================================
   END LIVE PRODUCT SEARCH
   ============================================ */

/* ============================================
   NEW PRODUCTS & POPULAR PRODUCTS SECTIONS
   ============================================ */

/* Product grid layout - 4 columns */
.pelekis-product-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.pelekis-product-grid .product {
  margin: 0 !important;
  padding: 0;
  width: 100% !important;
  float: none !important;
}

/* NEW Badge styling */
.pelekis-new-badge {
  position: absolute;
  top: -8px;
  left: -8px;
  background: #1a1a1a;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 3px;
  z-index: 20;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* Ensure product card is relative for badge positioning */
.pelekis-product-grid .product,
.woocommerce ul.products li.product,
.wc-block-grid__product,
ul.products li.product {
  position: relative;
}

/* Badge positioning for homepage WooCommerce blocks - top left of grey box */
.wc-block-grid__product .pelekis-new-badge,
.woocommerce ul.products li.product .pelekis-new-badge,
ul.products li.product .pelekis-new-badge {
  position: absolute;
  top: -8px;
  left: -8px;
  z-index: 20;
}

/* Single product page badge */
.single-product .pelekis-new-badge {
  top: 10px;
  left: 10px;
  font-size: 13px;
  padding: 8px 16px;
}

/* Section titles */
.pelekis-section-title {
  font-size: 32px;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 30px;
  text-align: center;
}

/* Responsive - Tablet */
@media (max-width: 1024px) {
  .pelekis-product-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}

/* Responsive - Mobile */
@media (max-width: 768px) {
  .pelekis-product-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }

  .pelekis-new-badge {
    font-size: 10px;
    padding: 4px 8px;
    top: 8px !important;
    left: 8px !important;
  }

  /* Ensure mobile carousels and product grids don't clip the badge */
  .wc-block-grid__products,
  .wc-block-grid__product,
  ul.products li.product {
    overflow: visible !important;
  }

  .pelekis-section-title {
    font-size: 24px;
    margin-bottom: 20px;
  }
}

/* Responsive - Small Mobile */
@media (max-width: 480px) {
  .pelekis-product-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   END NEW PRODUCTS & POPULAR PRODUCTS
   ============================================ */

/* ============================================
   PRODUCT CARD GREY BACKGROUND (Safeline Style)
   ============================================ */

/* Grey background on product cards - BASE (all pages) */
.woocommerce ul.products li.product,
ul.products li.product,
.wc-block-grid__product {
  background-color: #f9f9f9 !important;
  border-radius: 8px;
  padding: 25px !important;
  text-align: center;
  transition: background-color 0.3s ease;
  position: relative;
  min-height: 450px !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Hover effect */
.woocommerce ul.products li.product:hover,
ul.products li.product:hover,
.wc-block-grid__product:hover {
  background-color: #f0f0f0 !important;
}

/* Product images - bigger on internal pages */
.woocommerce ul.products li.product img,
ul.products li.product img {
  width: 100% !important;
  height: 300px !important;
  max-width: 100% !important;
  object-fit: contain !important;
  margin: 0 auto !important;
  display: block !important;
}

/* Product title styling - fixed height for consistency */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title,
.wc-block-grid__product-title {
  margin-top: auto !important;
  margin-bottom: 0 !important;
  padding-top: 10px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #1a1a1a !important;
  text-align: center !important;
  line-height: 1.4 !important;
  min-height: 45px !important;
}

/* Hide price on all pages */
.woocommerce ul.products li.product .price,
.wc-block-grid__product-price {
  display: none !important;
}

/* Hide buttons on all pages */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.woocommerce ul.products li.product a.added_to_cart,
ul.products li.product .button,
.wc-block-grid__product-add-to-cart,
.add_to_cart_button,
a.button.product_type_simple {
  display: none !important;
}

/* ============================================
   HOMEPAGE ONLY - Larger product cards
   ============================================ */

/* Homepage - bigger cards */
.home .wc-block-grid__product,
.page-id-1354 .wc-block-grid__product {
  padding: 20px !important;
  min-height: 400px !important;
}

/* Homepage - bigger image container */
.home .wc-block-grid__product .wc-block-grid__product-image,
.home .wc-block-grid__product .wc-block-grid__product-link,
.page-id-1354 .wc-block-grid__product .wc-block-grid__product-image,
.page-id-1354 .wc-block-grid__product .wc-block-grid__product-link {
  display: block !important;
  min-height: 300px !important;
}

/* Homepage - bigger images */
.home .wc-block-grid__product img,
.home .wc-block-grid__product .wc-block-grid__product-image img,
.page-id-1354 .wc-block-grid__product img,
.page-id-1354 .wc-block-grid__product .wc-block-grid__product-image img {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 320px !important;
  min-height: 250px !important;
  object-fit: contain !important;
  margin: 0 auto !important;
  display: block !important;
}

/* Homepage - bigger title */
.home .wc-block-grid__product-title,
.page-id-1354 .wc-block-grid__product-title {
  margin-top: 15px !important;
  font-size: 15px !important;
}

/* Desktop - 4 columns */
@media (min-width: 1024px) {
  .home .wc-block-grid__products,
  .page-id-1354 .wc-block-grid__products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 15px !important;
  }

  .home .wc-block-grid__product,
  .page-id-1354 .wc-block-grid__product {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* Tablet - 2 columns */
@media (min-width: 768px) and (max-width: 1023px) {
  .home .wc-block-grid__products,
  .page-id-1354 .wc-block-grid__products {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 15px !important;
  }
}

/* Mobile - Horizontal swipe carousel */
@media (max-width: 767px) {
  .home .wc-block-grid__products,
  .page-id-1354 .wc-block-grid__products {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch;
    gap: 15px !important;
    padding-bottom: 10px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .home .wc-block-grid__products::-webkit-scrollbar,
  .page-id-1354 .wc-block-grid__products::-webkit-scrollbar {
    display: none;
  }

  .home .wc-block-grid__product,
  .page-id-1354 .wc-block-grid__product {
    width: 85% !important;
    flex: 0 0 85% !important;
    max-width: 85% !important;
    scroll-snap-align: center;
    scroll-snap-stop: always;
    padding: 20px !important;
  }

  .home .wc-block-grid__product-title,
  .page-id-1354 .wc-block-grid__product-title {
    font-size: 18px !important;
  }
}

/* ============================================
   END PRODUCT CARD GREY BACKGROUND
   ============================================ */

/* ============================================
   FULL WIDTH IMAGES ON HOMEPAGE
   ============================================ */
.home .wp-block-image.alignfull,
.home .wp-block-image.is-style-full-width,
.home .full-width-image,
.page-id-1354 .wp-block-image.alignfull {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
}

.home .wp-block-image.alignfull img,
.home .wp-block-image.is-style-full-width img,
.home .full-width-image img,
.page-id-1354 .wp-block-image.alignfull img {
  width: 100% !important;
  height: auto !important;
}

/* ============================================
   END FULL WIDTH IMAGES
   ============================================ */

/* ============================================
   INTERNAL PRODUCT PAGES - Sidebar & Layout
   ============================================ */

/* Sidebar on product archive pages */
body:not(.home) .widget-area,
body:not(.home) #secondary,
body:not(.home) aside.sidebar,
.woocommerce-page:not(.home) .widget-area,
.archive:not(.home) .widget-area {
  width: 350px !important;
  min-width: 350px !important;
  max-width: 350px !important;
  flex: 0 0 350px !important;
  padding: 15px !important;
  background: #fff !important;
  overflow: visible !important;
}

/* Sidebar widget styling */
body:not(.home) .widget-area .widget,
body:not(.home) #secondary .widget {
  margin-bottom: 20px !important;
  padding: 0 !important;
}

/* Sidebar links - no wrap */
body:not(.home) .widget-area a,
body:not(.home) #secondary a {
  font-size: 14px !important;
  line-height: 1.6 !important;
  white-space: nowrap !important;
}

/* Main container - full width */
body:not(.home) .site-content .content-area,
body:not(.home) #primary,
.woocommerce-page:not(.home) .site-content,
.archive:not(.home) .site-content {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 20px !important;
}

/* Wider content area for products */
body:not(.home) .content-area,
body:not(.home) #primary,
.woocommerce-page:not(.home) .content-area,
.archive:not(.home) .content-area {
  flex: 1 !important;
  max-width: calc(100% - 370px) !important;
  width: calc(100% - 370px) !important;
}

/* Single product page - reclaim sidebar space (no category sidebar shown here) */
.single-product .content-area,
.single-product #primary,
body.single-product .content-area,
body.single-product #primary {
  max-width: 100% !important;
  width: 100% !important;
}

/* Breadcrumbs - add space below the top menu so they don't stick to it */
.woocommerce-breadcrumb,
nav.woocommerce-breadcrumb {
  margin-top: 70px !important;
  padding-top: 10px !important;
  font-size: 17px !important;
  color: #888 !important;
  letter-spacing: 0.2px !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  line-height: 1.5 !important;
}

.woocommerce-breadcrumb a,
nav.woocommerce-breadcrumb a {
  white-space: normal !important;
  word-break: normal !important;
}

/* Breadcrumb links - keep them subtle gray */
.woocommerce-breadcrumb a,
nav.woocommerce-breadcrumb a {
  color: #888 !important;
  font-weight: 400 !important;
  text-decoration: none !important;
}

.woocommerce-breadcrumb a:hover,
nav.woocommerce-breadcrumb a:hover {
  color: #555 !important;
}

/* The last text node (the current page name, after the final separator) - bold dark */
.woocommerce-breadcrumb {
  font-weight: 800 !important;
  color: #000 !important;
}

/* Make sure links inside override the bold/dark to stay subtle */
.woocommerce-breadcrumb a {
  font-weight: 400 !important;
  color: #888 !important;
}

/* ============================================
   CUSTOM NEWS - PROJECTS section (replaces broken GenerateBlocks query-loop)
   Uses self-contained class names that won't conflict with anything else.
   ============================================ */
.pelekis-news-projects {
  max-width: 1400px;
  margin: 0 auto;
  padding: 80px 20px;
  text-align: center;
}

.pelekis-news-projects__inner { width: 100%; }

.pelekis-news-projects__label {
  color: var(--accent, #008cff);
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.5em;
}

.pelekis-news-projects__title {
  font-size: 40px;
  font-weight: 700;
  margin: 0 0 40px;
  text-align: center;
}

.pelekis-news-projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}

.pelekis-news-card {
  background-color: var(--base-2, #f5f5f5);
  border: 1px solid var(--base, #e5e5e5);
  border-radius: 5px;
  padding: 15px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.pelekis-news-card__link {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

.pelekis-news-card__image {
  width: 100%;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin-bottom: 20px;
}

.pelekis-news-card__image img {
  max-width: 100%;
  max-height: 220px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.pelekis-news-card__date {
  text-align: center;
  color: #39424b;
  font-size: 16px;
  font-weight: 300;
  margin-bottom: 20px;
}

.pelekis-news-card__title {
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 10px;
  color: var(--contrast-2, #222);
}

.pelekis-news-card__link:hover .pelekis-news-card__title { color: var(--accent, #008cff); }

.pelekis-news-card__more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-top: auto;
  padding-top: 30px;
  font-size: 15px;
  color: var(--contrast, #222);
}

.pelekis-news-card__more-icon { margin-left: 0.5em; font-size: 0.9em; }

.pelekis-news-projects__view-all {
  margin-top: 50px;
  text-align: center;
}

.pelekis-news-projects__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 32px;
  background: var(--accent, #008cff);
  color: #fff;
  border-radius: 3px;
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: opacity 0.2s ease;
}

.pelekis-news-projects__cta:hover { opacity: 0.85; color: #fff; }
.pelekis-news-projects__cta span { margin-left: 0.7em; font-size: 0.9em; }

/* Mobile: horizontal swipe carousel (works regardless of language because we control the classes) */
@media (max-width: 768px) {
  .pelekis-news-projects { padding: 60px 0; }

  .pelekis-news-projects__title { font-size: 28px; padding: 0 16px; }
  .pelekis-news-projects__label { padding: 0 16px; }

  .pelekis-news-projects__grid {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    grid-template-columns: none;
    gap: 12px;
    padding: 0 16px 12px;
    scroll-padding-left: 16px;
  }

  .pelekis-news-card {
    flex: 0 0 85%;
    min-width: 85%;
    max-width: 85%;
    scroll-snap-align: start;
    box-sizing: border-box;
  }

  .pelekis-news-projects__view-all { margin-top: 30px; padding: 0 16px; }
}

/* News - Projects section ONLY (uses body.home + the unique grid wrapper class
   so TranslatePress's runtime DOM modifications can't break the descendant chain) */

/* Make the card a flex column so Learn More can be pushed to bottom */
body.home .gb-grid-wrapper-cd6ef286 .gb-container-97f899be {
  display: flex !important;
  flex-direction: column !important;
}

body.home .gb-grid-wrapper-cd6ef286 .gb-container-97f899be > .gb-inside-container {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  height: 100% !important;
}

/* Fixed image area for all cards - same size regardless of image dimensions */
body.home .gb-grid-wrapper-cd6ef286 figure.gb-block-image {
  width: 100% !important;
  height: 220px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  margin: 0 auto 20px !important;
}

body.home .gb-grid-wrapper-cd6ef286 figure.gb-block-image img {
  max-width: 100% !important;
  max-height: 220px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}

/* Push Learn More button to the bottom of each card */
body.home .gb-grid-wrapper-cd6ef286 .gb-button-wrapper {
  margin-top: auto !important;
}

/* Product grid on internal pages - 4 columns */
body:not(.home) .woocommerce ul.products,
body:not(.home) ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  width: 100% !important;
}

/* MOBILE FIXES (max-width: 768px) */
@media (max-width: 768px) {
  /* Reclaim full width on mobile - no 370px sidebar reservation */
  body:not(.home) .content-area,
  body:not(.home) #primary,
  .woocommerce-page:not(.home) .content-area,
  .archive:not(.home) .content-area {
    max-width: 100% !important;
    width: 100% !important;
  }

  /* 2-column product grid on mobile */
  body:not(.home) .woocommerce ul.products,
  body:not(.home) ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
    align-items: stretch !important;
    grid-auto-rows: 1fr !important;
  }

  /* Related/Upsell products on single product page - horizontal swipe carousel */
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products,
  .related.products ul.products,
  .upsells.products ul.products {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    grid-template-columns: none !important;
    grid-auto-rows: auto !important;
    gap: 12px !important;
    padding: 0 4px 10px !important;
    margin: 0 !important;
  }

  .single-product .related.products ul.products li.product,
  .single-product .upsells.products ul.products li.product,
  .related.products ul.products li.product,
  .upsells.products ul.products li.product {
    flex: 0 0 calc(50% - 6px) !important;
    min-width: calc(50% - 6px) !important;
    max-width: calc(50% - 6px) !important;
    scroll-snap-align: start !important;
  }

  /* Smaller breadcrumbs on mobile */
  .woocommerce-breadcrumb,
  nav.woocommerce-breadcrumb {
    margin-top: 30px !important;
    font-size: 13px !important;
    padding: 0 10px !important;
  }

  /* News - Projects section: CSS Grid carousel using viewport-relative units.
     vw (viewport width) bypasses any parent padding/margin calculation issues. */
  body.home .gb-grid-wrapper-cd6ef286,
  .gb-grid-wrapper.gb-grid-wrapper-cd6ef286 {
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: 85vw !important;
    grid-template-columns: unset !important;
    grid-auto-rows: auto !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    gap: 12px !important;
    padding: 0 16px 12px !important;
    scroll-padding: 16px !important;
    margin-left: 0 !important;
    flex-wrap: unset !important;
  }

  /* Each column fills its grid cell (which is 85vw wide) */
  body.home .gb-grid-column-97f899be,
  body.home .gb-grid-wrapper-cd6ef286 .gb-grid-column-97f899be,
  .gb-grid-wrapper-cd6ef286 .gb-grid-column-97f899be {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    scroll-snap-align: start !important;
    padding-left: 0 !important;
    padding-bottom: 0 !important;
    box-sizing: border-box !important;
  }

  /* Tighter product cards - card height fits content (image + title only) */
  body:not(.home) .woocommerce ul.products li.product,
  body:not(.home) ul.products li.product {
    height: auto !important;
    min-height: 0 !important;
    padding: 15px 12px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    align-content: flex-start !important;
  }

  body:not(.home) .woocommerce ul.products li.product a,
  body:not(.home) ul.products li.product a {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: center !important;
    height: auto !important;
    flex: 0 0 auto !important;
  }

  body:not(.home) .woocommerce ul.products li.product img,
  body:not(.home) ul.products li.product img {
    height: 140px !important;
    max-height: 140px !important;
    width: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    margin: 0 auto 10px !important;
    display: block !important;
    align-self: stretch !important;
    flex: 0 0 140px !important;
  }

  body:not(.home) .woocommerce ul.products li.product h2,
  body:not(.home) .woocommerce ul.products li.product .woocommerce-loop-product__title,
  body:not(.home) ul.products li.product h2,
  body:not(.home) ul.products li.product .woocommerce-loop-product__title {
    font-size: 13px !important;
    line-height: 1.3 !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: center !important;
  }
}

/* Hide result count and ordering dropdown */
body:not(.home) .woocommerce-result-count,
body:not(.home) .woocommerce-ordering,
.woocommerce-result-count,
.woocommerce-ordering {
  display: none !important;
}

/* Make product cards fill their grid cell - fix first item issue */
body:not(.home) .woocommerce ul.products li.product,
body:not(.home) ul.products li.product {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
}

/* Remove any ::before or first-child spacing */
body:not(.home) .woocommerce ul.products::before,
body:not(.home) .woocommerce ul.products::after,
body:not(.home) ul.products::before,
body:not(.home) ul.products::after {
  display: none !important;
  content: none !important;
}

body:not(.home) .woocommerce ul.products li.product:first-child,
body:not(.home) ul.products li.product:first-child {
  margin-left: 0 !important;
  grid-column: auto !important;
}

/* ============================================
   END INTERNAL PRODUCT PAGES
   ============================================ */

/* ============================================
   NEWS & PROJECTS SECTION - Homepage
   ============================================ */

/* Section container */
.home .wp-block-latest-posts,
.home .news-projects-section {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 25px !important;
  margin: 40px 0 !important;
}

/* Individual news card */
.home .wp-block-latest-posts__post-container,
.home .wp-block-latest-posts li,
.home .news-card {
  background-color: #f9f9f9 !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
  position: relative !important;
}

.home .wp-block-latest-posts li:hover,
.home .news-card:hover {
  background-color: #f0f0f0 !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1) !important;
}

/* Featured image */
.home .wp-block-latest-posts__featured-image,
.home .news-card-image {
  width: 100% !important;
  height: 200px !important;
  overflow: hidden !important;
}

.home .wp-block-latest-posts__featured-image img,
.home .news-card-image img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
}

/* Post title */
.home .wp-block-latest-posts__post-title,
.home .news-card-title {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #1a1a1a !important;
  padding: 15px 20px 10px !important;
  margin: 0 !important;
  text-decoration: none !important;
  display: block !important;
  line-height: 1.4 !important;
}

.home .wp-block-latest-posts__post-title:hover {
  color: #c41e3a !important;
}

/* Post excerpt */
.home .wp-block-latest-posts__post-excerpt,
.home .news-card-excerpt {
  font-size: 14px !important;
  color: #666 !important;
  padding: 0 20px 15px !important;
  margin: 0 !important;
  line-height: 1.6 !important;
}

/* Post date */
.home .wp-block-latest-posts__post-date,
.home .news-card-date {
  font-size: 12px !important;
  color: #999 !important;
  padding: 0 20px 20px !important;
  display: block !important;
}

/* Section heading */
.home .news-section-title,
.home h2.wp-block-heading + .wp-block-latest-posts {
  margin-top: 20px !important;
}

/* Tablet - 2 columns */
@media (max-width: 1024px) {
  .home .wp-block-latest-posts {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Mobile - 1 column */
@media (max-width: 767px) {
  .home .wp-block-latest-posts {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  .home .wp-block-latest-posts__featured-image,
  .home .wp-block-latest-posts__featured-image img {
    height: 180px !important;
  }
}

/* ============================================
   END NEWS & PROJECTS SECTION
   ============================================ */
