@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:wght@300;400;500;600;700&family=Barlow+Condensed:wght@400;600;700&display=swap');

/* ── VARIABLES ── */
:root {
  --red: #A61E2D;
  --red-dark: #821725;
  --black: #fff;
  --black-80: #f8d7d7;
  --black-70: #e8e8e8;
  --black-60: #d8d8d8;
  --gray: #888;
  --gray-light: #666;
  --white: #111;
  --w90: rgba(0,0,0,0.9);
  --w60: rgba(0,0,0,0.6);
  --w20: rgba(0,0,0,0.18);
  --w10: rgba(0,0,0,0.1);
  --w05: rgba(0,0,0,0.05);
  --nav-h: 72px;
  --tr: 0.22s ease;
  --font-d: 'Bebas Neue', sans-serif;
  --font-c: 'Barlow Condensed', sans-serif;
  --font-b: 'Barlow', sans-serif;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-b); background: #ffffff; color: #111; min-height: 100vh; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: #e4e4e4; }
::-webkit-scrollbar-thumb { background: var(--red); border-radius: 3px; }

/* ── PAGE SYSTEM ── */
#app { min-height: 100vh; }
.page { display: none; flex-direction: column; min-height: 100vh; }
.page.active { display: flex; }

/* ════════════════════════════════
   NAVBAR
════════════════════════════════ */
#navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 1000;
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 12px;
  transition: background var(--tr);
}

/* HOME: transparent with gradient so buttons stay readable */
#navbar.nav-transparent {
  background: linear-gradient(to bottom, rgba(255,255,255,0.75) 0%, rgba(255,255,255,0) 100%);
}

/* OTHER PAGES: solid white */
#navbar.nav-white {
  background: rgba(255,255,255,0.97);
  border-bottom: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 2px 24px rgba(0,0,0,0.10);
}

/* Nav sections */
.nav-left  { display: flex; align-items: center; gap: 4px; flex: 1; }
.nav-center { display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.nav-right { display: flex; align-items: center; gap: 10px; flex: 1; justify-content: flex-end; }

/* Logo */
.nav-logo { height: 50px; cursor: pointer; filter: drop-shadow(0 0 6px rgba(232,0,28,0.3)); transition: transform var(--tr); }
.nav-logo:hover { transform: scale(1.05); }

/* Nav buttons - ALWAYS red */
.nav-btn {
  color: var(--red);
  font-family: var(--font-c);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: 8px 13px;
  border-radius: 4px;
  white-space: nowrap;
  position: relative;
  transition: color var(--tr), text-shadow var(--tr);
}
.nav-btn:hover { color: #ff1a33; text-shadow: 0 0 12px rgba(232,0,28,0.7); }

/* Social icons - ALWAYS red */
.nav-icon-btn {
  color: var(--red);
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  border-radius: 4px;
  transition: color var(--tr), text-shadow var(--tr);
}
.nav-icon-btn:hover { color: #ff1a33; text-shadow: 0 0 12px rgba(232,0,28,0.7); }
.nav-social { display: flex; align-items: center; gap: 4px; }

/* ── DROPDOWN ── */
.nav-dropdown { position: relative; }

.submenu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 240px;
  background: #fff;
  border-top: 3px solid var(--red);
  border-radius: 0 0 6px 6px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.15);
  padding: 6px 0;
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
}
.nav-dropdown:hover .submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.submenu a {
  display: block;
  padding: 12px 20px;
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #111;
  transition: color var(--tr), background var(--tr), padding-left var(--tr);
  cursor: pointer;
}
.submenu a:hover {
  color: var(--red);
  background: rgba(0,0,0,0.04);
  padding-left: 28px;
}

/* ── SEARCH BAR ── */
.nav-search-toggle {
  display: flex;
  align-items: center;
  background: rgba(0,0,0,0.07);
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 999px;
  padding: 0 14px;
  height: 36px;
  width: 190px;
  cursor: text;
}
.nav-search-toggle input {
  background: none; border: none; outline: none;
  color: #111; font-family: var(--font-b); font-size: 13px; width: 100%;
  caret-color: var(--red);
}
.nav-search-toggle input::placeholder { color: rgba(0,0,0,0.4); }
.nav-search-toggle .search-icon { color: rgba(0,0,0,0.4); font-size: 14px; margin-left: 6px; flex-shrink: 0; }

/* ── SEARCH OVERLAY ── */
#search-overlay {
  position: fixed; inset: 0;
  background: rgba(255,255,255,0.97);
  z-index: 2000;
  display: none;
  flex-direction: column;
  align-items: center;
  padding-top: 120px;
}
#search-overlay.open { display: flex; }
.search-overlay-inner { width: 90%; max-width: 680px; }
.search-overlay-bar {
  display: flex; align-items: center; gap: 16px;
  background: #ebebeb;
  border: 2px solid var(--red);
  border-radius: 999px;
  padding: 0 24px; height: 60px;
}
.search-overlay-bar input {
  flex: 1; background: none; border: none; outline: none;
  color: #111; font-family: var(--font-c); font-size: 20px;
  letter-spacing: 1px; caret-color: var(--red);
}
.search-overlay-bar input::placeholder { color: #aaa; }
.search-close-btn { color: rgba(0,0,0,0.5); font-size: 26px; line-height:1; transition: color var(--tr); }
.search-close-btn:hover { color: var(--red); }
.search-submit-btn { color: var(--red); font-size: 20px; transition: color var(--tr); }
.search-submit-btn:hover { color: #111; }
#search-results { margin-top: 28px; display: grid; grid-template-columns: repeat(auto-fill,minmax(200px,1fr)); gap: 14px; }
.search-empty { color: #aaa; font-family: var(--font-c); font-size: 17px; letter-spacing: 1px; text-align: center; margin-top: 48px; grid-column: 1/-1; }

/* ── MOBILE ── */
.mobile-menu-btn { display: none; color: var(--red); font-size: 24px; transition: color 0.2s, text-shadow 0.2s; }
.mobile-menu-btn:hover { color: #ff1a33; text-shadow: 0 0 12px rgba(232,0,28,0.7); }
.mobile-drawer { position: fixed; inset: 0; z-index: 1500; visibility: hidden; pointer-events: none; }
.mobile-drawer.open { visibility: visible; pointer-events: all; }
.drawer-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.4); opacity: 0; transition: opacity 1.5s cubic-bezier(0.4,0,0.2,1); }
.mobile-drawer.open .drawer-overlay { opacity: 1; }
.drawer-panel { position: absolute; top:0; right:0; bottom:0; width:270px; background: #fff; border-left: 1px solid rgba(0,0,0,0.08); padding: 28px 0; overflow-y: auto; transform: translateX(100%); transition: transform 1.5s cubic-bezier(0.4,0,0.2,1); }
.mobile-drawer.open .drawer-panel { transform: translateX(0); }
.drawer-header { padding: 0 20px 20px; border-bottom: 1px solid rgba(0,0,0,0.08); margin-bottom: 12px; }
.drawer-close { position: absolute; top: 14px; right: 14px; color: #111; font-size: 26px; background: none; border: none; cursor: pointer; }
.drawer-link { display: flex; align-items: center; gap: 12px; padding: 13px 20px; font-family: var(--font-c); font-size: 15px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(0,0,0,0.85); cursor: pointer; transition: color var(--tr), background var(--tr); }
.drawer-link:hover { color: var(--red); background: rgba(0,0,0,0.03); }
.drawer-sub { padding-left: 44px; }
.drawer-sub a { display: block; padding: 9px 20px 9px 0; font-family: var(--font-c); font-size: 12px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: #888; cursor: pointer; transition: color var(--tr); }
.drawer-sub a:hover { color: var(--red); }

/* ════════════════════════════════
   HERO (HOME)
════════════════════════════════ */
#hero {
  position: relative;
  height: 100vh;
  min-height: 600px;
  overflow: hidden;
  background: #eee;
}
.hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to bottom, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,0.05) 100%);
}

/* ════════════════════════════════
   SELFWASH HERO
════════════════════════════════ */
.sw-hero {
  position: relative;
  height: 60vh;
  min-height: 380px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-top: var(--nav-h);
}
.sw-hero-overlay {
  position: absolute; inset: 0;
  background: rgba(255,255,255,0.65);
  z-index: 1;
}
.sw-hero-content {
  position: relative; z-index: 2; padding: 0 40px;
}
.sw-hero-content h1 { font-family: var(--font-d); font-size: clamp(40px,7vw,80px); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 14px; color: #111; }
.sw-hero-content h1 span { color: var(--red); }
.sw-hero-content p { font-size: 16px; color: rgba(0,0,0,0.6); max-width: 520px; margin: 0 auto 28px; line-height: 1.6; }

/* ════════════════════════════════
   BUTTONS
════════════════════════════════ */
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--red); color: #fff;
  font-family: var(--font-c); font-size: 14px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  padding: 13px 30px; border-radius: 4px; border: 2px solid var(--red);
  transition: background var(--tr), transform var(--tr), box-shadow var(--tr);
}
.btn-primary:hover { background: var(--red-dark); transform: translateY(-2px); box-shadow: 0 6px 24px rgba(232,0,28,0.4); }

.btn-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  background: transparent; color: #111;
  font-family: var(--font-c); font-size: 14px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  padding: 13px 30px; border-radius: 4px; border: 2px solid rgba(0,0,0,0.25);
  transition: border-color var(--tr), transform var(--tr);
}
.btn-secondary:hover { border-color: #111; transform: translateY(-2px); }

.btn-whatsapp {
  display: inline-flex; align-items: center; gap: 10px;
  background: #25D366; color: #fff;
  font-family: var(--font-c); font-size: 14px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  padding: 13px 30px; border-radius: 4px; border: 2px solid #25D366;
  transition: background var(--tr), transform var(--tr);
}
.btn-whatsapp:hover { background: #1ebe5d; transform: translateY(-2px); }

/* ════════════════════════════════
   CONTENT SECTIONS
════════════════════════════════ */
.content-section { padding: 72px 56px; background: #fff; }
.content-section.alt { background: #ebebeb; }
.section-tag { font-family: var(--font-c); font-size: 12px; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; color: var(--red); margin-bottom: 10px; display: block; }
.section-title { font-family: var(--font-d); font-size: clamp(34px,5vw,60px); letter-spacing: 2px; text-transform: uppercase; line-height: 1; color: #111; }
.section-title span { color: var(--red); }
.section-header { margin-bottom: 44px; }
.about-text { font-size: 15px; color: rgba(0,0,0,0.6); line-height: 1.8; margin-top: 20px; max-width: 680px; }

/* ── FEATURE BOXES ── */
.features-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(200px,1fr)); gap: 18px; margin-top: 36px; }
.feature-box {
  background: #ebebeb; border: 2px solid rgba(0,0,0,0.15); border-radius: 8px; padding: 28px 20px; text-align: center; cursor: pointer;
  transition: transform var(--tr), border-color var(--tr), background var(--tr);
}
.feature-box:hover { transform: translateY(-5px); border-color: var(--red); background: rgba(232,0,28,0.04); }
.feature-box .ficon { font-size: 38px; margin-bottom: 14px; display: block; }
.feature-box h3 { font-family: var(--font-c); font-size: 15px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #111; margin-bottom: 8px; }
.feature-box p { font-size: 13px; color: #777; line-height: 1.5; }

/* ── PRODUCT CARDS ── */
.cat-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 36px; }
.cat-tab {
  font-family: var(--font-c); font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 9px 18px; border-radius: 4px; border: 2px solid rgba(0,0,0,0.15); color: rgba(0,0,0,0.5); background: transparent;
  transition: all var(--tr); cursor: pointer;
}
.cat-tab:hover, .cat-tab.active { border-color: var(--red); color: #111; background: rgba(232,0,28,0.06); }

.products-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(250px,1fr)); gap: 22px; }
.product-card {
  background: #fff; border: 2px solid rgba(0,0,0,0.15); border-radius: 8px; overflow: hidden; cursor: pointer;
  transition: transform var(--tr), border-color var(--tr), box-shadow var(--tr);
}
.product-card:hover { transform: translateY(-5px); border-color: var(--red); box-shadow: 0 10px 36px rgba(232,0,28,0.12); }
.product-card-img { width: 100%; aspect-ratio: 4/3; object-fit: contain; background: #fff; padding: 10px; }
.product-card-body { padding: 18px; }
.product-card-cat { font-family: var(--font-c); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 6px; }
.product-card-name { font-family: var(--font-c); font-size: 16px; font-weight: 700; color: #111; margin-bottom: 6px; line-height: 1.3; }
.product-card-desc { font-size: 12px; color: #777; line-height: 1.5; margin-bottom: 14px; display: -webkit-box; line-clamp: 2; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.product-card-price { font-family: var(--font-d); font-size: 24px; color: var(--red); letter-spacing: 1px; }
.product-card-price small { font-family: var(--font-c); font-size: 12px; color: #888; font-weight: 400; letter-spacing: 0; }

/* ── PRODUCT DETAIL ── */
#page-product-detail .detail-hero { padding: 120px 56px 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.detail-img-wrap { background: transparent; border: none; border-radius: 0; padding: 0; display: flex; align-items: center; justify-content: center; overflow: hidden; max-height: 480px; }
.detail-img-wrap img { width: 100%; height: auto; max-height: 480px; object-fit: contain; margin: auto; display: block; }
.detail-info { padding-top: 16px; }
.detail-cat { font-family: var(--font-c); font-size: 12px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); margin-bottom: 14px; }
.detail-name { font-family: var(--font-d); font-size: clamp(28px,4vw,52px); letter-spacing: 2px; text-transform: uppercase; color: #111; line-height: 1; margin-bottom: 20px; }
.detail-desc { font-size: 14px; color: rgba(0,0,0,0.6); line-height: 1.7; margin-bottom: 28px; }
.detail-price { font-family: var(--font-d); font-size: 44px; color: var(--red); letter-spacing: 2px; margin-bottom: 28px; }
.detail-price small { font-family: var(--font-c); font-size: 15px; color: #888; letter-spacing: 0; }
.page-back-btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-c); font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #888; margin-bottom: 20px; transition: color var(--tr); cursor: pointer; }
.page-back-btn:hover { color: var(--red); }

/* ── SERVICE PAGE ── */
.service-intro { padding: 120px 56px 56px; max-width: 880px; }
.service-features { display: grid; grid-template-columns: repeat(auto-fill,minmax(250px,1fr)); gap: 22px; padding: 0 56px 56px; }
.service-feature-card { background: #ebebeb; border: 2px solid rgba(0,0,0,0.15); border-left: 4px solid var(--red); border-radius: 0 8px 8px 0; padding: 24px; transition: transform var(--tr); }
.service-feature-card:hover { transform: translateX(4px); }
.service-feature-card .icon { font-size: 30px; margin-bottom: 14px; }
.service-feature-card h3 { font-family: var(--font-c); font-size: 16px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #111; margin-bottom: 8px; }
.service-feature-card p { font-size: 13px; color: #777; line-height: 1.6; }

.photo-gallery { padding: 0 56px 72px; }
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(230px,1fr)); gap: 14px; }
.gallery-placeholder { aspect-ratio: 4/3; background: #ebebeb; border: 1px dashed rgba(0,0,0,0.18); border-radius: 8px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: #aaa; font-family: var(--font-c); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; transition: border-color var(--tr); }
.gallery-placeholder:hover { border-color: var(--red); }

.alidet-service-cards { display: grid; grid-template-columns: repeat(auto-fill,minmax(250px,1fr)); gap: 22px; padding: 0 56px 72px; }
.alidet-service-card { background: #ebebeb; border: 2px solid rgba(0,0,0,0.15); border-top: 4px solid var(--red); border-radius: 8px; padding: 28px; }
.alidet-service-card h3 { font-family: var(--font-c); font-size: 16px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #111; margin-bottom: 10px; }
.alidet-service-card p { font-size: 13px; color: #777; line-height: 1.6; }

/* ── PORTFOLIO ── */
.portfolio-hero { padding: 120px 56px 56px; }
.portfolio-grid { padding: 0 56px 72px; display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 26px; }
.portfolio-card { background: #fff; border: 2px solid rgba(0,0,0,0.15); border-radius: 8px; overflow: hidden; cursor: pointer; transition: transform var(--tr), border-color var(--tr); }
.portfolio-card:hover { transform: translateY(-5px); border-color: var(--red); }
.portfolio-card-img { width: 100%; aspect-ratio: 16/9; background: #eee; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.portfolio-card-img img { width: 100%; height: 100%; object-fit: contain; padding: 28px; background: #ebebeb; transition: transform 0.4s ease; }
.portfolio-card:hover .portfolio-card-img img { transform: scale(1.06); }
.portfolio-card-body { padding: 22px; }
.portfolio-card-location { font-family: var(--font-c); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 6px; }
.portfolio-card-title { font-family: var(--font-c); font-size: 17px; font-weight: 700; color: #111; margin-bottom: 6px; }
.portfolio-card-desc { font-size: 12px; color: #777; line-height: 1.5; }

/* ── CONTACT ── */
.contact-page { padding: 110px 56px 72px; display: grid; grid-template-columns: 1fr 1fr; gap: 72px; }
.contact-info h2 { font-family: var(--font-d); font-size: clamp(34px,5vw,60px); letter-spacing: 2px; text-transform: uppercase; line-height: 1; margin-bottom: 28px; color: #111; }
.contact-info h2 span { color: var(--red); }
.contact-item { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 24px; }
.contact-item-icon { width: 42px; height: 42px; background: rgba(232,0,28,0.08); border: 1px solid var(--red); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.contact-item-content h4 { font-family: var(--font-c); font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: #888; margin-bottom: 4px; }
.contact-item-content a, .contact-item-content p { font-size: 14px; color: #111; line-height: 1.5; transition: color var(--tr); }
.contact-item-content a:hover { color: var(--red); }
.contact-cta-group { display: flex; flex-direction: column; gap: 10px; margin-top: 32px; }
.contact-social-row { display: flex; gap: 10px; margin-top: 28px; flex-wrap: wrap; }
.social-pill { display: flex; align-items: center; gap: 8px; background: #ebebeb; border: 1px solid rgba(0,0,0,0.1); border-radius: 999px; padding: 9px 18px; font-family: var(--font-c); font-size: 12px; font-weight: 600; letter-spacing: 1px; color: rgba(0,0,0,0.6); transition: all var(--tr); }
.social-pill:hover { border-color: var(--red); color: #111; }

/* ── CONFIGURATOR ── */
.config-page-header { background: #ebebeb; }
.config-subtitle { text-align: center; color: #888; font-family: var(--font-c); font-size: 14px; letter-spacing: 1px; margin-bottom: 28px; }
.config-steps { display: flex; align-items: center; justify-content: center; padding: 0 40px 28px; max-width: 680px; margin: 0 auto; }
.config-step { display: flex; align-items: center; gap: 8px; font-family: var(--font-c); font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #aaa; padding: 8px 16px; border-bottom: 3px solid transparent; transition: color 0.2s, border-color 0.2s; white-space: nowrap; }
.config-step.active { color: #111; border-bottom-color: var(--red); }
.config-step span { width: 22px; height: 22px; border-radius: 50%; background: #ddd; color: #111; display: inline-flex; align-items: center; justify-content: center; font-size: 11px; }
.config-step.active span { background: var(--red); color: #fff; }
.config-step-line { flex: 1; height: 1px; background: rgba(0,0,0,0.1); min-width: 16px; }
.config-step-content { padding: 44px 56px 36px; background: #fff; min-height: 60vh; }
.config-step-content.hidden { display: none; }
.config-step-title { font-family: var(--font-c); font-size: 17px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 28px; padding-bottom: 10px; border-bottom: 1px solid rgba(0,0,0,0.08); }
.config-list-wrap { display: flex; flex-direction: column; gap: 28px; }
.config-list-section { background: #ebebeb; border: 1px solid rgba(0,0,0,0.08); border-radius: 8px; overflow: hidden; }
.config-list-header { background: #dcdcdc; padding: 13px 18px; font-family: var(--font-c); font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #111; border-bottom: 1px solid rgba(0,0,0,0.08); }
.config-list-item { display: grid; grid-template-columns: 22px 1fr auto auto; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid rgba(0,0,0,0.05); cursor: pointer; transition: background 0.18s; }
.config-list-item:last-child { border-bottom: none; }
.config-list-item:hover { background: rgba(0,0,0,0.03); }
.config-list-item input[type="radio"], .config-list-item input[type="checkbox"] { accent-color: var(--red); width: 16px; height: 16px; cursor: pointer; }
.cli-name { font-family: var(--font-c); font-size: 14px; font-weight: 700; color: #111; letter-spacing: 0.5px; }
.cli-desc { font-size: 11px; color: #888; }
.cli-price { font-family: var(--font-d); font-size: 17px; color: var(--red); letter-spacing: 1px; white-space: nowrap; justify-self: end; }
.config-nav-btns { display: flex; justify-content: space-between; align-items: center; margin-top: 28px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,0.08); }
.config-final-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; margin-bottom: 28px; }
.config-summary-box, .config-form-box { background: #ebebeb; border: 1px solid rgba(0,0,0,0.08); border-radius: 8px; padding: 24px; }
.config-summary-box h3, .config-form-box h3 { font-family: var(--font-c); font-size: 15px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #111; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid rgba(0,0,0,0.08); }
#config-summary-list { min-height: 100px; }
.config-summary-line { display: flex; justify-content: space-between; padding: 7px 0; border-bottom: 1px solid rgba(0,0,0,0.05); font-family: var(--font-c); font-size: 12px; }
.config-summary-line .csl-label { color: #888; }
.config-summary-line .csl-val { color: #111; font-weight: 700; }
.config-total-line { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; padding-top: 14px; border-top: 2px solid var(--red); font-family: var(--font-c); font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #111; }
.config-total-val { font-family: var(--font-d); font-size: 34px; color: var(--red); letter-spacing: 2px; }
.form-group { margin-bottom: 14px; }
.form-group label { display: block; font-family: var(--font-c); font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #888; margin-bottom: 5px; }
.form-group input, .form-group textarea { width: 100%; background: #fff; border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; padding: 9px 13px; font-family: var(--font-b); font-size: 13px; color: #111; outline: none; transition: border-color 0.2s; resize: vertical; }
.form-group input:focus, .form-group textarea:focus { border-color: var(--red); }
.form-group input::placeholder, .form-group textarea::placeholder { color: #bbb; }

/* ── FOOTER ── */
footer { background: #e4e4e4; border-top: 1px solid rgba(0,0,0,0.1); }
.footer-top { padding: 56px 80px 40px; display: grid; grid-template-columns: repeat(6,minmax(130px,1fr)); gap: 58px; border-bottom: 1px solid rgba(0,0,0,0.08); }
.footer-col h4 { font-family: var(--font-c); font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--red); margin-bottom: 14px; }
.footer-col ul li { margin-bottom: 9px; }
.footer-col ul li a, .footer-col p { font-size: 12px; color: #111; line-height: 1.6; transition: color var(--tr); cursor: pointer; }
.footer-col ul li a:hover { color: var(--red); }
.footer-bottom { padding: 20px 56px; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.footer-logo-wrap img { height: 32px; opacity: 0.7; }
.footer-badges { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.footer-badge { background: #dcdcdc; border: 1px solid rgba(0,0,0,0.1); border-radius: 4px; padding: 5px 12px; font-family: var(--font-c); font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #888; cursor: pointer; transition: color var(--tr), border-color var(--tr); }
.footer-badge:hover { color: #111; border-color: rgba(0,0,0,0.2); }
.footer-badge.ssl { color: #4CAF50; border-color: rgba(76,175,80,0.3); }
.footer-copy { font-size: 11px; color: #111; font-family: var(--font-c); letter-spacing: 1px; }

/* ── ANIMATIONS ── */
.fade-in { animation: fadeUp 0.5s ease both; }
@keyframes fadeUp { from { opacity:0; transform:translateY(18px); } to { opacity:1; transform:translateY(0); } }
.stagger > * { animation: fadeUp 0.5s ease both; }
.stagger > *:nth-child(1) { animation-delay: 0.05s; }
.stagger > *:nth-child(2) { animation-delay: 0.10s; }
.stagger > *:nth-child(3) { animation-delay: 0.15s; }
.stagger > *:nth-child(4) { animation-delay: 0.20s; }
.stagger > *:nth-child(5) { animation-delay: 0.25s; }
.stagger > *:nth-child(6) { animation-delay: 0.30s; }
.stagger > *:nth-child(n+7) { animation-delay: 0.35s; }
.toast { position: fixed; bottom: 28px; right: 28px; background: var(--red); color: #fff; font-family: var(--font-c); font-size: 13px; font-weight: 700; letter-spacing: 1px; padding: 12px 22px; border-radius: 6px; z-index: 9999; transform: translateY(70px); opacity: 0; transition: all 0.3s ease; }
.toast.show { transform: translateY(0); opacity: 1; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .nav-left, .nav-right { display: none; }
  .mobile-menu-btn { display: flex; }
  #navbar { justify-content: space-between; }
  .content-section { padding: 52px 20px; }
  .service-intro, .photo-gallery { padding-left: 20px; padding-right: 20px; }
  .service-features, .alidet-service-cards { padding-left: 20px; padding-right: 20px; }
  .portfolio-hero, .portfolio-grid { padding-left: 20px; padding-right: 20px; }
  .contact-page { grid-template-columns: 1fr; padding: 100px 20px 56px; gap: 40px; }
  #page-product-detail .detail-hero { grid-template-columns: 1fr; padding: 100px 20px 36px; }
  .footer-top { padding: 36px 20px; }
  .footer-bottom { padding: 18px 20px; flex-direction: column; align-items: flex-start; }
  .config-step-content { padding: 28px 18px; }
  .config-final-wrap { grid-template-columns: 1fr; }
  .config-steps { flex-wrap: wrap; gap: 4px; }
  .cli-desc { display: none; }
}
@media (max-width: 600px) {
  .products-grid { grid-template-columns: 1fr; padding: 0 5% 20px; gap: 16px; }
  .portfolio-grid { grid-template-columns: 1fr; }
}

/* ── LEGAL PAGES ─────────────────────────── */
#page-legal {
  background: #fff;
  color: #111;
}
#page-legal.page.active {
  display: flex;
}
.legal-page {
  flex: 1;
  max-width: 860px;
  margin: 0 auto;
  width: 100%;
  padding: 0 40px 72px;
}
.legal-header {
  padding: 40px 0 36px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  margin-bottom: 40px;
}
.legal-body {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.legal-section {
  padding: 24px 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.legal-section:last-child {
  border-bottom: none;
}
.legal-section h2 {
  font-family: var(--font-c);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 12px;
}
.legal-section p {
  font-size: 14px;
  color: rgba(0,0,0,0.7);
  line-height: 1.8;
}
.legal-section strong {
  color: #111;
}
.legal-list {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
}
.legal-list li {
  font-size: 14px;
  color: rgba(0,0,0,0.7);
  line-height: 1.8;
  padding: 4px 0 4px 18px;
  position: relative;
}
.legal-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--red);
  font-size: 12px;
}
@media (max-width: 900px) {
  .legal-page { padding: 0 20px 56px; }
}

/* ── SEARCH RESULTS PAGE ────────────────── */
.search-page-header {
  margin-bottom: 8px;
}
.search-page-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 80px 20px;
  color: #aaa;
}
.search-page-empty i {
  font-size: 48px;
  color: var(--red);
  margin-bottom: 20px;
  display: block;
  opacity: 0.4;
}
.search-page-empty p {
  font-family: var(--font-c);
  font-size: 16px;
  letter-spacing: 1px;
  color: #888;
}
.search-page-empty strong {
  color: #111;
}

/* ── LEGAL CHAPTERS & NAV ───────────────── */
.legal-nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.legal-nav-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #ebebeb;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 4px;
  padding: 9px 16px;
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(0,0,0,0.6);
  cursor: pointer;
  transition: all 0.2s ease;
}
.legal-nav-btn:hover {
  border-color: var(--red);
  color: #111;
  background: rgba(232,0,28,0.06);
}
.legal-chapter {
  margin-bottom: 16px;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 8px;
  overflow: hidden;
}
.legal-chapter-title {
  background: #ebebeb;
  border-bottom: 3px solid var(--red);
  padding: 18px 24px;
  font-family: var(--font-c);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #111;
}
.legal-chapter .legal-section {
  padding: 20px 24px;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}
.legal-chapter .legal-section:last-child {
  border-bottom: none;
}

/* ── MOBILE SEARCH BUTTON ───────────────── */
.mobile-search-btn {
  display: none;
  color: var(--red);
  font-size: 20px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: 4px;
  transition: color 0.2s, text-shadow 0.2s;
}
.mobile-search-btn:hover { color: #ff1a33; text-shadow: 0 0 12px rgba(232,0,28,0.7); }

@media (max-width: 900px) {
  .mobile-search-btn { display: flex; align-items: center; justify-content: center; }
  #navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 16px;
  }
  .nav-center { flex: 1; justify-content: flex-start; }
  .nav-left, .nav-right { display: none; }
  .mobile-btns-group {
    display: flex;
    align-items: center;
    gap: 4px;
  }
}

/* ── PRODUCT DETAIL RICH CONTENT ─────────── */

.detail-benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}
.detail-benefit-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: #ebebeb;
  border: 1px solid rgba(0,0,0,0.08);
  border-left: 4px solid var(--red);
  border-radius: 0 8px 8px 0;
  padding: 22px 20px;
  transition: transform 0.2s;
}
.detail-benefit-card:hover { transform: translateX(4px); }
.dbc-icon {
  color: var(--red);
  font-size: 22px;
  flex-shrink: 0;
  margin-top: 2px;
}
.detail-benefit-card h3 {
  font-family: var(--font-c);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #111;
  margin-bottom: 6px;
}
.detail-benefit-card p {
  font-size: 13px;
  color: rgba(0,0,0,0.6);
  line-height: 1.6;
}

.detail-specs-table {
  width: 100%;
  max-width: 640px;
  border-collapse: collapse;
  font-family: var(--font-c);
}
.detail-specs-table thead tr {
  background: var(--red);
}
.detail-specs-table thead th {
  padding: 13px 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  text-align: left;
}
.detail-specs-table tbody tr {
  border-bottom: 1px solid rgba(0,0,0,0.06);
  transition: background 0.15s;
}
.detail-specs-table tbody tr:hover { background: rgba(0,0,0,0.03); }
.detail-specs-table tbody tr:last-child { border-bottom: none; }
.detail-specs-table tbody td {
  padding: 13px 20px;
  font-size: 14px;
  color: rgba(0,0,0,0.8);
}
.detail-specs-table tbody td:first-child {
  color: rgba(0,0,0,0.45);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  width: 220px;
}

.detail-steps {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 720px;
}
.detail-step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background: #ebebeb;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 8px;
  padding: 20px 24px;
  transition: border-color 0.2s;
}
.detail-step:hover { border-color: var(--red); }
.detail-step-nr {
  font-family: var(--font-d);
  font-size: 36px;
  color: var(--red);
  letter-spacing: 2px;
  line-height: 1;
  flex-shrink: 0;
  width: 48px;
}
.detail-step-body h4 {
  font-family: var(--font-c);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #111;
  margin-bottom: 6px;
}
.detail-step-body p {
  font-size: 13px;
  color: rgba(0,0,0,0.6);
  line-height: 1.6;
}

.detail-protip {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: rgba(232,0,28,0.05);
  border: 1px solid rgba(232,0,28,0.3);
  border-radius: 8px;
  padding: 20px 24px;
  margin-top: 24px;
  max-width: 720px;
}
.detail-protip i {
  color: var(--red);
  font-size: 22px;
  flex-shrink: 0;
  margin-top: 2px;
}
.detail-protip strong {
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--red);
}
.detail-protip span {
  font-size: 13px;
  color: rgba(0,0,0,0.7);
  line-height: 1.6;
  display: block;
  margin-top: 4px;
}

.detail-section { border-top: 1px solid rgba(0,0,0,0.06); }

@media (max-width: 900px) {
  .detail-specs-table tbody td:first-child { width: 140px; }
  .detail-steps { gap: 12px; }
  .detail-step { padding: 16px; gap: 14px; }
  .detail-step-nr { font-size: 28px; width: 38px; }
}

/* ═══════════════════════════════════════
   CART SYSTEM
═══════════════════════════════════════ */

.cart-badge {
  position: absolute;
  top: -6px; right: -6px;
  background: var(--red);
  color: #fff;
  font-family: var(--font-c);
  font-size: 10px;
  font-weight: 700;
  width: 18px; height: 18px;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.cart-nav-btn { position: relative !important; }

.btn-add-cart {
  background: var(--red);
  font-size: 15px;
  padding: 15px 36px;
}
.btn-add-cart:hover { background: var(--red-dark); }

.cart-item {
  display: grid;
  grid-template-columns: 80px 1fr auto auto auto;
  align-items: center;
  gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid rgba(0,0,0,0.07);
}
.cart-item:last-child { border-bottom: none; }
.cart-item-img {
  width: 80px; height: 80px;
  object-fit: contain;
  background: #ebebeb;
  border-radius: 6px;
  padding: 8px;
}
.cart-item-name {
  font-family: var(--font-c);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: #111;
  margin-bottom: 2px;
}
.cart-item-variant {
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 600;
  color: var(--red);
  letter-spacing: 0.5px;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.cart-item-price {
  font-size: 13px;
  color: #888;
  font-family: var(--font-c);
  letter-spacing: 0.5px;
}
.cart-item-qty {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #ebebeb;
  border: 1px solid rgba(0,0,0,0.1);
  border-radius: 6px;
  padding: 8px 12px;
}
.qty-btn {
  background: none;
  border: none;
  color: #111;
  font-size: 18px;
  cursor: pointer;
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
  font-family: var(--font-b);
  font-weight: 700;
}
.qty-btn:hover { background: var(--red); color: #fff; }
.cart-item-qty span {
  font-family: var(--font-d);
  font-size: 22px;
  color: #111;
  min-width: 24px;
  text-align: center;
  letter-spacing: 1px;
}
.cart-item-subtotal {
  font-family: var(--font-d);
  font-size: 22px;
  color: var(--red);
  letter-spacing: 1px;
  min-width: 120px;
  text-align: right;
}
.cart-item-remove {
  background: none;
  border: 1px solid rgba(0,0,0,0.1);
  color: #bbb;
  width: 36px; height: 36px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: 14px;
  transition: color 0.2s, border-color 0.2s;
}
.cart-item-remove:hover { color: var(--red); border-color: var(--red); }

.cart-summary {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-top: 32px;
  padding-top: 28px;
  border-top: 2px solid rgba(0,0,0,0.08);
  flex-wrap: wrap;
}
.cart-summary-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-c);
  font-size: 12px;
  letter-spacing: 1px;
  color: #aaa;
  max-width: 400px;
  margin-bottom: 20px;
  line-height: 1.6;
}
.cart-total-row {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--font-c);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #111;
}
.cart-total-val {
  font-family: var(--font-d);
  font-size: 42px;
  color: var(--red);
  letter-spacing: 2px;
}
.cart-summary-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
}
.btn-send-order {
  font-size: 16px;
  padding: 16px 36px;
}

/* ═══════════════════════════════════════
   HOME CATEGORY CARDS
═══════════════════════════════════════ */
.home-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}
.home-cat-card {
  background: #fff;
  border: 2px solid rgba(0,0,0,0.15);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}
.home-cat-card:hover {
  transform: translateY(-5px);
  border-color: var(--red);
  box-shadow: 0 10px 36px rgba(232,0,28,0.10);
}
.home-cat-img-wrap {
  width: 100%;
  height: 160px;
  background: #ebebeb;
  overflow: hidden;
}
.home-cat-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.home-cat-card:hover .home-cat-img-wrap img { transform: scale(1.05); }
.home-cat-body {
  padding: 20px;
}
.home-cat-tag {
  font-family: var(--font-c);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 6px;
}
.home-cat-body h3 {
  font-family: var(--font-c);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #111;
  margin-bottom: 8px;
  text-transform: uppercase;
}
.home-cat-body p {
  font-size: 13px;
  color: #888;
  line-height: 1.6;
  margin-bottom: 14px;
}
.home-cat-link {
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--red);
  display: flex;
  align-items: center;
  gap: 8px;
  transition: gap 0.2s;
}
.home-cat-card:hover .home-cat-link { gap: 12px; }

@media (max-width: 900px) {
  .cart-item { grid-template-columns: 60px 1fr auto; gap: 12px; }
  .cart-item-subtotal, .cart-item-remove { display: none; }
  .cart-summary { flex-direction: column; align-items: flex-start; }
  .home-cat-grid { grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); }
}

/* ═══════════════════════════════════════
   HERO CATEGORY CARDS OVERLAY
═══════════════════════════════════════ */
#hero {
  position: relative;
  height: 100vh;
  min-height: 600px;
  overflow: hidden;
  background: #eee;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.hero-cards-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 3;
  display: flex;
  gap: 12px;
  padding: 40px;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-end;
  background: none;
}

.hero-cat-card {
  flex: 0 0 auto;
  width: 155px;
  background: rgba(255,255,255,0.92);
  border: 1.5px solid rgba(0,0,0,0.25);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}
.hero-cat-card:hover {
  transform: translateY(-6px);
  border-color: #ff1a33;
  box-shadow: 0 6px 24px rgba(232,0,28,0.4);
  background: rgba(255,255,255,0.97);
}
.hero-cat-card img {
  width: 100%;
  height: 90px;
  object-fit: cover;
  display: block;
  opacity: 0.85;
  transition: opacity 0.22s;
}
.hero-cat-card:hover img { opacity: 1; }

.hero-cat-icon {
  width: 100%;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  color: rgba(0,0,0,0.15);
  background: rgba(0,0,0,0.03);
  transition: color 0.22s;
}
.hero-cat-card:hover .hero-cat-icon { color: var(--red); }

.hero-cat-label {
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hcl-tag {
  font-family: var(--font-c);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--red);
}
.hcl-name {
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: #111;
  text-transform: uppercase;
  line-height: 1.2;
}
.hcl-arrow {
  font-size: 10px;
  color: rgba(0,0,0,0.3);
  margin-top: 4px;
  transition: color 0.2s, transform 0.2s;
  display: block;
}
.hero-cat-card:hover .hcl-arrow {
  color: var(--red);
  transform: translateX(3px);
}

@media (max-width: 900px) {
  .hero-cards-overlay {
    padding: 20px 12px 28px;
    gap: 8px;
    justify-content: center;
  }
  .hero-cat-card { width: 120px; }
  .hero-cat-card img, .hero-cat-icon { height: 70px; }
  .hero-cat-icon { font-size: 28px; }
  .hcl-name { font-size: 11px; }
}

/* ── DETAIL QTY SELECTOR ──────────────── */
.detail-cart-controls {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}
.dcc-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.dcc-row2 {
  display: flex;
  align-items: center;
  gap: 12px;
}
/* Butonul "Vezi Cosul" se aliniaza la dreapta variantelor */
.dcc-view-cart {
  flex-shrink: 0;
}

/* Selector variante */
.detail-variant-selector {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  flex: 1;
}
.variant-btn {
  padding: 0 16px;
  height: 44px;
  border: 2px solid rgba(0,0,0,0.18);
  background: #f5f5f5;
  border-radius: 6px;
  font-family: var(--font-c);
  font-size: 15px;
  font-weight: 600;
  color: #333;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, color 0.18s, transform 0.15s;
  letter-spacing: 0.5px;
}
.variant-btn:hover {
  border-color: var(--red);
  color: var(--red);
  transform: translateY(-1px);
}
.variant-btn.active {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
  box-shadow: 0 4px 14px rgba(232,0,28,0.35);
}
.detail-qty-selector {
  display: flex;
  align-items: center;
  gap: 0;
  background: #ebebeb;
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 6px;
  overflow: hidden;
  height: 50px;
}
.detail-qty-selector .qty-btn {
  width: 44px;
  height: 50px;
  font-size: 22px;
  font-weight: 300;
  color: #111;
  background: none;
  border: none;
  border-radius: 0;
  transition: background 0.2s, color 0.2s;
}
.detail-qty-selector .qty-btn:hover {
  background: var(--red);
  color: #fff;
}
.detail-qty-selector #detail-qty-display {
  font-family: var(--font-d);
  font-size: 22px;
  color: #111;
  width: 52px;
  min-width: 52px;
  text-align: center;
  letter-spacing: 1px;
  border: none;
  border-left: 1px solid rgba(0,0,0,0.1);
  border-right: 1px solid rgba(0,0,0,0.1);
  background: transparent;
  height: 50px;
  line-height: 50px;
  padding: 0;
  outline: none;
  appearance: textfield;
  -moz-appearance: textfield;
  cursor: text;
}
.detail-qty-selector #detail-qty-display::-webkit-inner-spin-button,
.detail-qty-selector #detail-qty-display::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.detail-qty-selector #detail-qty-display:focus {
  background: rgba(232,0,28,0.06);
  color: var(--red);
}

/* ── TOOLBAR "GATA" ────────────────────────── */
.qty-keyboard-toolbar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-top: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 -4px 24px rgba(0,0,0,0.14);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  z-index: 9999;
  transform: translateY(100%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}
.qty-keyboard-toolbar.visible {
  transform: translateY(0);
}
.qty-toolbar-label {
  font-family: var(--font-b);
  font-size: 15px;
  color: #444;
}
.qty-toolbar-label strong {
  font-size: 18px;
  color: var(--red);
  font-family: var(--font-d);
  letter-spacing: 1px;
}
.qty-toolbar-btn {
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 26px;
  font-family: var(--font-c);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background 0.18s, transform 0.15s;
}
.qty-toolbar-btn:hover { background: var(--red-dark); transform: scale(1.03); }

/* ── MOBILE CART BTN ──────────────────── */
.mobile-cart-btn {
  display: none;
  color: var(--red);
  font-size: 20px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 4px;
  position: relative;
  transition: color 0.2s, text-shadow 0.2s;
}
.mobile-cart-btn:hover { color: #ff1a33; text-shadow: 0 0 12px rgba(232,0,28,0.7); }
@media (max-width: 900px) {
  .mobile-cart-btn { display: flex; align-items: center; justify-content: center; }
}

/* ── FLOATING BACK BUTTON ─────────────── */

/* ── HERO CARDS MOBILE ─────────────────── */
.hero-cards-mobile {
  display: none;
}

@media (max-width: 900px) {
  /* Ascunde cardurile overlay de pe poza */
  .hero-cards-overlay {
    display: none !important;
  }

  /* Hero pe mobil - poza mare ca pe desktop */
  #hero {
    height: 100vw;
    min-height: 320px;
    max-height: 520px;
  }

  /* Carduri sub poza - lista verticala ca in exemplu */
  .hero-cards-mobile {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 14px;
    background: #ebebeb;
  }

  .hero-cards-mobile .hero-cat-card {
    width: 100%;
    display: grid;
    grid-template-columns: 70px 1fr 90px;
    align-items: center;
    background: #fff;
    border: 2px solid rgba(0,0,0,0.15);
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
    min-height: 72px;
  }

  .hero-cards-mobile .hero-cat-card:active,
  .hero-cards-mobile .hero-cat-card:hover {
    border-color: #ff1a33;
    box-shadow: 0 4px 16px rgba(232,0,28,0.25);
  }

  /* Poza in dreapta - coloana 3 */
  .hero-cards-mobile .hero-cat-card img {
    width: 90px;
    height: 72px;
    object-fit: cover;
    display: block;
    opacity: 1;
    grid-column: 3;
    order: 3;
  }

  /* Icon in stanga - coloana 1 */
  .hero-cards-mobile .hero-cat-icon {
    width: 70px;
    height: 72px;
    font-size: 28px;
    flex-shrink: 0;
    background: #ebebeb;
    color: var(--red);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Text in dreapta */
  .hero-cards-mobile .hero-cat-label {
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
  }

  .hero-cards-mobile .hcl-tag {
    font-family: var(--font-c);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--red);
  }

  .hero-cards-mobile .hcl-name {
    font-family: var(--font-c);
    font-size: 15px;
    font-weight: 700;
    color: #111;
    text-transform: uppercase;
  }

  .hero-cards-mobile .hcl-arrow {
    font-size: 11px;
    color: rgba(0,0,0,0.3);
    margin-top: 2px;
  }
}

/* ── DETAIL SLIDER ──────────────────────────── */
.detail-slider {
  position: relative;
  width: 100%;
  max-height: 480px;
  overflow: hidden;
  border-radius: 8px;
  background: transparent;
}

.detail-slider-track {
  display: flex;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  align-items: flex-start;
}

.detail-slide {
  min-width: 100%;
  max-height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.detail-slide img {
  width: 100%;
  max-height: 480px;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 8px;
}

.detail-slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.55);
  border: none;
  color: #fff;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  z-index: 10;
  transition: background 0.2s;
}
.detail-slider-btn:hover { background: rgba(201,151,58,0.85); }
.detail-slider-btn.prev { left: 10px; }
.detail-slider-btn.next { right: 10px; }

.detail-slider-dots {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 7px;
  z-index: 10;
}

.detail-slider-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.detail-slider-dot.active {
  background: var(--red, #e31e24);
  transform: scale(1.25);
}

@media (max-width: 768px) {
  .detail-slider-btn {
    width: 32px;
    height: 32px;
    font-size: 12px;
  }
}

/* ── CARD — PRET + VARIANTE ROW ──────────────── */
.product-card-price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.product-card-desc { margin-bottom: 10px; }

/* Variante pe card — oval, negru, rosu la selectie */
.card-variant-selector {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}
.card-variant-btn {
  padding: 3px 11px;
  border: 2px solid #111;
  background: transparent;
  border-radius: 50px;
  font-family: var(--font-c);
  font-size: 10px;
  font-weight: 700;
  color: #111;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  letter-spacing: 0.4px;
  white-space: nowrap;
  line-height: 1.4;
}
.card-variant-btn:hover { border-color: var(--red); color: var(--red); }
.card-variant-btn.active { background: var(--red); border-color: var(--red); color: #fff; }

/* ── CARD — ACTIONS ROW (qty + buton cos) ────── */
.product-card-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Qty selector — negru cu text rosu */
.card-qty-selector {
  display: flex;
  align-items: center;
  background: #111;
  border-radius: 6px;
  overflow: hidden;
  height: 38px;
  flex-shrink: 0;
}
.card-qty-btn {
  width: 32px;
  height: 38px;
  background: none;
  border: none;
  color: var(--red);
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.card-qty-btn:hover { background: #333; }
.card-qty-display {
  color: var(--red);
  font-family: var(--font-d);
  font-size: 15px;
  min-width: 26px;
  text-align: center;
  user-select: none;
}

/* Buton Adaugă în coș pe card */
.btn-card-cart {
  flex: 1;
  height: 38px;
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-family: var(--font-c);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: background 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  white-space: nowrap;
  text-transform: uppercase;
}
.btn-card-cart:hover { background: var(--red-dark); }

@media (max-width: 480px) {
  .btn-card-cart { font-size: 10px; padding: 0 8px; }
  .card-qty-btn { width: 28px; }
}

/* ══════════════════════════════════════
   VIDEO SECTION – Pompa Explode
══════════════════════════════════════ */
.video-section {
  background: #0a0a0a;
  padding: 60px 20px;
  text-align: center;
}
.video-tag-wrap {
  margin-bottom: 28px;
}
.video-tag-wrap .section-tag {
  color: #aaa;
}
.video-tag-wrap .section-title {
  color: #fff;
  margin-top: 8px;
}
.video-tag-wrap .section-title span {
  color: var(--red);
}
.video-wrapper {
  max-width: 900px;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,0.6);
  position: relative;
  background: #000;
}
.pompa-video {
  width: 100%;
  height: auto;
  display: block;
  max-height: 520px;
  object-fit: cover;
}

@media (max-width: 768px) {
  .video-section { padding: 40px 16px; }
  .pompa-video { max-height: 260px; }
}

/* ── HEADER ACTUALIZAT: bară neagră permanentă + două rânduri desktop ── */
:root { --nav-h: 104px; }
#navbar,
#navbar.nav-transparent,
#navbar.nav-white,
#navbar.nav-solid {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--nav-h);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  padding: 0;
  gap: 0;
  background: #050505 !important;
  border-bottom: 1px solid rgba(232,0,28,0.22);
  box-shadow: 0 2px 24px rgba(0,0,0,0.35);
}

.nav-topbar {
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 34px;
  background: #111;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.9);
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.4px;
}
.nav-topbar-left,
.nav-topbar-right {
  display: flex;
  align-items: center;
  gap: 28px;
}
.topbar-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  color: rgba(255,255,255,0.9);
}
.topbar-item i { color: var(--red); font-size: 13px; }

.nav-mainbar {
  height: 70px;
  display: flex;
  align-items: center;
  padding: 0 34px;
  background: #050505;
  gap: 28px;
}
.nav-logo-wrap {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}
.nav-logo { height: 50px; cursor: pointer; filter: none; }
.nav-logo:hover { transform: scale(1.04); }
.nav-menu {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 auto;
  margin-left: 18px;
}
.nav-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex: 0 0 auto;
}
.nav-btn {
  color: #fff;
  padding: 10px 13px;
}
.nav-btn:hover { color: var(--red); }
.nav-icon-btn { color: var(--red); }
.nav-social { display: flex; align-items: center; gap: 4px; }
.submenu { top: calc(100% + 12px); }
.mobile-btns-group { display: none; }

@media (max-width: 1100px) {
  .nav-topbar { padding: 0 20px; font-size: 12px; }
  .nav-topbar-left, .nav-topbar-right { gap: 14px; }
  .nav-mainbar { padding: 0 20px; gap: 16px; }
  .nav-menu { gap: 2px; margin-left: 8px; }
  .nav-btn { font-size: 13px; padding: 8px 8px; }
}

@media (max-width: 900px) {
  :root { --nav-h: 72px; }
  #navbar,
  #navbar.nav-transparent,
  #navbar.nav-white,
  #navbar.nav-solid {
    height: var(--nav-h);
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    background: #050505 !important;
  }
  .nav-topbar,
  .nav-menu,
  .nav-actions,
  .nav-left,
  .nav-right { display: none !important; }
  .nav-mainbar {
    width: 100%;
    height: 72px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: #050505;
  }
  .nav-logo-wrap,
  .nav-center { flex: 0 0 auto; justify-content: flex-start; }
  .nav-logo { height: 46px; }
  .mobile-btns-group {
    display: flex !important;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    margin-left: auto;
  }
  .mobile-search-btn,
  .mobile-menu-btn {
    display: flex !important;
    align-items: center;
    justify-content: center;
    color: var(--red);
  }
}


/* ── UPDATE: meniu aerisit + stare activa ── */
.nav-mainbar {
  gap: 34px;
}
.nav-logo-wrap {
  margin-right: clamp(36px, 8vw, 150px);
}
.nav-menu {
  justify-content: flex-end;
  margin-left: auto;
  gap: 14px;
}
.nav-actions {
  margin-left: 22px;
}
.nav-btn.active,
.nav-btn.active:hover {
  color: var(--red);
  text-shadow: 0 0 12px rgba(232,0,28,0.7);
}
.submenu a.active,
.submenu a.active:hover {
  color: var(--red);
  background: rgba(232,0,28,0.08);
  padding-left: 28px;
}
.nav-dropdown:hover .submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

@media (max-width: 1100px) {
  .nav-logo-wrap { margin-right: 24px; }
  .nav-menu { gap: 4px; }
  .nav-actions { margin-left: 8px; }
}

@media (max-width: 900px) {
  .nav-logo-wrap { margin-right: 0; }
}


/* ── UPDATE HOME INTRO CARDS: sub background, fără poze ── */
#hero {
  height: calc(100vh - var(--nav-h));
  min-height: 520px;
  margin-top: var(--nav-h);
}

.hero-cards-overlay,
.hero-cards-mobile {
  display: none !important;
}

.home-intro-cards {
  width: 100%;
  background:
    radial-gradient(circle at 18% 0%, rgba(232,0,28,0.22), transparent 26%),
    linear-gradient(180deg, #080808 0%, #111 100%);
  border-top: 1px solid rgba(232,0,28,0.45);
  border-bottom: 1px solid rgba(232,0,28,0.28);
  padding: 36px 34px 38px;
  display: grid;
  grid-template-columns: repeat(7, minmax(120px, 1fr));
  gap: 18px;
}

.home-intro-card {
  position: relative;
  min-height: 150px;
  padding: 22px 16px 18px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.015));
  color: #fff;
  cursor: pointer;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 14px;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}

.home-intro-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(232,0,28,0.72), transparent 38%, rgba(232,0,28,0.38));
  opacity: 0;
  transition: opacity 0.22s ease;
  pointer-events: none;
}

.home-intro-card::after {
  content: "→";
  position: absolute;
  right: 14px;
  bottom: 10px;
  color: rgba(255,255,255,0.32);
  font-family: var(--font-c);
  font-size: 18px;
  transition: color 0.22s ease, transform 0.22s ease;
}

.home-intro-card:hover {
  transform: translateY(-7px);
  border-color: rgba(232,0,28,0.88);
  box-shadow: 0 18px 38px rgba(232,0,28,0.24), 0 12px 30px rgba(0,0,0,0.34);
  background: linear-gradient(180deg, rgba(232,0,28,0.16), rgba(255,255,255,0.025));
}

.home-intro-card:hover::before { opacity: 1; }
.home-intro-card:hover::after { color: var(--red); transform: translateX(4px); }

.home-intro-icon {
  width: 62px;
  height: 62px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(232,0,28,0.12);
  border: 1px solid rgba(232,0,28,0.40);
  color: #fff;
  font-size: 30px;
  text-shadow: 0 0 18px rgba(232,0,28,0.65);
  position: relative;
  z-index: 1;
  transition: background 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.home-intro-card:hover .home-intro-icon {
  background: var(--red);
  color: #fff;
  transform: scale(1.06);
}

.home-intro-text {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.home-intro-text span {
  color: var(--red);
  font-family: var(--font-c);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.6px;
  text-transform: uppercase;
}

.home-intro-text strong {
  color: #fff;
  font-family: var(--font-c);
  font-size: clamp(18px, 1.55vw, 24px);
  line-height: 1.12;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

@media (max-width: 1200px) {
  .home-intro-cards {
    grid-template-columns: repeat(4, minmax(140px, 1fr));
  }
}

@media (max-width: 900px) {
  #hero {
    height: 100vw;
    min-height: 320px;
    max-height: 520px;
    margin-top: var(--nav-h);
  }
  .home-intro-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 18px 14px 22px;
    gap: 12px;
  }
  .home-intro-card {
    min-height: 126px;
    border-radius: 14px;
    padding: 18px 12px 16px;
  }
  .home-intro-card::before { border-radius: 14px; }
  .home-intro-icon {
    width: 50px;
    height: 50px;
    font-size: 24px;
    border-radius: 13px;
  }
  .home-intro-text strong {
    font-size: 17px;
  }
}

@media (max-width: 420px) {
  .home-intro-cards {
    grid-template-columns: 1fr;
  }
  .home-intro-card {
    min-height: 104px;
    flex-direction: row;
    justify-content: flex-start;
    text-align: left;
    padding: 18px 44px 18px 16px;
  }
}


/* ── UPDATE: topbar vizibil doar sus în pagină ── */
#navbar {
  transition: height 0.22s ease, background 0.22s ease, box-shadow 0.22s ease;
}
.nav-topbar {
  overflow: hidden;
  transition: height 0.22s ease, opacity 0.18s ease, padding 0.22s ease, border-color 0.22s ease;
}
#navbar.topbar-hidden {
  height: 70px !important;
}
#navbar.topbar-hidden .nav-topbar {
  height: 0 !important;
  opacity: 0;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border-bottom-color: transparent;
  pointer-events: none;
}
#navbar.topbar-hidden .nav-mainbar {
  height: 70px;
}

@media (max-width: 900px) {
  #navbar.topbar-hidden {
    height: var(--nav-h) !important;
  }
}


/* ── FIX: topbar fără întârziere/glisare și fără flash alb la scroll ── */
#navbar,
#navbar.nav-transparent,
#navbar.nav-white,
#navbar.nav-solid {
  background: #050505 !important;
  transition: none !important;
  will-change: auto !important;
}
.nav-mainbar,
.nav-topbar {
  background: #050505 !important;
  transition: none !important;
}
#navbar.topbar-hidden,
#navbar.topbar-hidden .nav-topbar,
#navbar.topbar-hidden .nav-mainbar {
  transition: none !important;
}
#hero {
  background: #050505;
}


/* ── UPDATE: home cards 6 iteme, fără Consumabile ── */
.home-intro-cards {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  max-width: 1180px;
  margin: 0 auto;
  padding: 42px 34px 44px !important;
}

.home-intro-card {
  min-height: 185px;
}

@media (max-width: 900px) {
  #hero {
    height: 58vw !important;
    min-height: 260px !important;
    max-height: 420px !important;
    margin-top: var(--nav-h) !important;
    background: #050505 !important;
  }

  .hero-bg-img {
    object-fit: contain !important;
    object-position: center center !important;
    background: #050505 !important;
  }

  .home-intro-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    max-width: none;
    margin: 0;
    padding: 18px 14px 24px !important;
    gap: 12px !important;
  }

  .home-intro-card {
    min-height: 150px !important;
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 18px 10px 16px !important;
    gap: 14px !important;
  }

  .home-intro-text span {
    display: none !important;
  }

  .home-intro-text strong {
    font-size: 18px !important;
    line-height: 1.12 !important;
  }

  .home-intro-icon {
    width: 64px !important;
    height: 64px !important;
    font-size: 30px !important;
  }
}

@media (max-width: 420px) {
  .home-intro-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .home-intro-card {
    min-height: 142px !important;
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 16px 8px 14px !important;
  }

  .home-intro-card::after {
    right: 10px;
    bottom: 8px;
  }

  .home-intro-text strong {
    font-size: 16px !important;
  }
}


/* ── UPDATE: home intro fără chenare vizibile, full-width, fără buton back ── */
body {
  background: #050505 !important;
}

.page-back-btn {
  display: none !important;
}

.home-intro-cards {
  width: 100vw !important;
  max-width: none !important;
  margin: 0 !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: 42px clamp(28px, 6vw, 92px) 46px !important;
  background: #111 !important;
  border-top: 1px solid rgba(232,0,28,0.28) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), inset 0 -1px 0 rgba(232,0,28,0.18) !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: clamp(18px, 3.2vw, 52px) !important;
}

.home-intro-card {
  min-height: 150px !important;
  padding: 10px 6px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  overflow: visible !important;
  gap: 18px !important;
}

.home-intro-card::before,
.home-intro-card::after {
  display: none !important;
  content: none !important;
}

.home-intro-card:hover {
  transform: translateY(-4px) !important;
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}

.home-intro-icon {
  width: 72px !important;
  height: 72px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #fff !important;
  font-size: 42px !important;
  text-shadow: 0 0 18px rgba(232,0,28,0.5) !important;
  box-shadow: none !important;
}

.home-intro-card:hover .home-intro-icon {
  background: transparent !important;
  color: var(--red) !important;
  transform: translateY(-2px) scale(1.04) !important;
}

.home-intro-text span {
  display: none !important;
}

.home-intro-text strong {
  color: #fff !important;
  font-size: clamp(19px, 1.8vw, 27px) !important;
  line-height: 1.18 !important;
  letter-spacing: 0.4px !important;
  text-shadow: none !important;
}

.home-intro-card:hover .home-intro-text strong {
  color: var(--red) !important;
}

@media (max-width: 1200px) {
  .home-intro-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 28px 42px !important;
  }
}

@media (max-width: 900px) {
  .home-intro-cards {
    width: 100vw !important;
    max-width: none !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 24px 18px 34px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px 12px !important;
    background: #111 !important;
  }

  .home-intro-card {
    min-height: 128px !important;
    padding: 8px 4px !important;
    gap: 12px !important;
  }

  .home-intro-icon {
    width: 58px !important;
    height: 58px !important;
    font-size: 34px !important;
  }

  .home-intro-text strong {
    font-size: 17px !important;
    line-height: 1.15 !important;
  }
}

@media (max-width: 420px) {
  .home-intro-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px 10px !important;
    padding: 22px 14px 30px !important;
  }

  .home-intro-card {
    min-height: 116px !important;
    padding: 6px 2px !important;
  }

  .home-intro-icon {
    width: 52px !important;
    height: 52px !important;
    font-size: 30px !important;
  }

  .home-intro-text strong {
    font-size: 15px !important;
  }
}

/* ── UPDATE: animație la scroll pentru cardurile home ── */
.home-intro-cards {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: clamp(18px, 3.2vw, 52px) !important;
}

.home-intro-card {
  opacity: 0 !important;
  will-change: transform, opacity !important;
  transition:
    opacity 3s cubic-bezier(0.22, 1, 0.36, 1),
    transform 3s cubic-bezier(0.22, 1, 0.36, 1),
    color var(--tr) !important;
}

.home-intro-card:nth-child(1),
.home-intro-card:nth-child(2),
.home-intro-card:nth-child(3) {
  transform: translateX(-90px) !important;
}

.home-intro-card:nth-child(4),
.home-intro-card:nth-child(5),
.home-intro-card:nth-child(6) {
  transform: translateX(90px) !important;
}

.home-intro-card.is-visible {
  opacity: 1 !important;
  transform: translateX(0) translateY(0) !important;
}

.home-intro-card.is-visible:hover {
  transform: translateY(-4px) !important;
}

.home-intro-card:nth-child(1) { transition-delay: 0.05s !important; }
.home-intro-card:nth-child(2) { transition-delay: 0.18s !important; }
.home-intro-card:nth-child(3) { transition-delay: 0.31s !important; }
.home-intro-card:nth-child(4) { transition-delay: 0.05s !important; }
.home-intro-card:nth-child(5) { transition-delay: 0.18s !important; }
.home-intro-card:nth-child(6) { transition-delay: 0.31s !important; }

@media (max-width: 900px) {
  .home-intro-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px 14px !important;
  }

  .home-intro-card:nth-child(odd) {
    transform: translateX(-58px) !important;
  }

  .home-intro-card:nth-child(even) {
    transform: translateX(58px) !important;
  }

  .home-intro-card.is-visible {
    transform: translateX(0) translateY(0) !important;
  }

  .home-intro-card.is-visible:hover {
    transform: translateY(-2px) !important;
  }

  .home-intro-card:nth-child(1),
  .home-intro-card:nth-child(2) { transition-delay: 0.05s !important; }
  .home-intro-card:nth-child(3),
  .home-intro-card:nth-child(4) { transition-delay: 0.18s !important; }
  .home-intro-card:nth-child(5),
  .home-intro-card:nth-child(6) { transition-delay: 0.31s !important; }
}

@media (prefers-reduced-motion: reduce) {
  .home-intro-card {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}


/* ── LEGAL INFO MOVED FROM FOOTER ───────────────── */
.legal-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
  margin: 28px 0 8px;
}
.legal-info-card {
  background: #f4f4f4;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  padding: 22px 24px;
}
.legal-info-card h4 {
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 14px;
}
.legal-info-card ul { list-style: none; margin: 0; padding: 0; }
.legal-info-card li { margin-bottom: 9px; }
.legal-info-card a,
.legal-info-card p {
  font-size: 13px;
  line-height: 1.7;
  color: #111;
  cursor: pointer;
}
.legal-info-card a:hover { color: var(--red); }

@media (max-width: 900px) {
  .footer-top { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 28px; }
  .footer-col-mobile-move { display: none; }
  .legal-info-grid { grid-template-columns: 1fr; gap: 14px; margin-top: 24px; }
  .legal-info-card { padding: 18px 20px; }
}

@media (min-width: 901px) {
  .legal-info-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}


/* ── FOOTER SOCIAL ICONS + MOBILE FOOTER CLEANUP ───────────────── */
.footer-social-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}
.footer-social-links a {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--red);
  color: #050505;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  box-shadow: 0 0 14px rgba(232,0,28,0.24);
  transition: transform var(--tr), box-shadow var(--tr), background var(--tr);
}
.footer-social-links a:hover,
.footer-social-links a:active {
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 0 18px rgba(232,0,28,0.42);
  background: #ff1a33;
}

@media (max-width: 900px) {
  .footer-col-about { display: none; }
  .footer-bottom {
    align-items: center;
  }
  .footer-logo-wrap,
  .footer-social-links {
    width: 100%;
    justify-content: center;
  }
  .footer-logo-wrap img {
    margin: 0 auto;
  }
  .footer-social-links {
    gap: 10px;
    margin: 2px 0 8px;
  }
  .footer-social-links a {
    width: 38px;
    height: 38px;
    font-size: 17px;
  }
}

@media (min-width: 901px) {
  .footer-social-links {
    margin-left: auto;
    margin-right: auto;
  }
  .legal-info-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* ── FINAL FIX: footer social doar pe mobil + layout corect + fără overflow orizontal ── */
html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden !important;
}

.page,
#navbar,
.nav-mainbar,
.mobile-drawer,
.drawer-panel {
  max-width: 100vw;
  box-sizing: border-box;
}

@media (min-width: 901px) {
  .footer-social-links {
    display: none !important;
  }
}

@media (max-width: 900px) {
  body {
    position: relative;
  }

  #navbar,
  .nav-mainbar {
    width: 100% !important;
    max-width: 100vw !important;
    overflow: hidden !important;
  }

  .nav-logo-wrap {
    min-width: 0 !important;
    flex: 1 1 auto !important;
    max-width: calc(100vw - 130px) !important;
  }

  .nav-logo {
    max-width: 210px !important;
    height: auto !important;
    max-height: 52px !important;
    object-fit: contain !important;
  }

  .mobile-btns-group {
    flex: 0 0 auto !important;
    max-width: 116px !important;
    gap: 8px !important;
  }

  .mobile-search-btn,
  .mobile-menu-btn {
    width: 46px !important;
    height: 46px !important;
    flex: 0 0 46px !important;
  }

  .home-intro-cards {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    overflow-x: hidden !important;
  }

  .footer-bottom {
    display: grid !important;
    grid-template-columns: minmax(116px, auto) 1fr !important;
    align-items: center !important;
    justify-content: stretch !important;
    column-gap: 12px !important;
    row-gap: 14px !important;
    padding: 18px 20px 20px !important;
    width: 100% !important;
  }

  .footer-logo-wrap {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: auto !important;
    justify-content: flex-start !important;
    display: flex !important;
    min-width: 0 !important;
  }

  .footer-logo-wrap img {
    margin: 0 !important;
    height: 34px !important;
    max-width: 118px !important;
    object-fit: contain !important;
  }

  .footer-social-links {
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: auto !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 7px !important;
    margin: 0 !important;
    flex-wrap: nowrap !important;
    min-width: 0 !important;
  }

  .footer-social-links a {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    font-size: 15px !important;
    box-shadow: 0 0 10px rgba(232,0,28,0.22) !important;
  }

  .footer-badges {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    width: 100% !important;
    justify-content: flex-start !important;
  }

  .footer-copy {
    grid-column: 1 / -1 !important;
    grid-row: 3 !important;
    width: 100% !important;
  }
}

@media (max-width: 390px) {
  .nav-logo { max-width: 185px !important; }
  .mobile-btns-group { max-width: 104px !important; gap: 4px !important; }
  .mobile-search-btn,
  .mobile-menu-btn {
    width: 44px !important;
    height: 44px !important;
    flex-basis: 44px !important;
  }
  .footer-bottom {
    grid-template-columns: minmax(100px, auto) 1fr !important;
    column-gap: 8px !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
  .footer-logo-wrap img {
    max-width: 104px !important;
  }
  .footer-social-links {
    gap: 5px !important;
  }
  .footer-social-links a {
    width: 29px !important;
    height: 29px !important;
    min-width: 29px !important;
    font-size: 13px !important;
  }
}

/* ── FIX FINAL: contrast text pe fundal negru pentru pagini produse/service/portofoliu/contact ── */
#page-products,
#page-product-detail,
#page-service,
#page-portfolio,
#page-contact {
  background: #050505 !important;
  color: #f5f5f5 !important;
}

#page-products .content-section,
#page-product-detail .detail-hero,
#page-service .service-intro,
#page-portfolio .portfolio-hero,
#page-contact .contact-page {
  background: #050505 !important;
  color: #f5f5f5 !important;
}

#page-products .section-title,
#page-service .section-title,
#page-portfolio .section-title,
#page-contact .section-title,
#page-product-detail .detail-name,
#page-contact .contact-info h2 {
  color: #ffffff !important;
  opacity: 1 !important;
  text-shadow: 0 0 12px rgba(255,255,255,0.14), 0 0 22px rgba(232,0,28,0.10) !important;
}

#page-product-detail .detail-desc,
#page-service .about-text,
#page-portfolio .about-text,
#page-contact .contact-item-content p,
#page-contact .contact-item-content a {
  color: rgba(255,255,255,0.88) !important;
  opacity: 1 !important;
  text-shadow: 0 0 8px rgba(255,255,255,0.08) !important;
}

#page-product-detail .detail-price small,
#page-contact .contact-item-content h4 {
  color: rgba(255,255,255,0.72) !important;
}

#page-product-detail .btn-secondary {
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.40) !important;
  background: rgba(255,255,255,0.04) !important;
}

#page-product-detail .btn-secondary:hover {
  border-color: var(--red) !important;
  color: var(--red) !important;
}

#page-products .cat-tab {
  color: rgba(255,255,255,0.72) !important;
  border-color: rgba(255,255,255,0.22) !important;
}

#page-products .cat-tab:hover,
#page-products .cat-tab.active {
  color: #ffffff !important;
  border-color: var(--red) !important;
  background: rgba(232,0,28,0.16) !important;
}

#page-service .service-feature-card,
#page-service .alidet-service-card,
#page-portfolio .portfolio-card {
  background: #f2f2f2 !important;
  color: #111 !important;
}

#page-service .service-feature-card p,
#page-service .alidet-service-card p,
#page-portfolio .portfolio-card-desc {
  color: rgba(0,0,0,0.76) !important;
}

#page-contact .contact-item-icon {
  background: rgba(232,0,28,0.14) !important;
  color: #ffffff !important;
}

@media (max-width: 900px) {
  #page-product-detail .detail-hero,
  #page-products .content-section,
  #page-service .service-intro,
  #page-portfolio .portfolio-hero,
  #page-contact .contact-page {
    background: #050505 !important;
  }

  #page-product-detail .detail-name {
    font-size: clamp(30px, 10vw, 46px) !important;
    line-height: 0.98 !important;
  }

  #page-product-detail .detail-desc {
    font-size: 15px !important;
    line-height: 1.75 !important;
  }
}

/* ── FIX: fundal alb produse/portofoliu + titluri negre pe secțiuni albe ── */
#page-products,
#page-portfolio {
  background: #ffffff !important;
  color: #111111 !important;
}

#page-products .content-section,
#page-portfolio .portfolio-hero,
#page-portfolio .portfolio-grid {
  background: #ffffff !important;
  color: #111111 !important;
}

#page-products .section-title,
#page-portfolio .section-title,
#page-products .section-title:not(span),
#page-portfolio .section-title:not(span),
#page-products .section-title,
#page-portfolio .section-title {
  color: #111111 !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

#page-products .section-title span,
#page-portfolio .section-title span,
#page-service .section-title span {
  color: var(--red) !important;
}

#page-portfolio .about-text {
  color: rgba(0,0,0,0.88) !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

#page-products .cat-tab {
  color: rgba(0,0,0,0.72) !important;
  border-color: rgba(0,0,0,0.18) !important;
  background: #ffffff !important;
}

#page-products .cat-tab:hover,
#page-products .cat-tab.active {
  color: #111111 !important;
  border-color: var(--red) !important;
  background: rgba(232,0,28,0.08) !important;
}

#page-service .content-section,
#page-service .content-section.alt {
  background: #ffffff !important;
  color: #111111 !important;
}

#page-service .content-section .section-title,
#page-service .content-section.alt .section-title {
  color: #111111 !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

@media (max-width: 900px) {
  #page-products,
  #page-portfolio,
  #page-products .content-section,
  #page-portfolio .portfolio-hero,
  #page-portfolio .portfolio-grid,
  #page-service .content-section,
  #page-service .content-section.alt {
    background: #ffffff !important;
    color: #111111 !important;
  }

  #page-products .section-title,
  #page-portfolio .section-title,
  #page-service .content-section .section-title,
  #page-service .content-section.alt .section-title {
    color: #111111 !important;
    text-shadow: none !important;
  }
}


/* ── UNIVERSAL FOOTER FIX: același footer mic pe toate paginile, fără pagina Acasă ── */
#page-selfwash > footer,
#page-service > footer,
#page-portfolio > footer,
#page-contact > footer,
#page-products > footer,
#page-product-detail > footer,
#page-cart > footer,
#page-search-results-page > footer,
#page-legal > footer {
  background: #e4e4e4;
  border-top: 1px solid rgba(0,0,0,0.1);
}

#page-selfwash .footer-bottom,
#page-service .footer-bottom,
#page-portfolio .footer-bottom,
#page-contact .footer-bottom,
#page-products .footer-bottom,
#page-product-detail .footer-bottom,
#page-cart .footer-bottom,
#page-search-results-page .footer-bottom,
#page-legal .footer-bottom {
  padding: 20px 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

@media (min-width: 901px) {
  #page-selfwash .footer-social-links,
  #page-service .footer-social-links,
  #page-portfolio .footer-social-links,
  #page-contact .footer-social-links,
  #page-products .footer-social-links,
  #page-product-detail .footer-social-links,
  #page-cart .footer-social-links,
  #page-search-results-page .footer-social-links,
  #page-legal .footer-social-links {
    display: none !important;
  }
}

@media (max-width: 900px) {
  #page-selfwash .footer-bottom,
  #page-service .footer-bottom,
  #page-portfolio .footer-bottom,
  #page-contact .footer-bottom,
  #page-products .footer-bottom,
  #page-product-detail .footer-bottom,
  #page-cart .footer-bottom,
  #page-search-results-page .footer-bottom,
  #page-legal .footer-bottom {
    display: grid !important;
    grid-template-columns: minmax(116px, auto) 1fr !important;
    align-items: center !important;
    column-gap: 12px !important;
    row-gap: 14px !important;
    padding: 18px 20px 20px !important;
    width: 100% !important;
  }
}

/* ── FIX LEGAL NAV + CONTACT CALL BUTTON ───────────────── */
@media (min-width: 901px) {
  #page-legal .legal-nav {
    display: none !important;
  }
}

#page-contact .btn-secondary[href^="tel:"],
.contact-cta-group .btn-secondary[href^="tel:"] {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #ffffff !important;
  box-shadow: 0 8px 24px rgba(255,255,255,0.16), 0 0 0 1px rgba(0,0,0,0.08) inset !important;
}

#page-contact .btn-secondary[href^="tel:"]:hover,
.contact-cta-group .btn-secondary[href^="tel:"]:hover {
  background: #f2f2f2 !important;
  border-color: #f2f2f2 !important;
  color: var(--red) !important;
}

/* ── HIDE LEGAL INFO CARDS ON DESKTOP ONLY ─────────────────
   Cardurile din pagina Politică Cookie / Legal rămân vizibile pe telefon,
   dar sunt ascunse pe desktop deoarece informațiile există deja în footer. */
@media (min-width: 901px) {
  #page-legal .legal-info-grid {
    display: none !important;
  }
}

@media (max-width: 900px) {
  #page-legal .legal-info-grid {
    display: grid !important;
  }
}


/* ── TEAM CARDS / ECHIPA NOASTRĂ ── */
.team-section,
.team-page-wrap {
  background: #ffffff !important;
  color: #111 !important;
}

.team-page-wrap {
  padding: calc(var(--nav-h) + 54px) 56px 84px;
  min-height: calc(100vh - var(--nav-h));
}

.team-page-header {
  text-align: center;
  max-width: 780px;
  margin: 0 auto 42px;
}

.team-page-wrap .section-title,
.team-section .section-title,
.contact-team-inline .section-title {
  color: #111 !important;
  text-shadow: none !important;
}

.team-section-lead {
  max-width: 720px;
  margin: -22px auto 34px;
  text-align: center;
  color: rgba(0,0,0,0.68) !important;
  font-size: 15px;
  line-height: 1.7;
}

.team-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  padding: 0 56px 72px;
}

.team-page-wrap .team-cards {
  padding: 0;
  max-width: 1120px;
  margin: 0 auto;
}

.team-card {
  background: #050505 !important;
  color: #ffffff !important;
  border: 2px solid var(--red) !important;
  border-radius: 18px;
  padding: 28px 24px;
  text-align: center;
  cursor: pointer;
  min-height: 100%;
  box-shadow: 0 18px 44px rgba(0,0,0,0.18);
  transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
}

.team-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 54px rgba(232,0,28,0.22);
  border-color: #ff1a33 !important;
}

.team-emoji {
  width: 86px;
  height: 86px;
  margin: 0 auto 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 46px;
  background: #ffffff;
  border: 3px solid var(--red);
  box-shadow: inset 0 0 0 5px #050505;
}

.team-role {
  display: block;
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--red) !important;
  margin-bottom: 8px;
}

.team-card h3 {
  font-family: var(--font-d);
  font-size: 42px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #ffffff !important;
  margin-bottom: 10px;
}

.team-card p {
  color: rgba(255,255,255,0.84) !important;
  font-size: 14px;
  line-height: 1.65;
  margin-bottom: 18px;
}

.team-phone,
.team-whatsapp {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: 100%;
  border-radius: 8px;
  padding: 12px 14px;
  font-family: var(--font-c);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  transition: transform var(--tr), background var(--tr), color var(--tr);
}

.team-phone {
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.28);
  margin-bottom: 10px;
}

.team-phone:hover {
  color: var(--red) !important;
  border-color: var(--red);
}

.team-whatsapp {
  color: #ffffff !important;
  background: #25D366;
  border: 1px solid #25D366;
}

.team-whatsapp:hover {
  background: #1ebe5d;
  transform: translateY(-2px);
}

.contact-team-inline {
  margin-top: 34px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.16);
}

#page-contact .contact-team-inline .team-section-lead {
  margin: 0 0 18px;
  text-align: left;
  color: rgba(255,255,255,0.82) !important;
}

#page-contact .team-cards-contact {
  grid-template-columns: 1fr;
  padding: 0;
  gap: 16px;
}

#page-contact .team-cards-contact .team-card {
  text-align: left;
  display: grid;
  grid-template-columns: 76px 1fr;
  column-gap: 16px;
  align-items: center;
}

#page-contact .team-cards-contact .team-emoji {
  grid-row: 1 / 7;
  width: 66px;
  height: 66px;
  font-size: 34px;
  margin: 0;
}

#page-contact .team-cards-contact .team-card h3 {
  font-size: 30px;
}

#page-contact .team-cards-contact .team-card p {
  margin-bottom: 12px;
}

#page-team {
  background: #ffffff !important;
  color: #111 !important;
}

@media (max-width: 900px) {
  .team-page-wrap { padding: calc(var(--nav-h) + 38px) 20px 64px; }
  .team-cards { grid-template-columns: 1fr; padding: 0 20px 56px; }
  .team-section-lead { margin-top: -16px; }
  #page-contact .team-cards-contact .team-card { grid-template-columns: 1fr; text-align: center; }
  #page-contact .team-cards-contact .team-emoji { grid-row: auto; margin: 0 auto 12px; }
}


/* Contact map embed */
.contact-map-wrap {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  overflow: hidden;
  min-height: 380px;
}
.contact-map-wrap iframe {
  width: 100%;
  height: 100%;
  min-height: 380px;
  border: 0;
  display: block;
}
@media (max-width: 900px) {
  .contact-map-wrap,
  .contact-map-wrap iframe {
    min-height: 320px;
  }
}


/* ═══════════════════════════════════════
   FIX FINAL CONTACT / FOOTER / SERVICE
   - Contact, Echipa si Maps pe acelasi rand pe desktop
   - carduri egale si mai compacte
   - footer jos pe pagina Contact
   - cele 6 carduri Service pe un singur rand
═══════════════════════════════════════ */

/* Footer fara Suport Clienti: coloanele ramase se distribuie egal */
.footer-top {
  grid-template-columns: repeat(5, minmax(150px, 1fr)) !important;
  gap: 34px !important;
  padding: 46px 56px 34px !important;
}
.footer-col p,
.footer-col ul li a {
  word-break: normal;
  overflow-wrap: anywhere;
}

/* Pagina Contact: footerul ramane jos, nu urca sub continut */
#page-contact.page.active {
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
}
#page-contact .contact-page {
  flex: 1 0 auto !important;
  width: 100% !important;
  max-width: 1260px !important;
  margin: 0 auto !important;
  padding: calc(var(--nav-h) + 44px) 32px 68px !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 0.95fr) minmax(360px, 1.12fr) minmax(300px, 1fr) !important;
  align-items: start !important;
  gap: 26px !important;
  background: #050505 !important;
}
#page-contact footer {
  margin-top: auto !important;
  flex-shrink: 0 !important;
}
#page-contact .contact-panel {
  background: #050505 !important;
  border: 1.5px solid var(--red) !important;
  border-radius: 14px !important;
  padding: 24px 22px !important;
  min-height: 360px !important;
  box-shadow: 0 14px 34px rgba(0,0,0,0.18) !important;
}
#page-contact .contact-info h2 {
  font-size: clamp(36px, 3.1vw, 52px) !important;
  line-height: 0.94 !important;
  margin-bottom: 22px !important;
}
#page-contact .contact-item {
  gap: 12px !important;
  margin-bottom: 14px !important;
}
#page-contact .contact-item-icon {
  width: 36px !important;
  height: 36px !important;
  font-size: 15px !important;
  border-radius: 7px !important;
}
#page-contact .contact-item-content h4 {
  font-size: 10px !important;
  letter-spacing: 2.4px !important;
}
#page-contact .contact-item-content a,
#page-contact .contact-item-content p {
  font-size: 13px !important;
  line-height: 1.42 !important;
}
#page-contact .contact-cta-group {
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 18px !important;
}
#page-contact .contact-cta-group .btn-whatsapp,
#page-contact .contact-cta-group .btn-primary,
#page-contact .contact-cta-group .btn-secondary {
  width: auto !important;
  min-width: 0 !important;
  flex: 0 0 auto !important;
  padding: 10px 16px !important;
  font-size: 11px !important;
  letter-spacing: 1.4px !important;
}
#page-contact .contact-social-row {
  margin-top: 14px !important;
  gap: 8px !important;
}
#page-contact .social-pill {
  padding: 7px 13px !important;
  font-size: 10px !important;
}

/* Panoul Echipa din Contact */
#page-contact .contact-team-inline {
  margin-top: 0 !important;
  padding-top: 24px !important;
  border-top: 1.5px solid var(--red) !important;
}
#page-contact .contact-team-inline .section-tag {
  margin-bottom: 12px !important;
}
#page-contact .contact-team-inline .team-section-lead {
  margin: 0 0 16px !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}
#page-contact .team-cards-contact {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 12px !important;
  padding: 0 !important;
}
#page-contact .team-cards-contact .team-card {
  min-height: 84px !important;
  padding: 11px 12px !important;
  border-radius: 12px !important;
  display: grid !important;
  grid-template-columns: 48px 1fr auto !important;
  column-gap: 12px !important;
  row-gap: 4px !important;
  align-items: center !important;
  text-align: left !important;
}
#page-contact .team-cards-contact .team-emoji {
  grid-row: 1 / 5 !important;
  width: 44px !important;
  height: 44px !important;
  font-size: 24px !important;
  margin: 0 !important;
  border-width: 2px !important;
  box-shadow: inset 0 0 0 3px #050505 !important;
}
#page-contact .team-cards-contact .team-role {
  font-size: 9px !important;
  letter-spacing: 1.3px !important;
  margin-bottom: 0 !important;
}
#page-contact .team-cards-contact .team-card h3 {
  font-size: 25px !important;
  line-height: 0.95 !important;
  margin: 0 !important;
}
#page-contact .team-cards-contact .team-card p {
  font-size: 11px !important;
  line-height: 1.35 !important;
  margin: 0 !important;
}
#page-contact .team-cards-contact .team-phone,
#page-contact .team-cards-contact .team-whatsapp {
  width: 104px !important;
  padding: 8px 9px !important;
  font-size: 9.5px !important;
  letter-spacing: 0.8px !important;
  border-radius: 7px !important;
  margin: 0 !important;
}
#page-contact .team-cards-contact .team-phone {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
}
#page-contact .team-cards-contact .team-whatsapp {
  grid-column: 3 !important;
  grid-row: 3 / 5 !important;
}

/* Maps compact si aliniat cu celelalte panouri */
#page-contact .contact-map-wrap {
  min-height: 360px !important;
  height: 360px !important;
  overflow: hidden !important;
}
#page-contact .contact-map-wrap iframe {
  min-height: 360px !important;
  height: 360px !important;
}

/* Service & Mentenanta: 6 carduri pe un rand pe desktop */
#page-service .service-features {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 14px !important;
  padding: 0 54px 56px !important;
}
#page-service .service-feature-card {
  padding: 19px 15px !important;
  min-height: 190px !important;
  border-left-width: 4px !important;
}
#page-service .service-feature-card .icon {
  font-size: 25px !important;
  margin-bottom: 12px !important;
}
#page-service .service-feature-card h3 {
  font-size: 14px !important;
  letter-spacing: 1.3px !important;
  line-height: 1.25 !important;
}
#page-service .service-feature-card p {
  font-size: 12px !important;
  line-height: 1.5 !important;
}

@media (max-width: 1200px) {
  #page-contact .contact-page {
    grid-template-columns: 1fr 1.08fr !important;
  }
  #page-contact .contact-map-wrap {
    grid-column: 1 / -1 !important;
    height: 300px !important;
    min-height: 300px !important;
  }
  #page-contact .contact-map-wrap iframe {
    height: 300px !important;
    min-height: 300px !important;
  }
  #page-service .service-features {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  .footer-top {
    grid-template-columns: 1fr 1fr !important;
    padding: 34px 20px !important;
    gap: 24px !important;
  }
  #page-contact .contact-page {
    grid-template-columns: 1fr !important;
    padding: calc(var(--nav-h) + 28px) 16px 44px !important;
    gap: 18px !important;
  }
  #page-contact .contact-panel {
    min-height: auto !important;
    padding: 20px 16px !important;
  }
  #page-contact .team-cards-contact .team-card {
    grid-template-columns: 48px 1fr !important;
    text-align: left !important;
  }
  #page-contact .team-cards-contact .team-phone,
  #page-contact .team-cards-contact .team-whatsapp {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
    width: 100% !important;
  }
  #page-contact .team-cards-contact .team-emoji {
    grid-row: 1 / 4 !important;
  }
  #page-contact .contact-map-wrap,
  #page-contact .contact-map-wrap iframe {
    min-height: 300px !important;
    height: 300px !important;
  }
  #page-service .service-features {
    grid-template-columns: 1fr !important;
    padding: 0 20px 46px !important;
  }
}

@media (max-width: 520px) {
  .footer-top {
    grid-template-columns: 1fr !important;
  }
  #page-contact .contact-cta-group {
    flex-direction: column !important;
  }
  #page-contact .contact-cta-group .btn-whatsapp,
  #page-contact .contact-cta-group .btn-primary,
  #page-contact .contact-cta-group .btn-secondary {
    width: 100% !important;
    justify-content: center !important;
  }
}


/* ══ HOME BEFORE AFTER SLIDER ═════════════════════ */
.home-before-after-section {
  background: #050505;
  padding: 64px 56px 74px;
  border-top: 1px solid rgba(232,0,28,0.18);
}

.home-ba-copy {
  max-width: 1120px;
  margin: 0 auto 26px;
}

.home-ba-copy .section-title {
  color: #fff;
  margin-bottom: 14px;
}

.home-ba-copy p {
  max-width: 680px;
  color: rgba(255,255,255,0.72);
  font-size: 15px;
  line-height: 1.7;
}

.ba-slider {
  --ba-pos: 50%;
  position: relative;
  max-width: 1120px;
  margin: 0 auto;
  aspect-ratio: 16 / 7;
  min-height: 360px;
  overflow: hidden;
  border-radius: 18px;
  border: 2px solid rgba(232,0,28,0.95);
  background: #080808;
  box-shadow: 0 24px 70px rgba(0,0,0,0.45), 0 0 42px rgba(232,0,28,0.12);
  user-select: none;
  touch-action: none;
}

.ba-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    transform: scale(0.85);
    pointer-events: none;
}

.ba-after-img { z-index: 1; }

.ba-before-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
  overflow: hidden;
  clip-path: inset(0 calc(100% - var(--ba-pos)) 0 0);
}

.ba-before-img { z-index: 2; }

.ba-divider {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--ba-pos);
  width: 3px;
  transform: translateX(-50%);
  background: rgba(255,255,255,0.95);
  z-index: 4;
  box-shadow: 0 0 18px rgba(0,0,0,0.45);
}

.ba-handle {
  position: absolute;
  left: var(--ba-pos);
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(5,5,5,0.88);
  border: 2px solid rgba(255,255,255,0.8);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  pointer-events: none;
}

.ba-handle span {
  width: 2px;
  height: 30px;
  background: rgba(255,255,255,0.85);
  border-radius: 2px;
}

.ba-handle i {
  font-size: 18px;
  line-height: 1;
}

.ba-range {
  position: absolute;
  inset: 0;
  z-index: 6;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: ew-resize;
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
}

.ba-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 74px;
  height: 74px;
  cursor: ew-resize;
}

.ba-range::-moz-range-thumb {
  width: 74px;
  height: 74px;
  border: 0;
  background: transparent;
  cursor: ew-resize;
}

.ba-label {
  position: absolute;
  top: 18px;
  z-index: 7;
  padding: 8px 14px;
  border-radius: 999px;
  font-family: var(--font-c);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0,0,0,0.62);
  border: 1px solid rgba(255,255,255,0.25);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  pointer-events: none;
}

.ba-label-before { left: 18px; }
.ba-label-after { right: 18px; }

@media (max-width: 900px) {
  .home-before-after-section {
    padding: 42px 16px 54px;
  }

  .home-ba-copy {
    margin-bottom: 18px;
  }

  .home-ba-copy p {
    font-size: 14px;
  }

  .ba-slider {
    width: 100%;
    aspect-ratio: 4 / 3;
    min-height: 360px;
    border-radius: 14px;
  }

  .ba-img {
    object-fit: contain;
    background: #070707;
  }

  .ba-handle {
    width: 62px;
    height: 62px;
  }

  .ba-handle span {
    height: 26px;
  }

  .ba-label {
    top: 12px;
    font-size: 10px;
    padding: 7px 10px;
  }

  .ba-label-before { left: 12px; }
  .ba-label-after { right: 12px; }
}

@media (max-width: 480px) {
  .ba-slider {
    min-height: 300px;
    aspect-ratio: 5 / 4;
  }
}
/* ══ END HOME BEFORE AFTER SLIDER ══ */


/* === CONTACT PAGE FIXES 2026 - REVIZUIT === */
#page-contact{
  background:#ffffff !important;
}

#page-contact .contact-page{
  background:#ffffff !important;
  align-items:stretch !important;
}

#page-contact .contact-panel{
  min-height:360px !important;
  height:auto !important;
  display:block !important;
}

#page-contact .contact-map-wrap{
  min-height:360px !important;
  height:100% !important;
}

#page-contact .contact-map-wrap iframe{
  min-height:360px !important;
  height:100% !important;
}

#page-contact .team-cards-contact{
  height:auto !important;
}

#page-contact .team-cards-contact .team-card{
  height:auto !important;
  min-height:84px !important;
  display:grid !important;
}

#page-contact .team-cards-contact .team-card p{
  flex-grow:0 !important;
}

@media (max-width: 900px){
  #page-contact .contact-page{
    align-items:start !important;
  }

  #page-contact .contact-panel{
    min-height:auto !important;
  }

  #page-contact .contact-map-wrap,
  #page-contact .contact-map-wrap iframe{
    height:300px !important;
    min-height:300px !important;
  }
}


/* ═══════════════════════════════════════
   UPDATE CONTACT WHITE THEME + BLACK BORDER
   - pagina Contact pe fundal alb
   - panouri/carduri Contact albe, cu ramă neagră
   - text negru pentru lizibilitate
═══════════════════════════════════════ */
#page-contact,
#page-contact.page.active {
  background: #ffffff !important;
  color: #111111 !important;
}

#page-contact .contact-page {
  background: #ffffff !important;
  color: #111111 !important;
}

#page-contact .contact-panel,
#page-contact .contact-info,
#page-contact .contact-team-inline,
#page-contact .contact-map-wrap {
  background: #ffffff !important;
  color: #111111 !important;
  border: 1.5px solid #000000 !important;
}

#page-contact .contact-info h2,
#page-contact .section-title,
#page-contact .team-cards-contact .team-card h3 {
  color: #111111 !important;
  text-shadow: none !important;
}

#page-contact .contact-info h2 span,
#page-contact .section-title span,
#page-contact .contact-team-inline .section-tag,
#page-contact .team-cards-contact .team-role {
  color: var(--red) !important;
}

#page-contact .contact-item-content h4,
#page-contact .contact-team-inline .team-section-lead,
#page-contact .contact-item-content a,
#page-contact .contact-item-content p {
  color: #111111 !important;
  text-shadow: none !important;
}

#page-contact .contact-item-content a:hover {
  color: var(--red) !important;
}

#page-contact .contact-item-icon {
  background: rgba(232,0,28,0.08) !important;
  border: 1px solid var(--red) !important;
  color: var(--red) !important;
}

#page-contact .team-cards-contact .team-card {
  background: #ffffff !important;
  color: #111111 !important;
  border: 1.5px solid #000000 !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.10) !important;
}

#page-contact .team-cards-contact .team-card p,
#page-contact .team-cards-contact .team-phone {
  color: #111111 !important;
}

#page-contact .team-cards-contact .team-phone {
  border-color: #000000 !important;
}

#page-contact .team-cards-contact .team-emoji {
  background: #ffffff !important;
  box-shadow: inset 0 0 0 3px #ffffff !important;
}

#page-contact .contact-team-inline {
  border-top: 1.5px solid #000000 !important;
}

#page-contact .btn-secondary[href^="tel:"],
#page-contact .contact-cta-group .btn-secondary[href^="tel:"] {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

#page-contact .btn-secondary[href^="tel:"]:hover,
#page-contact .contact-cta-group .btn-secondary[href^="tel:"]:hover {
  color: var(--red) !important;
  border-color: var(--red) !important;
  background: #ffffff !important;
}


/* =========================================================
   ALIDET RESTYLE — alb/negru + butoane roșu închis
   Modificare cerută: texte roșii -> negru, fundaluri -> alb,
   carduri cu ramă neagră, prețuri negre, cantități alb/negru.
========================================================= */
:root {
  --red: #A61E2D;
  --red-dark: #821725;
}

/* Fundaluri principale albe */
body,
.page,
.content-section,
.content-section.alt,
.config-page-header,
.config-step-content,
#search-overlay,
footer,
.footer-top,
.footer-bottom,
.home-before-after-section,
.products-section,
.product-detail-section,
#page-products,
#page-product-detail,
#page-cart,
#page-contact,
#page-service,
#page-portfolio,
#page-team,
#page-legal {
  background: #ffffff !important;
}

/* Eliminare griuri din zone/carduri/interioare */
.feature-box,
.service-feature-card,
.alidet-service-card,
.gallery-placeholder,
.product-card,
.portfolio-card,
.portfolio-card-img,
.portfolio-card-img img,
.contact-page,
.contact-panel,
.contact-info,
.contact-map-wrap,
.contact-team-inline,
.team-card,
.config-list-section,
.config-list-header,
.config-summary-box,
.config-form-box,
.form-group input,
.form-group textarea,
.footer-badge,
.social-pill,
.search-overlay-bar,
.search-card,
.detail-step,
.cart-item,
.cart-summary,
.detail-qty-selector,
.card-qty-selector,
.product-card-img,
.drawer-panel {
  background: #ffffff !important;
}

/* Rame negre pentru carduri */
.feature-box,
.service-feature-card,
.alidet-service-card,
.gallery-placeholder,
.product-card,
.portfolio-card,
.contact-panel,
.contact-info,
.contact-map-wrap,
.contact-team-inline,
.team-card,
.config-list-section,
.config-summary-box,
.config-form-box,
.search-card,
.detail-step,
.cart-item,
.cart-summary,
.product-variant-card,
.card-variant-btn,
.social-pill,
.footer-badge {
  border-color: #000000 !important;
}

.feature-box,
.service-feature-card,
.alidet-service-card,
.product-card,
.portfolio-card,
.contact-panel,
.contact-info,
.contact-map-wrap,
.contact-team-inline,
.team-card,
.config-list-section,
.config-summary-box,
.config-form-box,
.cart-summary {
  border-width: 2px !important;
  border-style: solid !important;
}

/* Texte/etichete care erau roșii devin negre */
.section-tag,
.section-title span,
.sw-hero-content h1 span,
.product-card-cat,
.detail-cat,
.portfolio-card-location,
.config-step-title,
.footer-col h4,
.hero-cat-label,
.hero-cat-card:hover .hero-cat-icon,
.contact-info h2 span,
.team-role,
.team-section .section-tag,
.product-detail-tag,
.search-page-tag,
.cart-item-variant,
.qty-toolbar-label strong,
.card-qty-btn,
.detail-qty-selector #detail-qty-display:focus,
.mobile-cart-btn,
.cli-price,
.config-total-val,
.cart-item-subtotal,
.cart-total-val,
.product-card-price,
.detail-price,
.card-price,
.product-card-price-row,
.product-detail-price,
.price,
.price-value,
.total-price,
.subtotal,
.total {
  color: #111111 !important;
}

/* Iconițe și accent roșu text -> negru, fără să afecteze butoanele roșii */
.nav-btn,
.nav-icon-btn,
.mobile-menu-btn,
.mobile-search-btn,
.contact-item-icon,
.search-submit-btn,
.cart-badge,
.drawer-sub a:hover,
.drawer-link:hover,
.page-back-btn:hover,
.contact-item-content a:hover,
.footer-col ul li a:hover,
.card-variant-btn:hover,
.dcc-view-cart {
  color: #111111 !important;
}

.contact-item-icon {
  background: #ffffff !important;
  border-color: #000000 !important;
}

/* Prețuri absolut toate negre */
.product-card-price,
.product-card-price small,
.detail-price,
.detail-price small,
.cli-price,
.config-total-val,
.cart-item-price,
.cart-item-subtotal,
.cart-total-val,
.product-card-price-row,
.card-price,
.product-detail-price,
.price,
.price-value,
.total-price,
.subtotal,
.total,
[class*="price"],
[class*="Price"],
[class*="total"],
[class*="Total"] {
  color: #111111 !important;
}

/* Butoane principale — roșu mai închis, nu aprins */
.btn-primary,
.btn-add-cart,
.qty-toolbar-btn,
.card-add-btn,
.product-add-btn,
.cart-checkout-btn,
.dcc-add-cart,
button[type="submit"],
input[type="submit"],
.toast {
  background: var(--red) !important;
  border-color: var(--red) !important;
  color: #ffffff !important;
  box-shadow: none !important;
}

.btn-primary:hover,
.btn-add-cart:hover,
.qty-toolbar-btn:hover,
.card-add-btn:hover,
.product-add-btn:hover,
.cart-checkout-btn:hover,
.dcc-add-cart:hover,
button[type="submit"]:hover,
input[type="submit"]:hover {
  background: var(--red-dark) !important;
  border-color: var(--red-dark) !important;
  color: #ffffff !important;
}

/* Butoane secundare albe/negre */
.btn-secondary,
.dcc-view-cart,
.cart-item-remove {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
}

.btn-secondary:hover,
.dcc-view-cart:hover,
.cart-item-remove:hover {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
}

/* Cantitate produse/coș: alb + negru */
.qty-btn,
.card-qty-btn,
.detail-qty-selector .qty-btn,
.cart-item-qty,
.card-qty-selector,
.detail-qty-selector,
.cart-item-qty span,
.detail-qty-selector #detail-qty-display,
.qty-value,
.quantity-value {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
}

.qty-btn:hover,
.card-qty-btn:hover,
.detail-qty-selector .qty-btn:hover {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
}

.cart-item-qty span,
.detail-qty-selector #detail-qty-display,
.qty-value,
.quantity-value {
  color: #111111 !important;
}

/* Borduri/linii decorative care erau roșii -> negre, exceptând butoanele */
.submenu,
.config-total-line,
.service-feature-card,
.alidet-service-card,
.detail-step:hover,
.cat-tab:hover,
.cat-tab.active,
.product-card:hover,
.portfolio-card:hover,
.gallery-placeholder:hover,
.social-pill:hover,
.form-group input:focus,
.form-group textarea:focus,
.search-overlay-bar {
  border-color: #000000 !important;
}

.submenu {
  border-top-color: #000000 !important;
}

.config-step.active {
  color: #111111 !important;
  border-bottom-color: #000000 !important;
}

.config-step.active span {
  background: #111111 !important;
  color: #ffffff !important;
}

/* Hover-uri mai discrete */
.feature-box:hover,
.cat-tab:hover,
.cat-tab.active,
.product-card:hover,
.portfolio-card:hover {
  background: #ffffff !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.10) !important;
}

/* Badge coș rămâne buton/accent roșu închis */
.cart-badge {
  background: var(--red) !important;
  color: #ffffff !important;
}

/* WhatsApp rămâne verde */
.btn-whatsapp {
  background: #25D366 !important;
  border-color: #25D366 !important;
  color: #ffffff !important;
}

.btn-whatsapp:hover {
  background: #1ebe5d !important;
  border-color: #1ebe5d !important;
  color: #ffffff !important;
}

/* =========================================================
   ALIDET HOTFIX — curățare vizuală alb/negru + roșu doar pe butoane
   ========================================================= */

/* 1) Navigație: text vizibil pe navbar negru */
#navbar,
.nav-solid {
  background: #050505 !important;
}
#navbar .nav-btn,
#navbar .nav-icon-btn,
#navbar .mobile-search-btn,
#navbar .mobile-menu-btn,
#navbar .topbar-item {
  color: #ffffff !important;
  text-shadow: none !important;
}
#navbar .nav-btn:hover,
#navbar .nav-btn.active,
#navbar .nav-btn.active:hover,
#navbar .nav-icon-btn:hover,
#navbar .mobile-search-btn:hover,
#navbar .mobile-menu-btn:hover {
  color: #ffffff !important;
  background: rgba(166, 30, 45, 0.18) !important;
  border: 1px solid #A61E2D !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
#navbar .submenu a,
#navbar .submenu a:hover,
#navbar .submenu a.active {
  color: #111111 !important;
  background: #ffffff !important;
}

/* 2) Fundaluri albe peste tot unde au rămas blocuri negre/gri */
#page-products,
#page-selfwash,
#page-service,
#page-portfolio,
#page-team,
#page-cart,
#page-product-detail,
.content-section,
.content-section.alt,
.video-section,
.service-intro,
.portfolio-hero,
.photo-gallery,
.alidet-service-cards,
.config-page-header,
.config-step-content,
.config-list-section,
.config-list-header,
.config-summary-box,
.config-form-box,
footer,
.footer-top,
.footer-bottom,
.product-card,
.feature-box,
.service-feature-card,
.alidet-service-card,
.portfolio-card,
.portfolio-card-img,
.portfolio-card-img img,
.gallery-placeholder,
.cat-tab,
.search-overlay-bar,
.drawer-panel {
  background: #ffffff !important;
}

/* 3) Texte roșii sau invizibile -> negru */
.section-tag,
.section-title,
.section-title span,
.sw-hero-content h1,
.sw-hero-content h1 span,
.video-tag-wrap .section-title,
.video-tag-wrap .section-title span,
.product-card-cat,
.product-card-name,
.product-card-desc,
.portfolio-card-location,
.portfolio-card-title,
.portfolio-card-desc,
.service-intro .section-title,
.service-intro .section-title span,
.service-intro p,
.content-section .section-title,
.content-section .section-title span,
.content-section.alt .section-title,
.content-section.alt .section-title span,
.feature-box h3,
.feature-box p,
.service-feature-card h3,
.service-feature-card p,
.alidet-service-card h3,
.alidet-service-card p,
.gallery-placeholder,
.gallery-placeholder i,
.gallery-placeholder span,
.config-step-title,
.cli-name,
.cli-desc,
.footer-col h4,
.footer-col p,
.footer-col a,
.footer-copy,
.about-text,
.detail-cat,
.detail-name,
.detail-desc,
.page-back-btn,
.cat-tab,
.cat-tab.active,
.cat-tab:hover {
  color: #111111 !important;
  text-shadow: none !important;
}

/* 4) Prețuri și totaluri — toate negre */
.product-card-price,
.product-card-price small,
.detail-price,
.detail-price small,
.cli-price,
.config-total-val,
.config-total-line,
.cart-item-price,
.cart-item-subtotal,
.cart-total-val,
.product-card-price-row,
.card-price,
.product-detail-price,
.price,
.price-value,
.total-price,
.subtotal,
.total,
[class*="price"],
[class*="Price"],
[class*="total"],
[class*="Total"] {
  color: #111111 !important;
}

/* 5) Borduri carduri — negru curat */
.feature-box,
.product-card,
.service-feature-card,
.alidet-service-card,
.portfolio-card,
.gallery-placeholder,
.cat-tab,
.config-list-section,
.config-summary-box,
.config-form-box,
.form-group input,
.form-group textarea,
.social-pill,
.footer-badge,
.search-overlay-bar,
.detail-step,
.card-qty-selector,
.detail-qty-selector,
.cart-item-qty,
.qty-btn,
.card-qty-btn,
.quantity-value,
.qty-value {
  border-color: #000000 !important;
}
.service-feature-card,
.alidet-service-card {
  border-left-color: #000000 !important;
  border-top-color: #000000 !important;
}

/* 6) Butoane — doar ele rămân roșu închis */
.btn-primary,
.btn-add-cart,
.card-add-btn,
.product-add-btn,
.cart-checkout-btn,
.dcc-add-cart,
button[type="submit"],
input[type="submit"],
.toast {
  background: #A61E2D !important;
  border-color: #A61E2D !important;
  color: #ffffff !important;
  text-shadow: none !important;
  box-shadow: none !important;
}
.btn-primary:hover,
.btn-add-cart:hover,
.card-add-btn:hover,
.product-add-btn:hover,
.cart-checkout-btn:hover,
.dcc-add-cart:hover,
button[type="submit"]:hover,
input[type="submit"]:hover {
  background: #821725 !important;
  border-color: #821725 !important;
  color: #ffffff !important;
}

/* 7) Butoane cantitate + valoarea cantității: alb cu text negru */
.qty-btn,
.card-qty-btn,
.detail-qty-selector .qty-btn,
.cart-item-qty,
.card-qty-selector,
.detail-qty-selector,
.cart-item-qty span,
.detail-qty-selector #detail-qty-display,
.qty-value,
.quantity-value,
input[type="number"] {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
  text-shadow: none !important;
}
.qty-btn:hover,
.card-qty-btn:hover,
.detail-qty-selector .qty-btn:hover {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
}

/* 8) Iconițe/elemente decorative roșii rămase -> negru, cu excepția butoanelor principale */
.feature-box .ficon,
.service-feature-card .icon,
.contact-item-icon,
.search-submit-btn,
.search-close-btn:hover,
.page-back-btn:hover,
.drawer-link:hover,
.drawer-sub a:hover,
.footer-col ul li a:hover,
.social-pill:hover,
.gallery-placeholder i,
.gallery-placeholder svg,
.product-card i,
.portfolio-card i {
  color: #111111 !important;
  text-shadow: none !important;
}
.contact-item-icon {
  background: #ffffff !important;
  border-color: #000000 !important;
}

/* 9) Secțiunile reclamate explicit */
.video-section,
.video-tag-wrap,
#page-service .service-intro,
#page-service .content-section,
#page-service .content-section.alt,
#page-service .service-features,
#page-service .alidet-service-cards,
#page-portfolio,
#page-portfolio .portfolio-hero,
#page-portfolio .portfolio-grid,
#page-portfolio .content-section,
#page-products .content-section {
  background: #ffffff !important;
  color: #111111 !important;
}
#page-service .section-title,
#page-service .section-title span,
#page-portfolio .section-title,
#page-portfolio .section-title span,
#page-products .section-title,
#page-products .section-title span,
.video-tag-wrap .section-title,
.video-tag-wrap .section-title span {
  color: #111111 !important;
  text-shadow: none !important;
}

/* 10) Hover discret pe carduri */
.feature-box:hover,
.product-card:hover,
.service-feature-card:hover,
.alidet-service-card:hover,
.portfolio-card:hover,
.cat-tab:hover,
.cat-tab.active {
  background: #ffffff !important;
  border-color: #000000 !important;
  color: #111111 !important;
  box-shadow: 0 10px 24px rgba(0,0,0,0.08) !important;
}

/* 11) Badge coș — vizibil, roșu închis */
.cart-badge {
  background: #A61E2D !important;
  color: #ffffff !important;
}

/* WhatsApp rămâne verde */
.btn-whatsapp,
.btn-whatsapp:hover {
  background: #25D366 !important;
  border-color: #25D366 !important;
  color: #ffffff !important;
}

/* ── PATCH: echipă/contact vizibil + navbar glow roșu ── */
.nav-btn,
.nav-btn:visited {
  color: #ffffff !important;
  text-shadow: none !important;
}
.nav-btn:hover,
.nav-btn:focus {
  color: #ff1a33 !important;
  text-shadow: 0 0 8px rgba(232,0,28,0.85), 0 0 18px rgba(232,0,28,0.55) !important;
}
.nav-btn.active,
.nav-btn.active:hover,
.nav-btn.active:focus {
  color: #ff1a33 !important;
  border: 1px solid #ff1a33 !important;
  background: rgba(232,0,28,0.08) !important;
  box-shadow: 0 0 14px rgba(232,0,28,0.45) !important;
  text-shadow: 0 0 8px rgba(232,0,28,0.85), 0 0 18px rgba(232,0,28,0.55) !important;
}
.nav-icon-btn,
.nav-icon-btn:visited {
  color: #ffffff !important;
}
.nav-icon-btn:hover,
.nav-icon-btn:focus {
  color: #ff1a33 !important;
  text-shadow: 0 0 8px rgba(232,0,28,0.85), 0 0 18px rgba(232,0,28,0.55) !important;
}

.team-card,
#page-contact .team-cards-contact .team-card,
.team-cards-preview .team-card,
.team-cards-full .team-card {
  background: #ffffff !important;
  color: #111111 !important;
  border: 2px solid #000000 !important;
  box-shadow: 0 18px 44px rgba(0,0,0,0.10) !important;
}
.team-card:hover,
#page-contact .team-cards-contact .team-card:hover {
  border-color: #000000 !important;
  box-shadow: 0 22px 54px rgba(0,0,0,0.12) !important;
}
.team-card h3,
.team-card p,
.team-card .team-role,
.team-role,
#page-contact .team-cards-contact .team-card h3,
#page-contact .team-cards-contact .team-card p,
#page-contact .team-cards-contact .team-role,
.team-section-lead,
.contact-team-inline .team-section-lead {
  color: #111111 !important;
  text-shadow: none !important;
  opacity: 1 !important;
  visibility: visible !important;
}
.team-phone,
#page-contact .team-cards-contact .team-phone {
  background: #ffffff !important;
  color: #111111 !important;
  border: 1.5px solid #000000 !important;
  text-shadow: none !important;
}
.team-phone:hover,
#page-contact .team-cards-contact .team-phone:hover {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
}
.team-whatsapp,
#page-contact .team-cards-contact .team-whatsapp {
  background: #25D366 !important;
  color: #ffffff !important;
  border-color: #25D366 !important;
}
.team-whatsapp:hover,
#page-contact .team-cards-contact .team-whatsapp:hover {
  background: #1ebe5d !important;
  color: #ffffff !important;
  border-color: #1ebe5d !important;
}

/* ── PATCH NAVBAR: stil tip carduri home, fără chenar/fundal ── */
#navbar .nav-btn,
#navbar .nav-btn:visited {
  color: #ffffff !important;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

#navbar .nav-btn:hover,
#navbar .nav-btn:focus,
#navbar .nav-btn:hover i,
#navbar .nav-btn:focus i {
  color: #b51f32 !important;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  text-shadow:
    0 0 8px rgba(181,31,50,0.75),
    0 0 18px rgba(181,31,50,0.45) !important;
}

#navbar .nav-btn.active,
#navbar .nav-btn.active:hover,
#navbar .nav-btn.active:focus,
#navbar .nav-btn.active i,
#navbar .nav-btn.active:hover i,
#navbar .nav-btn.active:focus i {
  color: #b51f32 !important;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  text-shadow:
    0 0 8px rgba(181,31,50,0.75),
    0 0 18px rgba(181,31,50,0.45) !important;
}

/* ── PATCH PRODUCT DETAIL: fundal alb + text negru pentru toate produsele ── */
#page-product-detail,
#page-product-detail .detail-hero,
#page-product-detail .detail-info,
#page-product-detail .detail-img-wrap,
#page-product-detail .detail-main,
#page-product-detail .product-detail-section,
#page-product-detail section,
#page-product-detail .content-section {
  background: #ffffff !important;
  color: #111111 !important;
}

#page-product-detail .detail-name,
#page-product-detail .detail-cat,
#page-product-detail .detail-desc,
#page-product-detail .detail-price,
#page-product-detail .detail-price small,
#page-product-detail .page-back-btn,
#page-product-detail h1,
#page-product-detail h2,
#page-product-detail h3,
#page-product-detail h4,
#page-product-detail p,
#page-product-detail span:not(.cart-badge),
#page-product-detail small,
#page-product-detail li,
#page-product-detail a:not(.btn-primary):not(.btn-add-cart):not(.dcc-add-cart) {
  color: #111111 !important;
  text-shadow: none !important;
  opacity: 1 !important;
}

#page-product-detail .detail-cat,
#page-product-detail .product-detail-tag,
#page-product-detail .section-tag {
  color: #111111 !important;
  letter-spacing: 3px;
}

#page-product-detail .detail-desc {
  color: #222222 !important;
  line-height: 1.75;
}

#page-product-detail .detail-price,
#page-product-detail .detail-price small,
#page-product-detail [class*="price"],
#page-product-detail [class*="Price"] {
  color: #111111 !important;
  text-shadow: none !important;
}

#page-product-detail .detail-img-wrap img {
  background: #ffffff !important;
}

#page-product-detail .btn-secondary,
#page-product-detail .dcc-view-cart {
  background: #ffffff !important;
  color: #111111 !important;
  border: 2px solid #000000 !important;
  text-shadow: none !important;
}

#page-product-detail .btn-secondary:hover,
#page-product-detail .dcc-view-cart:hover {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

#page-product-detail .detail-qty-selector,
#page-product-detail .detail-qty-selector .qty-btn,
#page-product-detail .detail-qty-selector #detail-qty-display {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #000000 !important;
  text-shadow: none !important;
}

#page-product-detail .btn-add-cart,
#page-product-detail .dcc-add-cart {
  background: var(--red) !important;
  color: #ffffff !important;
  border-color: var(--red) !important;
}

#page-product-detail .btn-add-cart:hover,
#page-product-detail .dcc-add-cart:hover {
  background: var(--red-dark) !important;
  color: #ffffff !important;
  border-color: var(--red-dark) !important;
}

@media (max-width: 900px) {
  #page-product-detail,
  #page-product-detail .detail-hero,
  #page-product-detail .detail-info,
  #page-product-detail .product-detail-section,
  #page-product-detail section {
    background: #ffffff !important;
    color: #111111 !important;
  }
}

/* ── PATCH 2026-06-09: text produs mai intens + slider Tesla full-card ── */
#page-product-detail,
#page-product-detail * {
  text-shadow: none !important;
}

#page-product-detail .detail-desc,
#page-product-detail .detail-benefit-card p,
#page-product-detail .detail-step p,
#page-product-detail .detail-pro-tip,
#page-product-detail .detail-specs-table tbody td,
#page-product-detail .detail-specs-table tbody td:first-child,
#page-product-detail .detail-info p,
#page-product-detail .detail-info span,
#page-product-detail .detail-info li,
#page-product-detail .detail-info a,
#page-product-detail .product-card-desc {
  color: #000000 !important;
  opacity: 1 !important;
}

#page-product-detail .detail-specs-table tbody td {
  font-weight: 500 !important;
}

#page-product-detail .detail-specs-table tbody td:first-child {
  font-weight: 700 !important;
  letter-spacing: 1.4px !important;
}

#page-product-detail .detail-specs-table tbody tr {
  background: #ffffff !important;
  border-bottom: 1px solid rgba(0,0,0,0.12) !important;
}

#page-product-detail .detail-specs-table tbody tr:nth-child(even) {
  background: #f7f7f7 !important;
}

#page-product-detail .detail-name,
#page-product-detail .detail-cat,
#page-product-detail .detail-price,
#page-product-detail .detail-price small {
  color: #000000 !important;
  opacity: 1 !important;
}

/* Slider Tesla: imaginea umple complet cardul, fără margini negre */
.ba-slider {
  background: #ffffff !important;
}

.ba-img,
.ba-before-img,
.ba-after-img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
  background: transparent !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  .ba-img,
  .ba-before-img,
  .ba-after-img {
    object-fit: cover !important;
    object-position: center center !important;
    transform: none !important;
    background: transparent !important;
  }
}
