/*
 Theme Name:   Inteli-Shop
 Theme URI:    https://inteli-shop.ro
 Description:  Intelitech branded WooCommerce child theme — Daikin HVAC catalog
 Author:       INTELITECH GROUP SRL
 Author URI:   https://inteli-tech.ro
 Template:     storefront
 Version:      1.7.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  inteli-shop
*/

/* ==========================================================================
   INTELITECH BRAND DESIGN TOKENS (Brand Guidelines v2.0)
   ========================================================================== */

:root {
  /* Primary Green Family */
  --it-green: #6AC350;
  --it-green-hover: #2AA83F;
  --it-green-text: #017C16;
  --it-green-pale: #B2F182;
  --it-green-glow: #8DDF64;
  --it-green-light: #D0ECCD;
  --it-green-lightest: #DFF1DD;

  /* Secondary Blue (legacy) */
  --it-blue: #00A0E3;
  --it-blue-sky: #44C7F4;
  --it-blue-tint: #E4F5FF;

  /* Neutrals — Dark */
  --it-dark: #1A1A1A;
  --it-charcoal: #24292E;
  --it-grey-700: #333333;
  --it-logo-dark: #3A3A3A;
  --it-grey-800: #3C4D62;

  /* Neutrals — Mid */
  --it-grey-50: #7A7D7F;
  --it-grey-400: #A7ABAD;
  --it-silver: #BABDBF;
  --it-grey-150: #C9CDD1;

  /* Neutrals — Light */
  --it-border: #DDE1E4;
  --it-grey-100: #F0F2F5;
  --it-bg: #F2F5F7;
  --it-whitesmoke: #FAFBFC;
  --it-white: #FFFFFF;

  /* Semantic */
  --it-error: #D73A49;
  --it-success: #28A745;

  /* Shadows */
  --it-shadow-card: -4px 4px 10px 0px rgba(143,164,179,0.15), 5px -2px 10px 0px rgba(165,176,190,0.15);
  --it-shadow-elevated: rgba(0,0,0,0.06) 0px 2px 32px 0px;
  --it-shadow-deep: rgba(87,133,153,0.12) 0px 12px 32px -4px;
  --it-shadow-green-glow: rgb(178,241,130) -8px 0px 30px 4px;
  --it-shadow-cta: rgba(106,195,80,0.3) 10px -3px 40px -10px, rgba(106,195,80,0.3) -10px 3px 40px 0px;

  /* Gradients */
  --it-gradient-brand: linear-gradient(45deg, #6AC350, #B2F182 62%);
  --it-gradient-warm: linear-gradient(20deg, rgba(255,243,156,0.25), transparent 80%);

  /* Transitions */
  --it-transition-fast: 0.2s ease-out;
  --it-transition-medium: 0.3s ease-out;
  --it-transition-slow: 0.6s ease-out;

  /* Typography */
  --it-font: 'Rubik', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Layout */
  --it-nav-height: 72px;
  --it-max-width: 1280px;
  --it-radius-sm: 4px;
  --it-radius-md: 8px;
  --it-radius-lg: 16px;
  --it-radius-pill: 800px;
}

/* ==========================================================================
   GLOBAL RESET & BASE
   ========================================================================== */

body,
.storefront-full-width-content .site {
  background-color: var(--it-bg);
  font-family: var(--it-font);
  font-size: 16px;
  font-weight: 400;
  color: var(--it-charcoal);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

* {
  box-sizing: border-box;
}

/* ==========================================================================
   TYPOGRAPHY
   ========================================================================== */

h1, h2, h3, h4, h5, h6,
.woocommerce div.product .product_title,
.page-title,
.entry-title {
  font-family: var(--it-font);
  color: var(--it-charcoal);
  letter-spacing: -0.02em;
  line-height: 1.2;
}

h1, .entry-title {
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 700;
}

h2, .page-title {
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 600;
}

h3 {
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 500;
}

p, li, td, th, label, input, textarea, select {
  font-family: var(--it-font);
}

a {
  color: var(--it-green-text);
  text-decoration: none;
  transition: color var(--it-transition-fast);
}

a:hover,
a:focus {
  color: var(--it-green-hover);
}

/* Heading underline effect (from brand guidelines) */
.woocommerce-products-header__title,
.page-title {
  display: inline;
  background-image: linear-gradient(transparent 60%, rgba(141,223,100,0.35) 60%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: 0 4px;
}

/* ==========================================================================
   LAYOUT
   ========================================================================== */

.col-full,
.site-content .col-full {
  max-width: var(--it-max-width);
  padding-left: 24px;
  padding-right: 24px;
}

.site-content {
  padding-top: 32px;
}
.tax-product_cat .site-content {
  padding-top: 0;
}

/* ==========================================================================
   NAVIGATION — single row: logo left, menu right, blends with hero
   ========================================================================== */

/* Hide secondary nav, search, and handheld footer nav */
.secondary-navigation,
.site-search,
.storefront-handheld-footer-bar,
.storefront-primary-navigation .handheld-navigation,
#site-navigation > div:last-child {
  display: none !important;
}

/* Unified header wrapper — no borders, blends with hero */
.site-header,
.storefront-primary-navigation {
  background-color: var(--it-white) !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Fix: allow sticky header by removing overflow from wrapper */
.hfeed.site {
  overflow: visible !important;
}

/* Single-row header: full-width white bar, content aligned with hero */
.site-header {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center;
  min-height: 68px;
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 calc((100vw - var(--it-max-width)) / 2 + 24px) !important;
  background-color: #FFFFFF !important;
  position: sticky;
  top: 0;
  z-index: 999;
}

.site-header > .col-full {
  flex: 0 0 auto;
  width: auto !important;
  padding: 0;
  max-width: none;
}

/* Primary nav fills remaining space, menu pushed right */
.storefront-primary-navigation {
  flex: 1 1 auto;
  padding: 0;
  background-color: transparent !important;
}

.storefront-primary-navigation .col-full {
  max-width: none;
  padding: 0;
}

.main-navigation {
  display: flex;
  justify-content: flex-end;
  width: 100% !important;
  float: none !important;
}

.main-navigation ul.menu {
  display: flex;
  align-items: center;
}

/* Hide phone CTA button from nav */
.nav-phone-cta,
.menu-item .nav-phone-cta {
  display: none !important;
}

/* Nav links */
.main-navigation ul li a,
.site-header-cart a,
.site-header .site-header-cart a {
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 15px;
  color: #373737;
  letter-spacing: 0;
  transition: color 0.2s;
  padding: 8px 18px;
}

.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item > a {
  color: #42A226;
}

.main-navigation ul.menu > li.current-menu-item > a {
  color: #42A226;
}

/* Dropdown menus */
.main-navigation ul.menu ul {
  background-color: var(--it-whitesmoke);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-md);
  box-shadow: var(--it-shadow-deep);
  padding: 8px 0;
}

.main-navigation ul.menu ul li a {
  padding: 10px 24px;
  font-size: 14px;
}

.main-navigation ul.menu ul li a:hover {
  background-color: var(--it-green-lightest);
  color: var(--it-green-text);
}

/* Site branding / Logo */
.site-branding {
  padding: 12px 0;
  flex-shrink: 0;
}

.site-header .custom-logo-link img,
.custom-logo-link img,
.site-branding img {
  width: 180px !important;
  max-width: none !important;
  height: auto !important;
  max-height: none !important;
}

.site-title a {
  font-family: var(--it-font);
  font-weight: 700;
  color: var(--it-charcoal);
  font-size: 22px;
}

/* Phone CTA in nav (added via functions.php) */
.nav-phone-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--it-green);
  color: var(--it-white) !important;
  padding: 8px 16px;
  border-radius: var(--it-radius-pill);
  font-weight: 500;
  font-size: 14px;
  transition: background var(--it-transition-fast), box-shadow var(--it-transition-fast);
}

.nav-phone-cta:hover {
  background: var(--it-green-hover);
  color: var(--it-white) !important;
  box-shadow: var(--it-shadow-cta);
}

.nav-phone-cta svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

/* ==========================================================================
   BUTTONS (Brand Guidelines: bg #6AC350, text #FAFBFC, radius 4px)
   ========================================================================== */

button,
input[type="button"],
input[type="submit"],
.button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.storefront-button,
.added_to_cart {
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 14px;
  background-color: var(--it-green);
  color: var(--it-whitesmoke);
  border: 1px solid var(--it-green);
  border-radius: var(--it-radius-sm);
  padding: 16px 32px;
  cursor: pointer;
  transition: background-color var(--it-transition-fast), border-color var(--it-transition-fast), box-shadow var(--it-transition-fast);
  text-transform: none;
  letter-spacing: 0;
  line-height: 1;
  box-shadow: var(--it-shadow-cta);
}

button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover {
  background-color: var(--it-green-hover);
  border-color: var(--it-green-hover);
  color: var(--it-whitesmoke);
}

/* Ghost / Secondary button */
.button.ghost,
.woocommerce a.button.ghost {
  background: rgba(255,255,255,0.6);
  color: var(--it-green-text);
  border: 1px solid var(--it-border);
  box-shadow: none;
}

.button.ghost:hover {
  border-color: var(--it-green);
  color: var(--it-green);
}

/* ==========================================================================
   FORMS (Brand: white bg, 1px #DDE1E4 border, 4px radius)
   ========================================================================== */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select,
.input-text {
  font-family: var(--it-font);
  font-size: 16px;
  background: var(--it-white);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-sm);
  padding: 8px 16px;
  min-height: 48px;
  color: var(--it-charcoal);
  transition: border-color var(--it-transition-fast), box-shadow var(--it-transition-fast);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--it-green);
  box-shadow: rgb(221,225,228) 0px 0px 0px 2px inset;
  outline: none;
}

/* ==========================================================================
   PRODUCT CARDS (Brand: #FAFBFC bg, 1px #DDE1E4 border, 16px radius, green glow hover)
   ========================================================================== */

.woocommerce ul.products li.product,
ul.products li.product {
  background: var(--it-white);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 0;
  overflow: hidden;
  transition: box-shadow var(--it-transition-medium), transform var(--it-transition-medium), border-color var(--it-transition-medium);
  position: relative;
}

.woocommerce ul.products li.product:hover {
  box-shadow: var(--it-shadow-green-glow);
  border-color: var(--it-green-light);
  transform: translateY(-2px);
}

/* Product image container */
.woocommerce ul.products li.product a img,
ul.products li.product a img {
  border-radius: 0;
  margin: 0;
  transition: transform var(--it-transition-medium);
}

.woocommerce ul.products li.product:hover a img {
  transform: scale(1.03);
}

.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
  overflow: hidden;
}

/* Product info area */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 16px;
  color: var(--it-charcoal);
  padding: 16px 16px 4px;
  margin: 0;
}

.woocommerce ul.products li.product .price,
ul.products li.product .price {
  color: var(--it-green-text);
  font-weight: 600;
  font-size: 18px;
  padding: 4px 16px 16px;
}

.woocommerce ul.products li.product .price del {
  color: var(--it-grey-400);
  font-weight: 400;
  font-size: 14px;
}

.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  font-weight: 700;
}

/* Category badges on product cards */
.woocommerce ul.products li.product .product-category-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--it-green);
  color: var(--it-white);
  font-size: 11px;
  font-weight: 500;
  padding: 4px 12px;
  border-radius: var(--it-radius-pill);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  z-index: 2;
}

/* ==========================================================================
   SINGLE PRODUCT PAGE
   ========================================================================== */

.woocommerce div.product {
  background: var(--it-white);
  border-radius: var(--it-radius-lg);
  border: 1px solid var(--it-border);
  padding: 32px;
  margin-bottom: 32px;
}

/* Catalog mode: hide add-to-cart button but keep variation dropdown */
.woocommerce div.product .single_add_to_cart_button,
.woocommerce div.product .quantity {
  display: none !important;
}

/* Style the variation dropdown — prominent selector */
.woocommerce div.product .variations {
  margin-bottom: 20px;
  border: none;
}
.woocommerce div.product .variations td {
  display: block;
  padding: 0;
}
.woocommerce div.product .variations td.label {
  padding-bottom: 6px;
}
.woocommerce div.product .variations td.label label {
  font-family: var(--it-font);
  font-weight: 700;
  font-size: 15px;
  color: var(--it-charcoal);
}
.woocommerce div.product .variations td.value select {
  font-family: var(--it-font);
  font-size: 16px;
  font-weight: 600;
  padding: 14px 18px;
  border: 2px solid var(--it-green);
  border-radius: var(--it-radius-sm);
  width: 100%;
  max-width: 320px;
  background: var(--it-white);
  color: var(--it-charcoal);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236AC350' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 42px;
}
.woocommerce div.product .variations td.value select:hover {
  border-color: var(--it-green-hover);
  background-color: #F0FAF0;
}
.woocommerce div.product .variations td.value select:focus {
  border-color: var(--it-green-hover);
  outline: none;
  box-shadow: 0 0 0 3px rgba(106, 195, 80, 0.25);
}

/* Hide the reset variations link */
.woocommerce div.product .reset_variations {
  display: none !important;
}

/* Hide default sale badge on single product page */
.single-product .onsale {
  display: none !important;
}

/* Style the variation price display with inline discount badge */
.woocommerce div.product .woocommerce-variation-price {
  margin: 16px 0;
}
.woocommerce div.product .woocommerce-variation-price .price {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.woocommerce div.product .woocommerce-variation-price .price del {
  font-size: 16px;
  font-weight: 400;
  color: var(--it-grey-400);
  text-decoration: line-through;
  order: 2;
}
.woocommerce div.product .woocommerce-variation-price .price ins {
  font-size: 28px !important;
  font-weight: 700;
  color: var(--it-green-text) !important;
  text-decoration: none;
  order: 1;
}
.woocommerce div.product .woocommerce-variation-price .price .it-discount-tag {
  background: #E53935;
  color: #fff;
  font-family: var(--it-font);
  font-weight: 700;
  font-size: 14px;
  padding: 5px 12px;
  border-radius: var(--it-radius-pill);
  order: 3;
  margin-left: 4px;
  line-height: 1;
  align-self: center;
}
/* If no del/ins (single price, no sale) */
.woocommerce div.product .woocommerce-variation-price .price > .woocommerce-Price-amount {
  font-size: 28px !important;
  font-weight: 700;
  color: var(--it-green-text) !important;
}

/* Hide the top-level "de la" price only on variable products (variation form shows it) */
.single-product.product-type-variable .summary > .price {
  display: none !important;
}

/* Hide breadcrumbs on product category pages — hide the entire container */
.tax-product_cat .storefront-breadcrumb {
  display: none !important;
}

/* Hide "S-ar putea să-ți placă și" upsell section (redundant) */
.single-product .upsells.products {
  display: none !important;
}

/* Center "Produse similare" related products */
.single-product .related.products ul.products {
  display: flex !important;
  justify-content: center;
  gap: 24px;
  float: none !important;
}
.single-product .related.products ul.products li.product {
  float: none !important;
  width: auto !important;
  flex: 0 1 280px;
}

.woocommerce div.product .product_title {
  font-size: clamp(24px, 4vw, 36px);
  font-weight: 700;
  margin-bottom: 8px;
}

.woocommerce div.product p.price {
  color: var(--it-green-text);
  font-size: 28px;
  font-weight: 700;
}

.woocommerce div.product p.price del {
  color: var(--it-grey-400);
  font-size: 20px;
}

/* Variation selects */
.woocommerce div.product .variations td select {
  min-width: 200px;
}

.woocommerce div.product .variations label {
  font-weight: 600;
  color: var(--it-charcoal);
}

/* Product tabs — narrow the tab labels column */
@media (min-width: 768px) {
  .woocommerce div.product .woocommerce-tabs {
    display: flex;
    gap: 32px;
  }
  .woocommerce div.product .woocommerce-tabs ul.tabs {
    flex: 0 0 160px;
    min-width: 160px;
  }
  .woocommerce div.product .woocommerce-tabs .panel {
    flex: 1;
    min-width: 0;
  }
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 2px solid var(--it-border);
  padding: 0;
  margin: 0 0 24px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: none;
  background: none;
  padding: 0;
  margin: 0 24px 0 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 15px;
  color: var(--it-grey-50);
  padding: 12px 0;
  border-bottom: 2px solid transparent;
  transition: color var(--it-transition-fast), border-color var(--it-transition-fast);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--it-green);
  border-bottom-color: var(--it-green);
}

/* Request quote button (replaces Add to Cart) */
.it-request-quote {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--it-green);
  color: var(--it-white) !important;
  padding: 16px 32px;
  border-radius: var(--it-radius-sm);
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 16px;
  transition: background var(--it-transition-fast), box-shadow var(--it-transition-fast);
  box-shadow: var(--it-shadow-cta);
  text-decoration: none;
}

.it-request-quote:hover {
  background: var(--it-green-hover);
  color: var(--it-white) !important;
}

.it-request-quote svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

/* WhatsApp button */
.it-whatsapp-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #25D366;
  color: var(--it-white) !important;
  padding: 14px 24px;
  border-radius: var(--it-radius-sm);
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 14px;
  transition: background var(--it-transition-fast);
  text-decoration: none;
  margin-left: 12px;
}

.it-whatsapp-btn:hover {
  background: #1da851;
  color: var(--it-white) !important;
}

/* ==========================================================================
   PRODUCT GRID LAYOUT (override StoreFront floats inside matching @media)
   ========================================================================== */

/* Ensure product grid starts clean — kill Storefront clearfix pseudo-elements
   which become grid children and steal a cell in the first row */
.woocommerce ul.products {
  clear: both !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none !important;
  content: none !important;
}

/* Position sale badge absolutely on archive product cards */
.woocommerce ul.products li.product {
  position: relative;
}
.woocommerce ul.products li.product .onsale {
  position: absolute !important;
  top: 12px;
  left: 12px;
  z-index: 2;
  margin: 0;
}

/* Base grid — override Storefront float layout at ALL widths */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* Kill all Storefront float/width rules on product items */
ul.products li.product,
ul.products .wc-block-grid__product,
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.site-main ul.products li.product,
.site-main ul.products.columns-3 li.product,
.site-main ul.products.columns-4 li.product,
.storefront-full-width-content .site-main ul.products li.product,
.storefront-full-width-content .site-main ul.products.columns-3 li.product,
.storefront-full-width-content .site-main ul.products.columns-4 li.product,
.page-template-template-fullwidth-php .site-main ul.products.columns-3 li.product,
.page-template-template-fullwidth-php .site-main ul.products.columns-4 li.product {
  width: 100% !important;
  float: none !important;
  margin-right: 0 !important;
  margin-left: 0 !important;
  margin-bottom: 0 !important;
}

@media (max-width: 768px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* Product images must fill their cards */
ul.products li.product a img,
.woocommerce ul.products li.product a img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* ==========================================================================
   WIDGETS & SIDEBAR
   ========================================================================== */

.widget {
  background: var(--it-whitesmoke);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 24px;
  margin-bottom: 24px;
}

.widget-title,
.widget h2 {
  font-size: 16px;
  font-weight: 600;
  color: var(--it-charcoal);
  border-bottom: 2px solid var(--it-green);
  padding-bottom: 8px;
  margin-bottom: 16px;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

.site-footer {
  background: var(--it-charcoal);
  color: var(--it-grey-150);
  padding: 180px 0 0;
  position: relative;
  z-index: 1;
  margin-top: -180px;
  clip-path: polygon(0 140px, 100% 0, 100% 100%, 0 100%);
}

/* Remove gap between content and footer on homepage */
.home .site-content {
  margin-bottom: 0 !important;
}

.home #main {
  margin-bottom: 0 !important;
}

/* Add bottom padding so diagonal footer doesn't overlap content */
.woocommerce-page .site-content {
  padding-bottom: 200px;
}

.site-footer .col-full {
  max-width: var(--it-max-width);
  padding: 0 24px;
}

.site-footer a {
  color: var(--it-grey-150);
  transition: color var(--it-transition-fast);
}

.site-footer a:hover {
  color: var(--it-green);
}

.site-footer .widget {
  background: none;
  border: none;
  padding: 0;
}

/* Footer content — logo, social, nav, legal */
.it-footer-content {
  text-align: center;
  padding-bottom: 32px;
}

.it-footer-logo {
  margin-bottom: 40px;
  display: flex;
  justify-content: center;
}

.it-footer-logo img {
  width: 240px;
  height: auto;
  filter: brightness(0) invert(1);
}

.it-footer-logo a {
  display: inline-block;
}

.it-footer-social {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-bottom: 40px;
}

.it-footer-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: var(--it-grey-150);
  transition: color var(--it-transition-fast), transform var(--it-transition-fast);
}

.it-footer-social a:hover {
  color: var(--it-green);
  transform: translateY(-2px);
}

.it-footer-social svg {
  width: 24px;
  height: 24px;
}

.it-footer-nav {
  display: flex;
  justify-content: center;
  gap: 8px 32px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.it-footer-nav a {
  font-family: var(--it-font);
  font-size: 15px;
  font-weight: 500;
  color: var(--it-whitesmoke);
  text-decoration: none;
  padding: 4px 0;
}

.it-footer-nav a:hover {
  color: var(--it-green);
}

.it-footer-legal {
  display: flex;
  justify-content: center;
  gap: 8px 16px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.it-footer-legal a {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--it-grey-400);
  text-decoration: none;
}

.it-footer-legal a:hover {
  color: var(--it-green);
}

.it-footer-legal span {
  color: var(--it-grey-600);
  font-size: 13px;
}

.site-info {
  border-top: 1px solid var(--it-grey-800);
  padding: 20px 24px;
  text-align: center;
  font-size: 13px;
  color: var(--it-grey-400);
  position: relative;
  z-index: 2;
}

.site-info strong {
  color: var(--it-whitesmoke);
}

/* ==========================================================================
   BREADCRUMBS
   ========================================================================== */

/* Breadcrumb — compact, integrated with design */
.storefront-breadcrumb {
  background: none !important;
  padding: 10px 0 0 !important;
  margin: 0 !important;
}
.woocommerce-breadcrumb {
  font-family: var(--it-font) !important;
  font-size: 13px !important;
  font-weight: 400;
  color: var(--it-grey-400) !important;
  padding: 0 !important;
  margin: 0 !important;
}
.woocommerce-breadcrumb a {
  color: var(--it-grey-400) !important;
  text-decoration: none;
  transition: color var(--it-transition-fast);
}
.woocommerce-breadcrumb a:hover {
  color: var(--it-green) !important;
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-sm);
  background: var(--it-white);
  color: var(--it-charcoal);
  font-weight: 500;
  padding: 8px 14px;
}

.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--it-green);
  border-color: var(--it-green);
  color: var(--it-white);
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--it-green-lightest);
  border-color: var(--it-green-light);
  color: var(--it-green-text);
}

/* ==========================================================================
   WC NOTICES / MESSAGES
   ========================================================================== */

.woocommerce-info,
.woocommerce-message {
  border-top-color: var(--it-green);
  background: var(--it-green-lightest);
}

.woocommerce-error {
  border-top-color: var(--it-error);
}

/* ==========================================================================
   CATEGORY PAGE HEADER
   ========================================================================== */

/* Hide the default WooCommerce products header on category pages */
.tax-product_cat .woocommerce-products-header {
  display: none !important;
}

/* Category hero — full-width, flush with navbar, image on right */
.it-category-hero {
  background: var(--it-white);
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  margin-bottom: 40px;
  border-bottom: 1px solid var(--it-border);
}
.it-category-hero-inner {
  max-width: var(--it-max-width, 1200px);
  margin: 0 auto;
  display: flex;
  align-items: center;
  min-height: 220px;
  padding: 40px 24px;
  gap: 40px;
}
.it-category-hero-text {
  flex: 1;
}
.it-category-hero h1 {
  color: var(--it-charcoal);
  font-family: var(--it-font);
  font-size: clamp(28px, 3.5vw, 42px);
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 12px;
  background: none;
  padding: 0;
  display: block;
}
.it-category-hero p {
  color: var(--it-charcoal);
  font-family: var(--it-font);
  font-size: 16px;
  line-height: 1.7;
  margin: 0 0 16px;
  opacity: 0.7;
}
.it-category-count {
  display: inline-block;
  background: var(--it-green-tint-light, #DFF1DD);
  color: var(--it-green-text);
  font-family: var(--it-font);
  font-size: 13px;
  font-weight: 600;
  padding: 6px 16px;
  border-radius: var(--it-radius-pill);
}
.it-category-hero-image {
  flex: 0 0 auto;
}
.it-category-hero-image img {
  max-height: 180px;
  width: auto;
  object-fit: contain;
}
@media (max-width: 768px) {
  .it-category-hero-inner {
    flex-direction: column;
    text-align: center;
    min-height: auto;
    padding: 32px 16px;
    gap: 24px;
  }
  .it-category-hero-image img {
    max-height: 120px;
  }
}

.term-description p {
  color: var(--it-grey-50);
  font-size: 15px;
  max-width: 720px;
}

/* ==========================================================================
   ORDERING / RESULT COUNT
   ========================================================================== */

.woocommerce-ordering select {
  font-family: var(--it-font);
  font-size: 14px;
  padding: 8px 12px;
  border-radius: var(--it-radius-sm);
  border: 1px solid var(--it-border);
  min-height: 40px;
}

.woocommerce-result-count {
  font-size: 14px;
  color: var(--it-grey-50);
}

/* ==========================================================================
   BADGES & PILLS
   ========================================================================== */

.onsale {
  background: var(--it-green) !important;
  color: var(--it-white) !important;
  border-radius: var(--it-radius-pill) !important;
  font-family: var(--it-font);
  font-size: 12px;
  font-weight: 600;
  padding: 6px 14px;
  line-height: 1;
  min-height: auto;
  min-width: auto;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
  /* ---- Mobile: consistent full-width layout ---- */

  /* Remove col-full margin so content goes edge-to-edge */
  .site-content > .col-full {
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  /* All homepage sections: full-width, consistent padding */
  .it-hero,
  .it-category-grid,
  .it-about-section,
  .it-daikin-section,
  .it-oferim-section,
  .it-recomm-section,
  .it-blog-section,
  .it-cta-section {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Hero: stack vertically, full-width */
  .it-hero {
    flex-direction: column;
    min-height: auto;
    margin-bottom: 32px;
  }

  .it-hero-visual {
    min-height: 300px;
    flex: none;
    width: 100%;
  }

  .it-hero-content {
    flex: none;
    width: 100%;
    padding: 24px 0;
  }

  /* ---- Mobile header ---- */
  .site-header {
    position: sticky;
    top: 0;
    z-index: 999;
    padding: 0 16px !important;
    min-height: 56px;
  }

  /* ---- Mobile nav: full-screen overlay ---- */

  /* Lock body scroll when menu is open */
  body:has(.main-navigation.toggled) {
    overflow: hidden !important;
  }

  .main-navigation.toggled .primary-navigation {
    display: block !important;
    position: fixed;
    top: 60px;
    left: 0;
    right: 0;
    bottom: 0;
    background: #FFFFFF;
    z-index: 99998;
    padding: 8px 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .main-navigation.toggled .primary-navigation ul.menu {
    flex-direction: column !important;
    align-items: stretch !important;
    display: flex !important;
  }

  .main-navigation.toggled .primary-navigation ul.menu > li > a {
    padding: 14px 24px;
    display: block;
    border-bottom: 1px solid #F2F5F7;
    font-size: 16px;
    color: #373737;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }

  .main-navigation.toggled .primary-navigation ul.menu > li > a:hover {
    color: #42A226;
    background: #F9FAFB;
  }

  /* Hide sub-menus by default on mobile */
  .main-navigation.toggled .primary-navigation ul.menu ul.sub-menu {
    display: none !important;
    position: static !important;
    box-shadow: none !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0;
    background: #F9FAFB;
  }

  /* Show sub-menu when parent is tapped open on mobile */
  .main-navigation.toggled .primary-navigation ul.menu li.submenu-open > ul.sub-menu {
    display: flex !important;
    flex-direction: column !important;
    padding: 8px 0 !important;
  }

  /* Toggle arrow indicator on expandable menu items */
  .main-navigation.toggled .primary-navigation ul.menu li.menu-item-has-children > a::after {
    content: '+';
    float: right;
    font-size: 18px;
    font-weight: 400;
    color: #999;
    transition: transform 0.2s ease;
  }

  .main-navigation.toggled .primary-navigation ul.menu li.menu-item-has-children.submenu-open > a::after {
    content: '−';
    color: var(--it-green);
  }

  /* Mobile submenu card items: simpler stacked layout */
  .main-navigation.toggled .menu-item-192 > .sub-menu > .menu-item > a,
  .main-navigation.toggled .menu-item-193 > .sub-menu .menu-item:not(.servicii-availability-note) > a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 24px 12px 40px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    border-bottom: 1px solid #F2F5F7 !important;
    min-height: unset !important;
  }

  /* Keep menu images small in mobile submenu */
  .main-navigation.toggled .it-produse-menu-img,
  .main-navigation.toggled .it-servicii-menu-img {
    width: 32px;
    height: 32px;
  }

  /* Hide availability note on mobile */
  .main-navigation.toggled .servicii-availability-note {
    display: none !important;
  }

  .main-navigation.toggled .primary-navigation ul.menu ul.sub-menu li a {
    padding: 10px 24px 10px 40px;
    font-size: 14px;
    border-bottom: 1px solid #F2F5F7;
  }

  .main-navigation.toggled .primary-navigation ul.menu ul.sub-menu ul.sub-menu li a {
    padding-left: 56px;
  }

  /* ---- Other mobile adjustments ---- */
  .woocommerce .products ul,
  .woocommerce ul.products {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
  }

  .woocommerce div.product {
    padding: 20px;
  }

  .col-full {
    padding-left: 16px;
    padding-right: 16px;
  }

  /* Grids to single column on mobile */
  .it-oferim-section {
    grid-template-columns: 1fr !important;
  }

  .it-oferim-header {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
  }

  .it-recomm-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .it-request-quote {
    width: 100%;
    justify-content: center;
  }

  .it-whatsapp-btn {
    margin-left: 0;
    margin-top: 12px;
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .woocommerce .products ul,
  .woocommerce ul.products {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   HIDE CART/CHECKOUT ELEMENTS (Catalog mode)
   ========================================================================== */

.site-header-cart,
.woocommerce-cart,
.woocommerce-checkout,
.cart-contents,
.widget_shopping_cart {
  display: none !important;
}

/* ==========================================================================
   GREEN ACCENT BAR (top of page, decorative — brand guidelines)
   ========================================================================== */

body::before {
  content: '';
  display: block;
  height: 4px;
  background: var(--it-gradient-brand);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99999;
}

body {
  padding-top: 4px;
}

/* ==========================================================================
   SCROLL ANIMATIONS (subtle fade-in for product cards)
   ========================================================================== */

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.woocommerce ul.products li.product {
  animation: fadeInUp 0.4s ease-out both;
}

.woocommerce ul.products li.product:nth-child(2) { animation-delay: 0.05s; }
.woocommerce ul.products li.product:nth-child(3) { animation-delay: 0.1s; }
.woocommerce ul.products li.product:nth-child(4) { animation-delay: 0.15s; }
.woocommerce ul.products li.product:nth-child(5) { animation-delay: 0.2s; }
.woocommerce ul.products li.product:nth-child(6) { animation-delay: 0.25s; }

/* ==========================================================================
   HOMEPAGE — Full-width layout for front page
   ========================================================================== */

/* Remove default page wrapper constraints on homepage */
.home .site-content .col-full,
.page-template-default.home .site-content .col-full {
  max-width: 100%;
  padding: 0;
}

.home .site-content {
  padding-top: 0;
}

.home .entry-content {
  margin: 0;
}

.home .hentry {
  margin: 0;
  padding: 0;
}

.home .page-title,
.home .entry-header,
.home .entry-title,
.home header.entry-header,
.page-id-190 .entry-header,
.page-id-190 .entry-title {
  display: none !important;
}

/* Remove storefront default styles on home */
.home .storefront-breadcrumb {
  display: none;
}

/* Section line accent (blue-green gradient like original) */
.it-section-line {
  width: 180px;
  height: 4px;
  background: linear-gradient(90deg, var(--it-blue) 33%, var(--it-charcoal) 33%, var(--it-charcoal) 66%, var(--it-green) 66%);
  border-radius: 2px;
  margin: 16px 0 24px;
}

.it-section-line--center {
  margin-left: auto;
  margin-right: auto;
}

/* ==========================================================================
   HERO SECTION
   ========================================================================== */

.it-hero {
  display: flex;
  align-items: center;
  min-height: 700px;
  background: var(--it-white);
  position: relative;
  overflow: hidden;
  padding: 40px 0;
  margin-bottom: 60px;
}

.it-hero-visual {
  position: relative;
  flex: 0 0 50%;
  min-height: 600px;
}

.it-hero-plant {
  position: absolute;
  left: -40px;
  top: 80px;
  width: 280px;
  z-index: 4;
}

.it-hero-sofa {
  position: absolute;
  bottom: 0;
  left: -100px;
  width: 130%;
  max-width: 900px;
  z-index: 1;
}

.it-hero-ac {
  position: absolute;
  top: 40px;
  left: 100px;
  width: 500px;
  z-index: 3;
}

.it-hero-content {
  flex: 0 0 45%;
  padding: 40px 60px 40px 20px;
  z-index: 4;
}

.it-hero-content h1 {
  font-size: clamp(28px, 3.5vw, 42px);
  font-weight: 700;
  line-height: 1.2;
  color: var(--it-charcoal);
  margin-bottom: 0;
}

.it-hero-content p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--it-charcoal);
  margin-bottom: 24px;
}

.it-hero-pot {
  position: absolute;
  right: -80px;
  bottom: 0;
  width: 220px;
  z-index: 1;
}

/* Green CTA button */
.it-btn-green {
  display: inline-block;
  background: var(--it-green);
  color: var(--it-white) !important;
  padding: 16px 32px;
  border-radius: var(--it-radius-sm);
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 16px;
  text-decoration: none;
  transition: background var(--it-transition-fast), box-shadow var(--it-transition-fast);
  box-shadow: var(--it-shadow-cta);
}

.it-btn-green:hover {
  background: var(--it-green-hover);
  color: var(--it-white) !important;
}

/* WhatsApp CTA button */
.it-btn-whatsapp {
  display: inline-block;
  background: #25D366;
  color: var(--it-white) !important;
  padding: 16px 32px;
  border-radius: var(--it-radius-sm);
  font-family: var(--it-font);
  font-weight: 500;
  font-size: 16px;
  text-decoration: none;
  transition: background var(--it-transition-fast);
}

.it-btn-whatsapp:hover {
  background: #1da851;
  color: var(--it-white) !important;
}

/* ==========================================================================
   CATEGORY GRID
   ========================================================================== */

.it-categories {
  padding: 0 24px;
  max-width: var(--it-max-width);
  margin: 0 auto;
}

.it-cat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto;
  gap: 16px;
}

/* Category cards — base */
.it-cat-card {
  display: block;
  background-color: var(--it-whitesmoke);
  background-size: auto 76%;
  background-position: 140% 100%;
  background-repeat: no-repeat;
  border-radius: 0;
  padding: 40px 32px 32px;
  overflow: visible;
  color: var(--it-charcoal);
  position: relative;
  min-height: 280px;
  transition:
    background-color 0.5s,
    background-position 4s cubic-bezier(0.165, 0.84, 0.44, 1),
    padding 0.6s,
    color 0.2s;
}

.it-cat-card,
.it-cat-card:hover,
.it-cat-card:focus,
.it-cat-card:visited {
  text-decoration: none !important;
}

/* Category cards — hover (blue bg + image slides in + white text) */
.it-cat-card:hover {
  background-color: var(--it-blue);
  background-position: 100% 100%;
  color: #fff;
}

.it-cat-card:hover h4,
.it-cat-card:hover .it-cat-count {
  color: #fff;
}

.it-cat-card h4 {
  font-size: 20px;
  font-weight: 600;
  margin: 0 0 4px;
  color: var(--it-charcoal);
  text-decoration: none !important;
  transition: color 200ms ease;
}

.it-cat-count {
  font-size: 14px;
  color: var(--it-grey-50);
  transition: color 200ms ease;
}

/* Hide the <img> tag — images are now CSS backgrounds */
.it-cat-card img {
  display: none;
}

/* ---- Services card (div, not link — individual links inside) ---- */
.it-cat-card--services {
  background-image: url('/wp-content/uploads/2026/03/Servicii.png');
  background-size: auto 100%;
  background-position: 110% 100%;
  cursor: default;
}

.it-cat-card--services:hover {
  background-color: var(--it-whitesmoke);
  background-position: 110% 100%;
  color: var(--it-charcoal);
}

.it-cat-card--services:hover h4,
.it-cat-card--services:hover .it-cat-subtext,
.it-cat-card--services:hover .it-service-list li {
  color: var(--it-charcoal);
}

.it-cat-subtext {
  display: block;
  font-size: 14px;
  color: var(--it-grey-50);
  margin-bottom: 16px;
  transition: color 200ms ease;
}

.it-service-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.it-service-list li {
  padding: 6px 0;
  font-size: 15px;
  font-weight: 500;
  border-bottom: none;
  position: relative;
  padding-left: 20px;
  transition: color 200ms ease;
}

.it-service-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--it-grey-400);
}

.it-service-list li a {
  color: var(--it-charcoal);
  text-decoration: none !important;
  transition: color 0.2s;
}

.it-service-list li a:hover {
  color: var(--it-blue);
}

/* Grid layout: top row 4 cols, bottom row: services (span 2) + business (span 2) */
.it-cat-card--services {
  grid-column: span 2;
}

.it-cat-card--small:not(.it-cat-card--services) {
  grid-column: span 2;
  background-size: auto 100%;
  background-position: 103% 100%;
}

/* ==========================================================================
   ABOUT / 12 ANI SECTION
   ========================================================================== */

.it-about-section {
  display: flex;
  align-items: center;
  gap: 60px;
  max-width: var(--it-max-width);
  margin: 60px auto;
  padding: 0 24px;
}

.it-about-image {
  flex: 0 0 50%;
}

.it-about-image img {
  width: 100%;
  border-radius: var(--it-radius-lg);
  object-fit: cover;
}

.it-about-content {
  flex: 1;
}

.it-about-content h2 {
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 700;
  margin-bottom: 0;
}

.it-about-content p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--it-charcoal);
  margin-bottom: 24px;
}

/* ==========================================================================
   DAIKIN SECTION
   ========================================================================== */

.it-daikin-section {
  background: var(--it-charcoal);
  padding: 60px 24px;
  margin-top: 40px;
}

.it-daikin-logo {
  display: block;
  margin: 0 auto 48px;
  max-width: 280px;
}

.it-daikin-grid {
  display: flex;
  gap: 48px;
  max-width: var(--it-max-width);
  margin: 0 auto;
  align-items: flex-start;
}

.it-daikin-image {
  flex: 0 0 48%;
}

.it-daikin-image img {
  width: 100%;
  border-radius: var(--it-radius-lg);
  object-fit: cover;
}

.it-daikin-text {
  flex: 1;
}

.it-daikin-text h3 {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 28px;
  color: var(--it-white) !important;
  margin-bottom: 20px;
}

.it-daikin-text h3 em {
  font-style: italic;
  color: var(--it-white) !important;
}

.it-daikin-icon {
  width: 40px;
  height: auto;
}

.it-daikin-text p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--it-whitesmoke);
}

/* ==========================================================================
   CE OFERIM SECTION
   ========================================================================== */

.it-oferim-section {
  max-width: var(--it-max-width);
  margin: 0 auto;
  padding: 60px 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  align-items: stretch;
}

.it-oferim-header {
  grid-column: span 2;
  grid-row: span 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 32px;
  background: var(--it-whitesmoke);
}

.it-oferim-header h3 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  margin-bottom: 0;
}

.it-oferim-card {
  background: var(--it-whitesmoke);
  padding: 20px;
  text-align: center;
  transition: background-color 0.6s;
  cursor: default;
}

.it-oferim-card:hover {
  background-color: #D1EBF3;
}

.it-oferim-card img {
  width: 120px;
  height: 100px;
  object-fit: contain;
  margin: 0 auto 16px;
  display: block;
}

.it-oferim-card h4 {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--it-charcoal);
}

.it-oferim-card p {
  font-size: 15px;
  color: var(--it-grey-50);
  margin: 0;
}

/* ==========================================================================
   CE NE RECOMANDĂ SECTION
   ========================================================================== */

.it-recomm-section {
  background: var(--it-white);
  padding: 60px 24px;
  text-align: center;
}

.it-recomm-section h3 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  margin-bottom: 0;
}

.it-recomm-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  max-width: var(--it-max-width);
  margin: 32px auto 0;
  padding-top: 36px;
}

.it-recomm-card {
  background: var(--it-whitesmoke);
  border-radius: 0;
  padding: 20px;
  text-align: center;
  transition: background-color 0.6s;
  cursor: default;
}

.it-recomm-card:hover {
  background-color: #D1EBF3;
}

.it-recomm-card img {
  width: 120px;
  height: auto;
  object-fit: contain;
  margin: -36px auto 16px;
  display: block;
}

.it-recomm-card p {
  font-size: 15px;
  color: var(--it-charcoal);
  margin: 0;
  line-height: 1.5;
}

/* ==========================================================================
   BLOG SECTION
   ========================================================================== */

.it-blog-section {
  max-width: var(--it-max-width);
  margin: 0 auto;
  padding: 60px 24px;
  text-align: center;
}

.it-blog-section h2 {
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 700;
  margin-bottom: 0;
}

.it-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
  text-align: left;
}

.it-blog-card,
.it-blog-card:hover,
.it-blog-card:focus,
.it-blog-card:visited {
  display: block;
  text-decoration: none !important;
  color: var(--it-charcoal);
  transition: transform var(--it-transition-medium);
}

.it-blog-card:hover {
  transform: translateY(-4px);
  color: var(--it-charcoal);
}

.it-blog-card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: var(--it-radius-lg);
  margin-bottom: 16px;
}

.it-blog-card h4 {
  font-size: 18px;
  font-weight: 700;
  color: var(--it-blue);
  margin: 0 0 8px;
  line-height: 1.3;
}

.it-blog-card p {
  font-size: 15px;
  color: var(--it-charcoal);
  line-height: 1.6;
  margin: 0 0 12px;
}

.it-read-more {
  color: var(--it-blue);
  font-weight: 500;
  font-size: 15px;
  display: inline-block;
  position: relative;
  padding-bottom: 4px;
}

.it-read-more::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--it-blue) 50%, var(--it-green) 50%);
  margin-top: 6px;
  border-radius: 2px;
}

/* ==========================================================================
   BLOG ARCHIVE PAGE
   ========================================================================== */

.it-blog-archive {
  padding-bottom: 200px;
}

/* Hero banner — matching Despre Noi style */
.it-blog-hero {
  text-align: center;
  padding: 80px 24px 40px;
  max-width: 800px;
  margin: 0 auto;
}

.it-blog-hero-inner {
  max-width: var(--it-max-width);
  margin: 0 auto;
}

.it-blog-hero h1 {
  font-family: var(--it-font);
  font-size: 42px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 16px;
}

.it-blog-hero p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--it-grey-50);
  max-width: 680px;
  margin: 0 auto;
}

/* Category filter tabs */
.it-blog-filters {
  border-bottom: 1px solid var(--it-border);
  padding: 0 24px;
}

.it-blog-filters-inner {
  max-width: var(--it-max-width);
  margin: 0 auto;
  display: flex;
  gap: 0;
}

.it-blog-filter-tab {
  padding: 16px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--it-charcoal);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color var(--it-transition-fast), border-color var(--it-transition-fast);
}

.it-blog-filter-tab:hover {
  color: var(--it-green);
}

.it-blog-filter-tab.active {
  color: var(--it-green);
  border-bottom-color: var(--it-green);
}

/* Blog grid wrapper */
.it-blog-grid-wrap {
  max-width: var(--it-max-width);
  margin: 0 auto;
  padding: 40px 24px 0;
}

.it-blog-archive .it-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 0;
}

/* Blog archive cards */
.it-blog-archive .it-blog-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--it-charcoal);
  transition: transform var(--it-transition-medium);
}

.it-blog-archive .it-blog-card:hover {
  transform: translateY(-4px);
}

.it-blog-card-image {
  display: block;
  overflow: hidden;
  border-radius: var(--it-radius-lg);
}

.it-blog-card-image img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: var(--it-radius-lg);
  transition: transform var(--it-transition-medium);
}

.it-blog-archive .it-blog-card:hover .it-blog-card-image img {
  transform: scale(1.05);
}

.it-blog-card-body {
  padding: 12px 0 0;
}

.it-blog-card-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  font-size: 13px;
}

.it-blog-card-category {
  color: var(--it-green);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0.5px;
  text-decoration: none;
}

.it-blog-card-category:hover {
  color: var(--it-green-hover);
}

.it-blog-card-meta time {
  color: #888;
  font-size: 13px;
}

.it-blog-card-title {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 8px;
}

.it-blog-card-title a {
  color: var(--it-charcoal);
  text-decoration: none;
}

.it-blog-card-title a:hover {
  color: var(--it-green);
}

.it-blog-card-excerpt {
  font-size: 15px;
  color: #555;
  line-height: 1.6;
  margin-bottom: 12px;
}

.it-blog-card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--it-green);
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
}

.it-blog-card-link:hover {
  color: var(--it-green-hover);
}

.it-blog-card-link svg {
  transition: transform var(--it-transition-fast);
}

.it-blog-card-link:hover svg {
  transform: translateX(3px);
}

/* Blog pagination */
.it-blog-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 48px;
}

.it-blog-pagination a,
.it-blog-pagination span {
  padding: 8px 16px;
  border-radius: 4px;
  font-size: 14px;
  text-decoration: none;
}

.it-blog-pagination a {
  color: var(--it-charcoal);
  border: 1px solid var(--it-border);
}

.it-blog-pagination a:hover {
  background: var(--it-green);
  color: #fff;
  border-color: var(--it-green);
}

.it-blog-pagination span.current {
  background: var(--it-green);
  color: #fff;
  border: 1px solid var(--it-green);
}

/* ==========================================================================
   CTA / NEWSLETTER SECTION
   ========================================================================== */

/* CTA section — diagonal parallelogram band (first diagonal) */
.it-cta-section {
  background: #fff;
  position: relative;
  padding: 160px 24px 160px;
  text-align: center;
  margin-top: -60px;
  clip-path: polygon(0 120px, 100% 0, 100% calc(100% - 120px), 0 100%);
}

.it-cta-content {
  max-width: 600px;
  margin: 0 auto;
}

.it-cta-content h3 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--it-charcoal);
}

.it-cta-content p {
  font-size: 16px;
  color: var(--it-grey-50);
  margin-bottom: 24px;
}

.it-cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ==========================================================================
   SERVICE LIST LINKS (inside Servicii card)
   ========================================================================== */

.it-service-list li a {
  color: var(--it-charcoal);
  text-decoration: none !important;
  display: block;
  transition: color 200ms ease;
}

.it-service-list li a:hover {
  color: var(--it-blue);
}

/* ==========================================================================
   SCROLL-TRIGGERED ANIMATIONS (IntersectionObserver)
   ========================================================================== */

.it-animate {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}

.it-animate.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Staggered animation for grid children */
.it-animate.is-visible .it-cat-card,
.it-animate.is-visible .it-oferim-card,
.it-animate.is-visible .it-recomm-card,
.it-animate.is-visible .it-blog-card {
  animation: fadeInUp 0.5s ease-out both;
}

.it-animate.is-visible .it-cat-card:nth-child(1),
.it-animate.is-visible .it-oferim-card:nth-child(1),
.it-animate.is-visible .it-recomm-card:nth-child(1),
.it-animate.is-visible .it-blog-card:nth-child(1) { animation-delay: 0s; }

.it-animate.is-visible .it-cat-card:nth-child(2),
.it-animate.is-visible .it-oferim-card:nth-child(2),
.it-animate.is-visible .it-recomm-card:nth-child(2),
.it-animate.is-visible .it-blog-card:nth-child(2) { animation-delay: 0.1s; }

.it-animate.is-visible .it-cat-card:nth-child(3),
.it-animate.is-visible .it-oferim-card:nth-child(3),
.it-animate.is-visible .it-recomm-card:nth-child(3),
.it-animate.is-visible .it-blog-card:nth-child(3) { animation-delay: 0.2s; }

.it-animate.is-visible .it-cat-card:nth-child(4),
.it-animate.is-visible .it-oferim-card:nth-child(4),
.it-animate.is-visible .it-recomm-card:nth-child(4) { animation-delay: 0.3s; }

.it-animate.is-visible .it-cat-card:nth-child(5) { animation-delay: 0.4s; }
.it-animate.is-visible .it-cat-card:nth-child(6) { animation-delay: 0.5s; }

/* ==========================================================================
   HOMEPAGE RESPONSIVE
   ========================================================================== */

@media (max-width: 960px) {
  .it-hero {
    flex-direction: column;
    min-height: auto;
    padding: 24px;
  }

  .it-hero-visual {
    flex: none;
    width: 100%;
    min-height: 300px;
    position: relative;
  }

  .it-hero-content {
    flex: none;
    padding: 24px 0;
  }

  .it-hero-pot {
    display: none;
  }

  .it-hero-plant {
    width: 150px;
    left: -20px;
  }

  .it-hero-ac {
    width: 180px;
    top: 30px;
    left: 80px;
  }

  .it-cat-grid {
    grid-template-columns: 1fr 1fr;
  }

  /* Category cards: shrink background images on tablet/mobile */
  .it-cat-card {
    background-size: auto 55%;
    background-position: 120% 100%;
    min-height: 200px;
    padding: 24px 20px 20px;
  }

  .it-cat-card h4 {
    font-size: 17px;
  }

  .it-cat-card--services {
    background-size: auto 70%;
    background-position: 115% 100%;
  }

  .it-cat-card--small:not(.it-cat-card--services) {
    background-size: auto 70%;
    background-position: 110% 100%;
  }

  .it-cat-card--services,
  .it-cat-card--small {
    grid-column: span 1;
  }

  .it-about-section {
    flex-direction: column;
    gap: 32px;
  }

  .it-about-image {
    flex: none;
    width: 100%;
  }

  .it-daikin-grid {
    flex-direction: column;
  }

  .it-daikin-image {
    flex: none;
    width: 100%;
  }

  .it-oferim-section {
    grid-template-columns: repeat(2, 1fr);
  }

  .it-oferim-header {
    grid-column: span 2;
    grid-row: span 1;
  }

  .it-recomm-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .it-blog-grid {
    grid-template-columns: 1fr;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }

  .it-blog-archive .it-blog-grid {
    grid-template-columns: 1fr;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }

  .it-blog-archive {
    padding-bottom: 160px;
  }

  .it-blog-hero {
    padding: 60px 16px 24px;
  }

  .it-blog-hero h1 {
    font-size: 32px;
  }

  .it-blog-filters {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 0 16px;
  }

  .it-blog-filters-inner {
    min-width: max-content;
  }

  .it-blog-filter-tab {
    padding: 12px 14px;
    font-size: 13px;
    white-space: nowrap;
  }
}

@media (max-width: 600px) {
  .it-cat-grid {
    grid-template-columns: 1fr !important;
  }

  /* Single-column: cards are wider, images positioned right with hover slide */
  .it-cat-card {
    background-size: auto 60%;
    background-position: 120% 100%;
    min-height: 180px;
    padding: 28px 24px 24px;
  }

  .it-cat-card:hover {
    background-position: 95% 100%;
  }

  .it-cat-card h4 {
    font-size: 18px;
    max-width: 55%;
  }

  .it-cat-count {
    max-width: 55%;
  }

  .it-cat-card--services {
    grid-column: span 1;
    background-size: auto 45%;
    background-position: 105% 100%;
  }

  .it-cat-card--services:hover {
    background-position: 100% 100%;
  }

  .it-cat-card--services h4,
  .it-cat-card--services .it-cat-subtext,
  .it-cat-card--services .it-service-list {
    max-width: 65%;
  }

  .it-cat-card--small:not(.it-cat-card--services) {
    grid-column: span 1;
    background-size: auto 70%;
    background-position: 95% 10%;
  }

  .it-cat-card--small:not(.it-cat-card--services):hover {
    background-position: 85% 10%;
  }

  .it-cat-card--small:not(.it-cat-card--services) h4 {
    max-width: 55%;
  }

  .it-oferim-section {
    grid-template-columns: 1fr;
  }

  .it-oferim-header {
    grid-column: span 1;
  }

  .it-recomm-grid {
    grid-template-columns: 1fr 1fr;
  }

  .it-cta-section {
    padding: 120px 16px 120px;
    clip-path: polygon(0 80px, 100% 0, 100% calc(100% - 80px), 0 100%);
  }

  .site-footer {
    clip-path: polygon(0 90px, 100% 0, 100% 100%, 0 100%);
    padding: 120px 0 0;
    margin-top: -140px;
  }

  .woocommerce-page .site-content {
    padding-bottom: 160px;
  }

  .it-footer-nav {
    gap: 8px 20px;
  }
}

/* ==========================================================================
   DESPRE NOI PAGE
   ========================================================================== */

/* --- Full-width layout --- */
body.page-despre-noi .site-content .col-full {
  max-width: 100%;
  padding: 0;
}

body.page-despre-noi .site-content {
  padding-top: 0;
}

body.page-despre-noi .entry-content {
  margin: 0;
}

body.page-despre-noi .hentry {
  margin: 0;
  padding: 0;
}

body.page-despre-noi .storefront-breadcrumb {
  display: none;
}

/* --- Hero / Intro --- */
.it-despre-hero {
  text-align: center;
  padding: 80px 24px 40px;
  max-width: 800px;
  margin: 0 auto;
  animation: fadeInUp 0.7s ease-out both;
}

.it-despre-hero h1 {
  font-family: var(--it-font);
  font-size: 42px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 16px;
}

.it-despre-hero p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--it-grey-50);
  max-width: 680px;
  margin: 0 auto;
}

/* --- Stats Grid --- */
.it-despre-stats-wrap {
  background: var(--it-bg);
  padding: 40px 24px 80px;
}


.it-despre-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 760px;
  margin: 0 auto;
}

.it-despre-stats .it-despre-stats-row2 {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.it-despre-stat {
  background: var(--it-white);
  border-radius: var(--it-radius-lg);
  padding: 24px 20px;
  text-align: center;
  transition: transform var(--it-transition-fast), box-shadow var(--it-transition-fast), background-color var(--it-transition-fast);
}

.it-despre-stat:hover {
  transform: translateY(-4px);
  box-shadow: var(--it-shadow-elevated);
  background-color: #e8f4fd;
}

.it-despre-stat img {
  width: 64px;
  height: 64px;
  margin: 0 auto 12px;
  display: block;
}

.it-despre-stat span {
  display: block;
  font-family: var(--it-font);
  font-size: 16px;
  font-weight: 600;
  color: var(--it-charcoal);
}

/* --- Benefits Section --- */
.it-despre-benefits {
  padding: 80px 24px;
  max-width: var(--it-max-width);
  margin: 0 auto;
}

.it-despre-benefits-header {
  text-align: center;
  margin-bottom: 48px;
}

.it-despre-benefits-header h2 {
  font-family: var(--it-font);
  font-size: 36px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 16px;
}

.it-despre-benefits-header p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--it-grey-50);
  max-width: 800px;
  margin: 0 auto;
}

.it-despre-benefits-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto auto auto;
  gap: 20px;
  align-items: stretch;
}

.it-despre-benefits-photo {
  grid-column: 1;
  grid-row: 1 / 4;
  border-radius: var(--it-radius-lg);
  overflow: hidden;
  min-height: 500px;
}

/* Instalații inteligente — tall card spanning 2 rows */
.it-despre-benefits-grid .it-despre-benefit:nth-child(2) {
  grid-column: 2;
  grid-row: 1 / 3;
}

/* Eficientizarea consumurilor */
.it-despre-benefits-grid .it-despre-benefit:nth-child(3) {
  grid-column: 3;
  grid-row: 1;
}

/* Confort */
.it-despre-benefits-grid .it-despre-benefit:nth-child(4) {
  grid-column: 3;
  grid-row: 2;
}

/* Un singur contractor — spans both right columns */
.it-despre-benefits-grid .it-despre-benefit:nth-child(5) {
  grid-column: 2 / 4;
  grid-row: 3;
}

.it-despre-benefits-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.it-despre-benefit {
  background: var(--it-whitesmoke);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  transition: transform var(--it-transition-fast), box-shadow var(--it-transition-fast), background-color var(--it-transition-fast);
}

.it-despre-benefit:hover {
  transform: translateY(-4px);
  box-shadow: var(--it-shadow-elevated);
  background-color: #e8f4fd;
}

.it-despre-benefit img {
  width: 56px;
  height: 56px;
  margin-bottom: 16px;
}

.it-despre-benefit h3 {
  font-family: var(--it-font);
  font-size: 18px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 12px;
  line-height: 1.4;
}

.it-despre-benefit p {
  font-size: 15px;
  line-height: 1.65;
  color: var(--it-grey-50);
  margin: 0;
}

/* --- Daikin Partnership --- */
.it-despre-daikin {
  display: flex;
  gap: 60px;
  align-items: center;
  max-width: var(--it-max-width);
  margin: 0 auto;
  padding: 80px 24px;
}

.it-despre-daikin-photo {
  flex: 1;
  border-radius: var(--it-radius-lg);
  overflow: hidden;
}

.it-despre-daikin-photo img {
  width: 100%;
  height: auto;
  display: block;
}

.it-despre-daikin-content {
  flex: 1;
}

.it-despre-daikin-content h2 {
  font-family: var(--it-font);
  font-size: 32px;
  font-weight: 700;
  font-style: italic;
  color: var(--it-blue);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.it-despre-daikin-content h2 img {
  width: 40px;
  height: 40px;
}

.it-despre-daikin-content p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--it-grey-50);
}

/* --- Certifications --- */
.it-despre-certs {
  padding: 80px 24px;
  max-width: var(--it-max-width);
  margin: 0 auto;
}

.it-despre-certs-header {
  text-align: center;
  margin-bottom: 48px;
}

.it-despre-certs-header h2 {
  font-family: var(--it-font);
  font-size: 36px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 16px;
}

.it-despre-certs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.it-despre-cert {
  background: var(--it-white);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 32px 20px;
  text-align: center;
  transition: transform var(--it-transition-fast), box-shadow var(--it-transition-fast), background-color var(--it-transition-fast);
}

.it-despre-cert:hover {
  transform: translateY(-4px);
  box-shadow: var(--it-shadow-elevated);
  background-color: #e8f4fd;
}

.it-despre-cert img {
  width: 72px;
  height: auto;
  margin: 0 auto 16px;
  display: block;
}

.it-despre-cert h4 {
  font-family: var(--it-font);
  font-size: 15px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 12px;
  line-height: 1.3;
}

.it-despre-cert p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--it-grey-50);
  margin-bottom: 12px;
}

.it-despre-cert .it-despre-cert-ministry {
  font-size: 13px;
  color: var(--it-grey-400);
  line-height: 1.4;
}

/* --- Scroll Animations for Despre Noi --- */
.it-animate.is-visible .it-despre-stat,
.it-animate.is-visible .it-despre-benefit,
.it-animate.is-visible .it-despre-cert {
  animation: fadeInUp 0.5s ease-out both;
}

.it-animate.is-visible .it-despre-stat:nth-child(1),
.it-animate.is-visible .it-despre-benefit:nth-child(1),
.it-animate.is-visible .it-despre-cert:nth-child(1) { animation-delay: 0s; }

.it-animate.is-visible .it-despre-stat:nth-child(2),
.it-animate.is-visible .it-despre-benefit:nth-child(2),
.it-animate.is-visible .it-despre-cert:nth-child(2) { animation-delay: 0.1s; }

.it-animate.is-visible .it-despre-stat:nth-child(3),
.it-animate.is-visible .it-despre-benefit:nth-child(3),
.it-animate.is-visible .it-despre-cert:nth-child(3) { animation-delay: 0.2s; }

.it-animate.is-visible .it-despre-stat:nth-child(4),
.it-animate.is-visible .it-despre-benefit:nth-child(4),
.it-animate.is-visible .it-despre-cert:nth-child(4) { animation-delay: 0.3s; }

.it-animate.is-visible .it-despre-cert:nth-child(5) { animation-delay: 0.4s; }
.it-animate.is-visible .it-despre-cert:nth-child(6) { animation-delay: 0.5s; }
.it-animate.is-visible .it-despre-cert:nth-child(7) { animation-delay: 0.6s; }
.it-animate.is-visible .it-despre-cert:nth-child(8) { animation-delay: 0.7s; }

/* --- Despre Noi Responsive --- */
@media (max-width: 960px) {
  .it-despre-benefits-grid {
    grid-template-columns: 1fr 1fr;
  }

  .it-despre-benefits-photo {
    grid-row: auto;
    grid-column: 1 / -1;
    min-height: 300px;
  }

  .it-despre-daikin {
    flex-direction: column;
    gap: 32px;
  }

  .it-despre-certs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .it-despre-hero {
    padding: 60px 16px 24px;
  }

  .it-despre-hero h1 {
    font-size: 32px;
  }

  .it-despre-stats {
    grid-template-columns: 1fr;
  }

  .it-despre-stats .it-despre-stats-row2 {
    grid-template-columns: 1fr;
  }


  .it-despre-benefits {
    padding: 48px 16px;
  }

  .it-despre-benefits-header h2 {
    font-size: 28px;
  }

  .it-despre-benefits-grid {
    grid-template-columns: 1fr;
  }

  /* Reset explicit grid placements so single column works */
  .it-despre-benefits-photo,
  .it-despre-benefits-grid .it-despre-benefit {
    grid-column: auto !important;
    grid-row: auto !important;
  }

  .it-despre-daikin {
    padding: 48px 16px;
  }

  .it-despre-daikin-content h2 {
    font-size: 24px;
  }

  .it-despre-certs {
    padding: 48px 16px;
  }

  .it-despre-certs-header h2 {
    font-size: 28px;
  }

  .it-despre-certs-grid {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   CONTACT PAGE
   ========================================================================== */

/* Page intro — replaces the green hero banner */
/* Hero split: map (left) + decorative panel with plants (right) */
.it-contact-hero {
  display: flex !important;
  height: 520px;
  overflow: hidden;
}

.it-contact-hero-map {
  flex: 1;
  min-width: 0;
}

.it-contact-hero-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.it-contact-hero-panel {
  flex: 1;
  min-width: 0;
  background: linear-gradient(135deg, #8DDF64 0%, #6AC350 40%, #2AA83F 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  padding: 48px;
}

.it-contact-hero-content {
  position: relative;
  z-index: 2;
}

.it-contact-hero-content h1 {
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700;
  color: #fff;
  margin: 0 0 12px;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
}

.it-contact-hero-content p {
  font-size: 17px;
  color: rgba(255, 255, 255, 0.92);
  margin: 16px 0 0;
}

.it-contact-hero-plant {
  display: none;
}

.it-contact-hero-pot {
  position: absolute;
  bottom: 0;
  left: 20px;
  height: 75%;
  z-index: 1;
  pointer-events: none;
  object-fit: contain;
  opacity: 0.25;
}

/* Two-column contact section */
.it-contact-main {
  max-width: var(--it-max-width);
  margin: 0 auto;
  padding: 56px 24px;
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: stretch;
}

/* White card (info + form) */
.it-contact-card {
  background: var(--it-white);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 36px;
  box-shadow: var(--it-shadow-card);
}

.it-contact-card h2 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--it-charcoal);
  padding-bottom: 20px;
  border-bottom: 3px solid var(--it-green);
}

/* Contact info rows */
.it-contact-row {
  display: flex !important;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 12px;
  margin: 0 -12px;
  border-radius: var(--it-radius-sm);
  font-size: 15px;
  color: var(--it-charcoal);
  text-decoration: none !important;
  transition: background 0.2s ease;
}

.it-contact-row + .it-contact-row {
  border-top: 1px solid var(--it-border);
}

a.it-contact-row:hover {
  background: var(--it-whitesmoke);
  color: var(--it-green-text);
  text-decoration: none !important;
}

a.it-contact-row:hover svg {
  fill: var(--it-green-hover);
}

.it-contact-row svg {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px;
  max-width: 22px;
  fill: var(--it-green);
  flex-shrink: 0;
  margin-top: 1px;
  transition: fill 0.2s ease;
}

.it-contact-row-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.it-contact-row-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--it-grey-400);
}

/* Divider between info groups */
.it-contact-divider {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--it-grey-400);
  margin: 20px 0 4px;
}

/* Map embed */
.it-contact-map {
  margin-top: 24px;
  border-radius: var(--it-radius-lg);
  overflow: hidden;
  height: 260px;
  border: 1px solid var(--it-border);
}

.it-contact-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* CF7 form overrides inside contact card */
.it-contact-card .wpcf7-form p {
  margin: 0;
}

.it-contact-card .wpcf7-form br {
  display: none;
}

.it-contact-card .wpcf7-form label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--it-grey-50);
  margin-bottom: 4px;
  margin-top: 16px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.it-contact-card .wpcf7-form label:first-child {
  margin-top: 0;
}

.it-contact-card .wpcf7-form input[type="text"],
.it-contact-card .wpcf7-form input[type="email"],
.it-contact-card .wpcf7-form input[type="tel"],
.it-contact-card .wpcf7-form textarea {
  width: 100%;
  display: block;
}

.it-contact-card .wpcf7-form textarea {
  min-height: 120px;
  resize: vertical;
}

.it-contact-card .wpcf7-form input[type="submit"] {
  width: 100%;
  margin-top: 24px;
}

.it-contact-card .wpcf7-response-output {
  margin: 16px 0 0;
  padding: 12px 16px;
  border-radius: var(--it-radius-sm);
  font-size: 14px;
}

/* Bottom section: team photo + legal info */
.it-contact-bottom {
  max-width: var(--it-max-width);
  margin: 0 auto;
  display: grid !important;
  padding: 0 24px 60px;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  border-top: 1px solid var(--it-border);
  padding-top: 48px;
}

.it-contact-team img {
  width: 100%;
  border-radius: var(--it-radius-lg);
  object-fit: cover;
  display: block;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

.it-contact-legal h2 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--it-charcoal);
}

.it-contact-legal .it-section-line {
  margin-bottom: 20px;
}

.it-contact-legal p {
  font-size: 15px;
  color: var(--it-charcoal);
  margin: 0 0 8px;
  line-height: 1.6;
}

.it-contact-legal strong {
  color: var(--it-charcoal);
  font-weight: 600;
}

/* Mobile */
@media (max-width: 768px) {
  .it-contact-hero {
    flex-direction: column;
    height: auto;
  }

  .it-contact-hero-map {
    height: 280px;
  }

  .it-contact-hero-panel {
    min-height: 200px;
    padding: 32px 24px;
  }

  .it-contact-hero-pot {
    height: 55%;
    opacity: 0.2;
  }

  .it-contact-main,
  .it-contact-bottom {
    grid-template-columns: 1fr;
    padding-left: 16px;
    padding-right: 16px;
    gap: 24px;
  }

  .it-contact-card {
    padding: 24px;
  }

  .it-contact-map {
    height: 200px;
  }
}

/* Full-width layout for contact page (like homepage) */
.page-template-default.page-id-177 .site-content .col-full,
body.page-id-177 .site-content .col-full {
  max-width: 100%;
  padding: 0;
}

body.page-id-177 .site-content {
  padding-top: 0;
}

body.page-id-177 .entry-content {
  margin: 0;
}

body.page-id-177 .hentry {
  margin: 0;
  padding: 0;
}

body.page-id-177 .storefront-breadcrumb {
  display: none;
}

/* ==========================================================================
   BLOG ARCHIVE — Polished card design (matching Magento original)
   ========================================================================== */

/* Hide breadcrumb on blog pages */
body.blog .storefront-breadcrumb,
body.category .storefront-breadcrumb,
body.single-post .storefront-breadcrumb {
  display: none !important;
}

/* Also hide Storefront default page header/title on blog */
body.blog .page-header,
body.blog .entry-header,
body.category .page-header,
body.category .entry-header {
  display: none !important;
}

/* Cards: equal height, white background, border, shadow */
.it-blog-archive .it-blog-card {
  background: #fff;
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform var(--it-transition-medium), box-shadow var(--it-transition-medium);
}

.it-blog-archive .it-blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(106, 195, 80, 0.15);
}

/* Card image fills top of card */
.it-blog-archive .it-blog-card .it-blog-card-image {
  border-radius: 0;
}

.it-blog-archive .it-blog-card .it-blog-card-image img {
  border-radius: 0;
  height: 220px;
  width: 100%;
  object-fit: cover;
}

/* Card body padding inside card */
.it-blog-archive .it-blog-card .it-blog-card-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Push "Citeste articolul" to bottom */
.it-blog-archive .it-blog-card .it-blog-card-link {
  margin-top: auto;
}

/* Category badge — green pill style */
.it-blog-card-category {
  display: inline-block;
  background: #DFF1DD;
  color: #017C16 !important;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.8px;
  padding: 4px 12px;
  border-radius: 4px;
  text-decoration: none !important;
  line-height: 1;
}

.it-blog-card-category:hover {
  background: var(--it-green);
  color: #fff !important;
}

/* Excerpt: let it grow to fill space */
.it-blog-archive .it-blog-card .it-blog-card-excerpt {
  flex: 1;
}

/* Responsive: 2 columns on tablet, 1 on mobile */
@media (max-width: 768px) {
  .it-blog-archive .it-blog-grid {
    grid-template-columns: 1fr !important;
    gap: 24px;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .it-blog-archive .it-blog-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ==========================================================================
   SINGLE BLOG POST — Polished layout
   ========================================================================== */

/* Hide breadcrumb + Storefront default headers */
body.single-post .storefront-breadcrumb {
  display: none !important;
}

/* Wrapper */
.it-single-post {
  padding-bottom: 240px;
}

/* --- Hero section --- */
.it-single-hero {
  position: relative;
  width: 100%;
  height: 420px;
  overflow: hidden;
}

.it-single-hero-bg {
  position: absolute;
  inset: 0;
}

.it-single-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.it-single-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.1) 60%, transparent 100%);
  display: flex;
  align-items: flex-end;
}

.it-single-hero-inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 40px 24px;
  width: 100%;
  text-align: left;
}

.it-single-hero-inner h1 {
  color: #fff;
  font-size: clamp(26px, 3.5vw, 40px);
  font-weight: 700;
  line-height: 1.25;
  margin: 12px 0 16px;
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

.it-single-category-badge {
  display: inline-block;
  background: var(--it-green);
  color: #fff !important;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.8px;
  padding: 5px 14px;
  border-radius: 4px;
  text-decoration: none !important;
  transition: background var(--it-transition-fast);
}

.it-single-category-badge:hover {
  background: var(--it-green-hover);
}

.it-single-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  color: rgba(255,255,255,0.85);
  font-size: 14px;
}

.it-single-meta time {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.it-single-meta svg {
  opacity: 0.8;
}

/* --- Content area --- */
.it-single-content-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 24px 0;
}

.it-single-content {
  font-size: 17px;
  line-height: 1.8;
  color: var(--it-charcoal);
}

.it-single-content h2,
.it-single-content h3,
.it-single-content h4 {
  margin-top: 32px;
  margin-bottom: 12px;
  font-weight: 700;
  color: var(--it-charcoal);
  line-height: 1.35;
}

.it-single-content h2 {
  font-size: 28px;
}

.it-single-content h3 {
  font-size: 22px;
}

.it-single-content h4 {
  font-size: 18px;
}

.it-single-content p {
  margin-bottom: 20px;
}

.it-single-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--it-radius-lg);
  margin: 24px 0;
}

.it-single-content a {
  color: var(--it-green);
  text-decoration: underline;
  text-decoration-color: rgba(106,195,80,0.3);
  text-underline-offset: 3px;
}

.it-single-content a:hover {
  color: var(--it-green-hover);
  text-decoration-color: var(--it-green-hover);
}

.it-single-content blockquote {
  border-left: 4px solid var(--it-green);
  margin: 24px 0;
  padding: 16px 24px;
  background: #f8faf7;
  border-radius: 0 var(--it-radius) var(--it-radius) 0;
  font-style: italic;
  color: #444;
}

.it-single-content ul,
.it-single-content ol {
  margin-bottom: 20px;
  padding-left: 24px;
}

.it-single-content li {
  margin-bottom: 8px;
}

/* --- Post Navigation --- */
.it-single-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--it-border);
}

.it-single-nav-link {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 20px;
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  text-decoration: none !important;
  transition: border-color var(--it-transition-fast), box-shadow var(--it-transition-fast);
}

.it-single-nav-link:hover {
  border-color: var(--it-green);
  box-shadow: 0 4px 16px rgba(106,195,80,0.1);
}

.it-single-nav-next {
  text-align: right;
}

.it-single-nav-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #888;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.it-single-nav-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--it-charcoal);
  line-height: 1.4;
}

.it-single-nav-link:hover .it-single-nav-title {
  color: var(--it-green);
}

/* --- Related Posts --- */
.it-related-posts {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--it-border);
}

.it-related-posts h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 24px;
  color: var(--it-charcoal);
}

.it-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.it-related-card {
  text-decoration: none !important;
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  overflow: hidden;
  transition: transform var(--it-transition-medium), box-shadow var(--it-transition-medium);
}

.it-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(106,195,80,0.12);
}

.it-related-card-image {
  overflow: hidden;
}

.it-related-card-image img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  transition: transform var(--it-transition-medium);
}

.it-related-card:hover .it-related-card-image img {
  transform: scale(1.05);
}

.it-related-card h4 {
  padding: 14px 16px;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--it-charcoal);
  margin: 0;
}

.it-related-card:hover h4 {
  color: var(--it-green);
}

/* --- Mobile responsive --- */
@media (max-width: 768px) {
  .it-single-hero {
    height: 300px;
  }

  .it-single-hero-inner h1 {
    font-size: 24px;
  }

  .it-single-content-wrap {
    padding: 32px 20px 0;
  }

  .it-single-content {
    font-size: 16px;
  }

  .it-single-nav {
    grid-template-columns: 1fr;
  }

  .it-single-nav-next {
    text-align: left;
  }

  .it-related-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }

  .it-single-post {
    padding-bottom: 200px;
  }
}

/* ==========================================================================
   SERVICII DROPDOWN — pill-button layout matching Magento original
   ========================================================================== */

/* Servicii dropdown — card-style with images */
.menu-item-193 > .sub-menu {
  display: none;
  flex-direction: column;
  padding: 20px !important;
  min-width: 500px !important;
}

.menu-item-193:hover > .sub-menu,
.menu-item-193:focus-within > .sub-menu {
  display: flex !important;
}

/* Availability note — header text */
.servicii-availability-note {
  width: 100% !important;
  margin-bottom: 8px !important;
  padding: 0 !important;
}

.servicii-availability-note > a {
  pointer-events: none !important;
  cursor: default !important;
  color: #555 !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  padding: 0 0 8px !important;
  background: none !important;
  border-bottom: 1px solid var(--it-border) !important;
  display: block !important;
}

.servicii-availability-note > a:hover {
  background: none !important;
  color: #555 !important;
}

/* Service cards grid — 2 columns */
.menu-item-193 > .sub-menu {
  flex-wrap: wrap;
  flex-direction: row;
  gap: 8px;
}

.menu-item-193 > .sub-menu .servicii-availability-note {
  flex: 0 0 100%;
}

.menu-item-193 > .sub-menu .menu-item:not(.servicii-availability-note) {
  flex: 0 0 calc(50% - 4px) !important;
  display: block !important;
}

/* Service card links — image + text */
.menu-item-193 > .sub-menu .menu-item:not(.servicii-availability-note) > a {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 13px 15px !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: #F8F9FA !important;
  color: var(--it-charcoal) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: background var(--it-transition-fast), border-color var(--it-transition-fast) !important;
  white-space: normal !important;
  line-height: 1.35 !important;
  min-height: 64px !important;
  box-sizing: border-box !important;
}

.menu-item-193 > .sub-menu .menu-item:not(.servicii-availability-note) > a:hover {
  background: #EDF7EA !important;
  color: var(--it-charcoal) !important;
  border-color: var(--it-green) !important;
  letter-spacing: 0 !important;
}

/* Service menu images */
.it-servicii-menu-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 6px;
}

/* Mobile: stack vertically */
@media (max-width: 768px) {
  .menu-item-193 > .sub-menu {
    min-width: unset !important;
    flex-direction: column !important;
  }
  .menu-item-193 > .sub-menu .menu-item:not(.servicii-availability-note) {
    flex: 0 0 100% !important;
  }
}

/* ==========================================================================
   PRODUSE DROPDOWN — card-style with category images
   ========================================================================== */

.menu-item-192 > .sub-menu {
  display: none;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 8px;
  padding: 20px !important;
  min-width: 500px !important;
}

.menu-item-192:hover > .sub-menu,
.menu-item-192:focus-within > .sub-menu {
  display: flex !important;
}

/* Hide sub-sub-menus (Sensira, Comfora, etc.) in the dropdown */
.menu-item-192 > .sub-menu > .menu-item > .sub-menu {
  display: none !important;
}

/* Top-level Produse children as cards */
.menu-item-192 > .sub-menu > .menu-item {
  flex: 0 0 calc(50% - 4px) !important;
  display: block !important;
}

.menu-item-192 > .sub-menu > .menu-item > a {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 13px 15px !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: #F8F9FA !important;
  color: var(--it-charcoal) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: background var(--it-transition-fast), border-color var(--it-transition-fast) !important;
  white-space: normal !important;
  line-height: 1.35 !important;
  min-height: 64px !important;
  box-sizing: border-box !important;
}

.menu-item-192 > .sub-menu > .menu-item > a:hover {
  background: #EDF7EA !important;
  color: var(--it-charcoal) !important;
  border-color: var(--it-green) !important;
  letter-spacing: 0 !important;
}

/* Produse menu images */
.it-produse-menu-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 6px;
}

/* Remove the dropdown arrow for Produse sub-items that have children */
.menu-item-192 > .sub-menu > .menu-item.menu-item-has-children > a::after {
  display: none !important;
}

/* Mobile: stack vertically */
@media (max-width: 768px) {
  .menu-item-192 > .sub-menu {
    min-width: unset !important;
    flex-direction: column !important;
  }
  .menu-item-192 > .sub-menu > .menu-item {
    flex: 0 0 100% !important;
  }
}

/* ==========================================================================
   SERVICE PAGES — Stand by me & Alte servicii
   ========================================================================== */

.it-service-page {
  padding-bottom: 240px;
}

/* Green gradient hero */
.it-service-hero {
  background: linear-gradient(135deg, var(--it-green) 0%, #2AA83F 100%);
  padding: 64px 24px;
  text-align: center;
}

.it-service-hero-inner {
  max-width: 700px;
  margin: 0 auto;
}

.it-service-hero h1 {
  color: #fff;
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 700;
  margin: 0 0 16px;
}

.it-service-hero p {
  color: rgba(255, 255, 255, 0.9);
  font-size: 17px;
  line-height: 1.6;
  margin: 0 0 24px;
}

.it-service-hero-btn {
  display: inline-block;
  background: #fff;
  color: var(--it-green) !important;
  font-weight: 700;
  padding: 14px 32px;
  border-radius: 4px;
  text-decoration: none !important;
  font-size: 15px;
  transition: all var(--it-transition-fast);
}

.it-service-hero-btn:hover {
  background: var(--it-charcoal);
  color: #fff !important;
}

/* Service content area */
.it-service-content {
  max-width: 1000px;
  margin: 0 auto;
  padding: 48px 24px 0;
}

.it-service-intro {
  text-align: center;
  margin-bottom: 48px;
}

.it-service-intro h2 {
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 700;
  color: var(--it-green);
  margin-bottom: 16px;
}

.it-service-intro p {
  font-size: 17px;
  line-height: 1.7;
  color: #555;
  max-width: 700px;
  margin: 0 auto;
}

.it-service-section-title {
  text-align: center;
  margin-bottom: 32px;
}

.it-service-section-title h2 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  margin-bottom: 12px;
}

.it-service-section-title p {
  font-size: 16px;
  color: #555;
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Benefit cards grid (Stand by me) */
.it-service-benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}

.it-service-benefit-card {
  background: #fff;
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 32px 24px;
  text-align: center;
  transition: transform var(--it-transition-medium), box-shadow var(--it-transition-medium);
}

.it-service-benefit-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(106, 195, 80, 0.12);
}

.it-service-benefit-icon {
  font-size: 40px;
  margin-bottom: 16px;
}

.it-service-benefit-card h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--it-charcoal);
}

.it-service-benefit-card p {
  font-size: 15px;
  color: #555;
  line-height: 1.6;
}

/* Pillar cards grid (Alte servicii) */
.it-service-pillars {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}

.it-service-pillar-card {
  background: #fff;
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 32px 24px;
  transition: transform var(--it-transition-medium), box-shadow var(--it-transition-medium);
}

.it-service-pillar-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(106, 195, 80, 0.12);
}

.it-service-pillar-icon {
  font-size: 36px;
  margin-bottom: 12px;
}

.it-service-pillar-card h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--it-charcoal);
}

.it-service-pillar-card p {
  font-size: 15px;
  color: #555;
  line-height: 1.6;
}

/* CTA block */
.it-service-cta-block {
  text-align: center;
  padding: 48px 24px;
  background: #f8faf7;
  border-radius: var(--it-radius-lg);
  margin-top: 48px;
}

.it-service-cta-block h3 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 12px;
}

.it-service-cta-block p {
  font-size: 16px;
  color: #555;
  margin-bottom: 24px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.it-btn-green {
  display: inline-block;
  background: var(--it-green);
  color: #fff !important;
  font-weight: 700;
  padding: 14px 32px;
  border-radius: 4px;
  text-decoration: none !important;
  font-size: 15px;
  transition: background var(--it-transition-fast);
}

.it-btn-green:hover {
  background: var(--it-green-hover);
}

/* Responsive service pages */
@media (max-width: 768px) {
  .it-service-benefits {
    grid-template-columns: 1fr;
  }
  .it-service-pillars {
    grid-template-columns: 1fr;
  }
  .it-service-page {
    padding-bottom: 200px;
  }
}

/* ==========================================================================
   SERVICE CATEGORY PAGES (WooCommerce) — hero for Instalare/Mentenanță
   ========================================================================== */

/* Hide default Storefront category description on service cats */
body.tax-product_cat .term-description {
  text-align: center;
  font-size: 16px;
  color: #555;
  max-width: 600px;
  margin: 0 auto 24px;
}

/* Hide breadcrumb on service pages */
body.page-template-default.page-id-501 .storefront-breadcrumb,
body.page-template-default.page-id-502 .storefront-breadcrumb,
body.page-id-501 .storefront-breadcrumb,
body.page-id-502 .storefront-breadcrumb {
  display: none !important;
}

/* Hide breadcrumb on service product category pages */
body.tax-product_cat.term-instalare-aer-conditionat .storefront-breadcrumb,
body.tax-product_cat.term-mentenanta-aer-conditionat .storefront-breadcrumb,
body.tax-product_cat.term-servicii .storefront-breadcrumb {
  display: none !important;
}

/* Hide Storefront page title on service pages */
body.page-id-501 .entry-header,
body.page-id-502 .entry-header {
  display: none !important;
}

/* Servicii dropdown: horizontal layout for service pill buttons */
.menu-item-193 > .sub-menu {
  display: none;
  flex-wrap: wrap;
}

/* Alte servicii: hero with background image instead of plain green */
.it-alte-servicii-page .it-service-hero {
  padding: 80px 24px;
}

/* Alte servicii: ensure despre-benefits section works outside despre-noi page */
.it-alte-servicii-page .it-despre-benefits {
  padding: 0 24px 0;
}

.it-alte-servicii-page .it-despre-benefits-header {
  padding-top: 48px;
}

/* Ensure scroll animations fire on service pages too */
.it-alte-servicii-page .it-animate {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.it-alte-servicii-page .it-animate.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ==========================================================================
   ALTE SERVICII — Full-width hero matching Magento original
   ========================================================================== */

/* Override the old dark hero for alte-servicii */
.it-alte-servicii-page .it-service-hero {
  display: none !important;
}

.it-alte-hero {
  background: #F2F3F5;
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  padding: 40px 24px 0;
  overflow: hidden;
}

.it-alte-hero-inner {
  max-width: var(--it-max-width);
  margin: 0 auto;
  display: flex;
  align-items: flex-end;
  gap: 0;
}

.it-alte-hero-text {
  flex: 1;
  text-align: center;
  padding: 20px 0 60px;
}

.it-alte-hero-text h1 {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 800;
  color: var(--it-charcoal);
  margin: 0 0 8px;
}

.it-alte-hero-text .it-section-line {
  margin: 0 auto 16px;
}

.it-alte-hero-text p {
  font-size: 16px;
  color: #555;
  margin: 0;
}

.it-alte-hero-text p strong {
  color: var(--it-charcoal);
}

.it-alte-hero-image {
  flex: 0 0 340px;
  margin-right: -40px;
  align-self: flex-end;
}

.it-alte-hero-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* Mobile: stack hero vertically */
@media (max-width: 768px) {
  .it-alte-hero-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .it-alte-hero-text {
    padding: 10px 0 24px;
  }

  .it-alte-hero-image {
    flex: 0 0 auto;
    max-width: 250px;
    margin-right: 0;
  }

  .it-alte-hero {
    padding: 24px 24px 0;
  }
}

/* ==========================================================================
   STAND BY ME — Alte-servicii-style hero + intro + registration
   ========================================================================== */

/* Override the old green hero for stand-by-me */
.it-standby-page .it-service-hero {
  display: none !important;
}

/* Hero: grey bg, text left, illustration right */
.it-standby-hero {
  background: #F2F3F5;
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  padding: 48px 24px 0;
  overflow: hidden;
}

.it-standby-hero-inner {
  max-width: var(--it-max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 40px;
}

.it-standby-hero-text {
  flex: 1;
  padding: 20px 0 48px;
}

.it-standby-hero-text h1 {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 800;
  color: var(--it-charcoal);
  margin: 0 0 8px;
}

.it-standby-hero-text .it-section-line {
  margin: 0 0 16px;
}

.it-standby-hero-text p {
  font-size: 16px;
  color: #555;
  line-height: 1.7;
  margin: 0 0 24px;
  max-width: 520px;
}

.it-standby-hero-image {
  flex: 0 0 320px;
  align-self: center;
}

.it-standby-hero-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* Intro section: lifestyle photo left, text right */
.it-standby-intro {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  overflow: hidden;
}

.it-standby-intro-inner {
  max-width: var(--it-max-width);
  margin: 0 auto;
  display: flex;
  align-items: stretch;
  gap: 0;
}

.it-standby-intro-image {
  flex: 0 0 45%;
}

.it-standby-intro-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.it-standby-intro-text {
  flex: 1;
  padding: 48px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.it-standby-daikin-logo {
  width: 48px;
  height: auto;
  margin-bottom: 16px;
}

.it-standby-intro-text h2 {
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 700;
  color: var(--it-green);
  margin: 0 0 16px;
  line-height: 1.3;
}

.it-standby-intro-text h2 em {
  font-style: italic;
}

.it-standby-intro-text p {
  font-size: 16px;
  color: #555;
  line-height: 1.7;
  margin: 0;
}

/* Benefit card taglines */
.it-benefit-tagline {
  font-weight: 600;
  color: var(--it-green) !important;
  font-size: 14px !important;
  margin-bottom: 8px !important;
}

/* SVG icons in benefit cards */
.it-service-benefit-icon img {
  width: 48px;
  height: 48px;
  display: block;
  margin: 0 auto;
}

/* Benefit card links */
.it-service-benefit-card a {
  color: var(--it-green);
  font-weight: 600;
  text-decoration: underline;
}

.it-service-benefit-card a:hover {
  color: var(--it-green-hover);
}

/* Green underline for section title */
.it-service-section-title .it-section-line {
  margin: 0 auto 16px;
}

/* Registration section */
.it-standby-registration {
  margin-top: 64px;
}

.it-standby-registration-header {
  text-align: center;
  margin-bottom: 40px;
}

.it-standby-registration-header h2 {
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 700;
  color: var(--it-charcoal);
  margin-bottom: 12px;
}

.it-standby-registration-header p {
  font-size: 16px;
  color: #555;
}

/* Two cards side by side */
.it-standby-reg-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.it-standby-reg-card {
  background: #fff;
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 32px 28px;
  transition: transform var(--it-transition-medium), box-shadow var(--it-transition-medium);
}

.it-standby-reg-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(106, 195, 80, 0.12);
}

.it-step-letter {
  font-size: 32px;
  font-weight: 800;
  color: var(--it-green);
  margin-bottom: 4px;
}

.it-standby-reg-card h3 {
  font-size: 20px;
  font-weight: 700;
  color: var(--it-charcoal);
  margin: 0 0 8px;
}

.it-reg-card-highlight {
  font-weight: 600;
  color: var(--it-green) !important;
  font-size: 14px !important;
  margin-bottom: 16px !important;
}

.it-standby-reg-card ol {
  padding-left: 20px;
  margin: 0;
}

.it-standby-reg-card ol li {
  font-size: 15px;
  color: #555;
  line-height: 1.7;
  margin-bottom: 8px;
}

.it-standby-reg-card a {
  color: var(--it-green);
  font-weight: 600;
  text-decoration: underline;
}

.it-standby-reg-card a:hover {
  color: var(--it-green-hover);
}

/* Scroll animations for stand-by-me */
.it-standby-page .it-animate {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.it-standby-page .it-animate.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Responsive: Stand by me */
@media (max-width: 768px) {
  .it-standby-hero-inner {
    flex-direction: column;
    text-align: center;
  }

  .it-standby-hero-text {
    padding: 10px 0 24px;
  }

  .it-standby-hero-text .it-section-line {
    margin: 0 auto 16px;
  }

  .it-standby-hero-text p {
    max-width: none;
  }

  .it-standby-hero-image {
    flex: 0 0 auto;
    max-width: 220px;
  }

  .it-standby-hero {
    padding: 24px 24px 0;
  }

  .it-standby-intro-inner {
    flex-direction: column;
  }

  .it-standby-intro-image {
    flex: 0 0 auto;
  }

  .it-standby-intro-image img {
    height: 240px;
  }

  .it-standby-intro-text {
    padding: 32px 24px;
  }

  .it-standby-reg-cards {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   PRODUCT PAGE — Custom tabs, benefits, specs, video, upsell
   ============================================================ */

/* Tab content — description */
.it-tab-descriere {
  max-width: 800px;
  line-height: 1.7;
}
.it-tab-descriere h4 {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 18px;
  color: var(--it-charcoal);
  margin: 24px 0 12px;
}
.it-tab-descriere p {
  margin-bottom: 12px;
  color: var(--it-grey-600, #57606A);
}

/* Tab content — benefits grid with icons */
.it-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.it-benefit-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--it-white);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-sm);
  padding: 16px;
  transition: var(--it-transition-fast);
}
.it-benefit-card:hover {
  box-shadow: var(--it-shadow-green-glow);
  border-color: var(--it-green);
}
.it-benefit-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
}
.it-benefit-icon img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: 4px;
}
.it-benefit-text h4 {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 13px;
  color: var(--it-charcoal);
  margin: 0 0 4px;
  line-height: 1.3;
}
.it-benefit-text p {
  font-size: 12px;
  color: var(--it-grey-400);
  margin: 0;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .it-benefits-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}
@media (max-width: 480px) {
  .it-benefits-grid {
    grid-template-columns: 1fr;
  }
}

/* Tab content — spec tables */
.it-tab-specs {
  overflow-x: auto;
}
.it-tab-specs h4 {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 18px;
  color: var(--it-charcoal);
  margin: 24px 0 12px;
}
.it-tab-specs table,
.it-spec-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  font-family: var(--it-font);
  margin-bottom: 24px;
}
.it-tab-specs table thead th,
.it-spec-table thead th {
  background: var(--it-green);
  color: var(--it-white);
  font-weight: 600;
  padding: 10px 12px;
  text-align: left;
  position: sticky;
  top: 0;
  font-size: 12px;
  white-space: nowrap;
}
.it-tab-specs table tbody td,
.it-spec-table tbody td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--it-border);
  color: var(--it-charcoal);
  white-space: nowrap;
}
.it-tab-specs table tbody tr:nth-child(even),
.it-spec-table tbody tr:nth-child(even) {
  background: var(--it-grey-50);
}
.it-tab-specs table tbody tr:hover,
.it-spec-table tbody tr:hover {
  background: var(--it-green-tint-light, #DFF1DD);
}
.it-spec-table-wrapper {
  overflow-x: auto;
  border-radius: var(--it-radius-sm);
  border: 1px solid var(--it-border);
  margin-bottom: 24px;
}

/* Tab content — manual download */
.it-tab-manual {
  text-align: center;
  padding: 40px 20px;
}
.it-manual-download {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--it-green);
  color: var(--it-white) !important;
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 16px;
  padding: 14px 32px;
  border-radius: var(--it-radius-sm);
  text-decoration: none !important;
  transition: var(--it-transition-fast);
}
.it-manual-download:hover {
  background: var(--it-green-hover);
  transform: translateY(-2px);
  box-shadow: var(--it-shadow-cta);
}
.it-manual-download svg {
  fill: currentColor;
}

/* Color variant switcher */
.it-color-variants {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0 16px;
  flex-wrap: wrap;
}
.it-color-label {
  font-family: var(--it-font);
  font-size: 13px;
  color: var(--it-grey-400);
  font-weight: 500;
}
.it-color-swatch {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  border: 2px solid var(--it-border);
  border-radius: var(--it-radius-sm);
  padding: 4px;
  text-decoration: none !important;
  transition: var(--it-transition-fast);
}
.it-color-swatch:hover {
  border-color: var(--it-green);
}
.it-color-swatch.active {
  border-color: var(--it-green);
  box-shadow: 0 0 0 1px var(--it-green);
}
.it-color-swatch img {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 2px;
}
.it-color-swatch span {
  font-family: var(--it-font);
  font-size: 11px;
  color: var(--it-charcoal);
  font-weight: 500;
}

/* Service upsell section */
.it-service-upsell {
  max-width: 900px;
  margin: 32px auto;
  padding: 0 16px;
}
.it-service-upsell h3 {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 20px;
  color: var(--it-charcoal);
  margin-bottom: 16px;
}
.it-upsell-cards {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.it-upsell-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--it-white);
  border: 1px solid var(--it-border);
  border-radius: var(--it-radius-lg);
  padding: 20px 24px;
  text-decoration: none !important;
  transition: var(--it-transition-fast);
  flex: 1;
  min-width: 260px;
}
.it-upsell-card:hover {
  border-color: var(--it-green);
  box-shadow: var(--it-shadow-green-glow);
  transform: translateY(-2px);
}
.it-upsell-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--it-green-tint-light, #DFF1DD);
  border-radius: 50%;
}
.it-upsell-info h4 {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 14px;
  color: var(--it-charcoal);
  margin: 0 0 4px;
}
.it-upsell-price {
  font-family: var(--it-font);
  font-size: 13px;
  color: var(--it-green-text);
  font-weight: 600;
}

/* YouTube video embed */
.it-product-video {
  max-width: 900px;
  margin: 32px auto;
  padding: 0 16px;
}
.it-product-video h3 {
  font-family: var(--it-font);
  font-weight: 600;
  font-size: 20px;
  color: var(--it-charcoal);
  margin-bottom: 16px;
}
.it-video-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: var(--it-radius-lg);
  border: 1px solid var(--it-border);
}
.it-video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--it-radius-lg);
}

/* Discount badge on product page */
.it-discount-badge {
  display: inline-block;
  background: #E53935;
  color: #fff;
  font-family: var(--it-font);
  font-weight: 700;
  font-size: 14px;
  padding: 4px 10px;
  border-radius: var(--it-radius-pill);
}

/* Warranty badge */
.it-warranty-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--it-font);
  font-size: 13px;
  color: var(--it-green-text);
  font-weight: 500;
  margin: 8px 0;
}
