/* ================================
   Font: Oswald (Latin Extended – cu diacritice românești)
   ================================ */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/Inter_28pt-Regular.woff2') format('woff2');
}


@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/Oswald-Regular.woff2') format('woff2');
}



@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/Oswald-SemiBold.woff2') format('woff2');
}


body {
  font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans",
               Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;
}

/* === Fonturi OrangeBox === */

.navbar a, .navbar li, .main-menu a {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 16px;
  text-transform: none;
  color: #222;
}

.banner-title {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 34px;
  letter-spacing: 0.5px;
  color: #111;
  margin-bottom: 0.5rem;
}

.banner-subtitle {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 18px;
  color: #444;
  max-width: 720px;
}

.card-title.h2 {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 24px;
  color: #fff;
}

.card-text {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: #f2f2f2;
}
.navbar a,
.navbar li,
.main-menu a {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.3px;
  padding: 0.75rem 1.25rem;
  text-transform: none;
  color: #222;
}
.banner-title {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 36px;
  letter-spacing: 0.4px;
  margin-bottom: 1rem;
  line-height: 1.2;
  color: #111;
}

.banner-subtitle {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.6;
  color: #444;
  max-width: 760px;
  margin: 0 auto;
}
/* Stil pentru linkurile din meniul principal de categorii */
.header-container a {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.1px;
  text-transform: none;
}
h1, h2, h3 {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
}


/* ================================
   Layout / UI helpers
   ================================ */

/* Sticky sidebar on product page */
@media (min-width: 992px) {
  .obx-sticky { position: sticky; top: 24px; }
}

/* Consistent card look */
.obx-card,
#obx-rental,
#obx-choose-unit {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

/* Tighten spacing inside price/rental cards */
#productPrice .price { line-height: 1; }
#obx-rental .btn,
#obx-choose-unit .btn { min-width: 88px; }

/* Accordion compact */
.obx-acc .accordion-button { padding: .6rem .9rem; }
.obx-acc .accordion-body   { padding: .75rem .9rem; }

/* ================================
   Paletă brand
   ================================ */
:root{
  --obx-orange-50:  #fff3e6;
  --obx-orange-100: #ffe1c7;
  --obx-orange-200: #ffc38a;
  --obx-orange-300: #ffab5c;
  --obx-orange-400: #ff9333;
  --obx-orange-500: #ff7a00; /* brand */
  --obx-orange-600: #e86e00;
  --obx-orange-700: #cc5f00;
  --obx-orange-800: #a74d00;
  --obx-orange-900: #7a3800;
}

/* Carduri tematice (ex. PREȚ + CTA) */
.card.obx-card{
  border: 1.5px solid var(--obx-orange-300);
  box-shadow: 0 2px 10px rgba(255,122,0,.08);
  border-radius: .75rem;
}
.card.obx-card .card-header{
  background: var(--obx-orange-50);
  border-bottom-color: var(--obx-orange-200);
}

/* Buton principal (În coș) – compat Bootstrap .active/.disabled */
.btn.btn-obx{
  --bs-btn-color:#fff;
  --bs-btn-bg:var(--obx-orange-600);
  --bs-btn-border-color:var(--obx-orange-600);
  --bs-btn-hover-color:#fff;
  --bs-btn-hover-bg:var(--obx-orange-700);
  --bs-btn-hover-border-color:var(--obx-orange-700);
  --bs-btn-active-color:#fff;
  --bs-btn-active-bg:var(--obx-orange-800);
  --bs-btn-active-border-color:var(--obx-orange-800);
  --bs-btn-disabled-bg:var(--obx-orange-200);
  --bs-btn-disabled-border-color:var(--obx-orange-200);
}
/* Outline pentru perioade – devine plin la .active fără negru */
.btn.btn-obx-outline{
  --bs-btn-color:var(--obx-orange-700);
  --bs-btn-bg:transparent;
  --bs-btn-border-color:var(--obx-orange-600);
  --bs-btn-hover-color:var(--obx-orange-700);
  --bs-btn-hover-bg:var(--obx-orange-50);
  --bs-btn-hover-border-color:var(--obx-orange-600);
  --bs-btn-active-color:#fff;
  --bs-btn-active-bg:var(--obx-orange-600);
  --bs-btn-active-border-color:var(--obx-orange-600);
}

/* ================================
   „Alegeți boxa” (radio tiles)
   ================================ */
#obx-choose-unit label{
  border:1px solid var(--obx-orange-200);
  border-radius:.5rem;
  padding:.375rem .5rem;
  transition: all .15s ease;
}
#obx-choose-unit label:hover{ background:var(--obx-orange-50); }
#obx-choose-unit input[type="radio"]:checked + span{
  font-weight:600;
  color: var(--obx-orange-800);
}
#obx-choose-unit input[type="radio"]:disabled + span{
  color:#999;
}

/* Highlight când e selectată */
#obx-choose-unit label.is-checked{
  background: var(--obx-orange-50);
  border-color: var(--obx-orange-600);
  box-shadow: 0 0 0 2px var(--obx-orange-50) inset;
}

/* Focus vizibil pe butoanele de perioadă și pe "În coș" */
.btn-obx:focus-visible,
.btn-obx-outline:focus-visible{
  outline: 0;
  box-shadow: 0 0 0 .2rem rgba(255,122,0,.25);
  border-color: var(--obx-orange-600);
}

/* Când "În coș" e activ (nu disabled) */
.btn.btn-obx:not(:disabled){
  --bs-btn-bg: var(--obx-orange-600);
  --bs-btn-border-color: var(--obx-orange-600);
}

/* ascunde complet indicatorul generic de stoc / link-uri produs (intenționat) */
.stockFlag{ display:none !important; }
.product-links{ display:none !important; }

/* butonul principal să fie full-width când e singur */
.tobasket-function .btn{ width:100%; }

/* links stil brand */
.obx-link{ color:var(--obx-orange-700); text-decoration:underline; }
.obx-link:hover{ color:var(--obx-orange-800); }

/* ================================
   HARTA PARCĂRII (scoped)
   ================================ */
#parkMapModal .modal-body{ padding:0; }
#parkMapModal img{ width:100%; height:auto; display:block; }
/* X-ul rămâne clickabil peste overlay intern */
#parkMapModal .btn-close{ position: relative; z-index: 1; }
/* Asigură că harta stă peste; backdrop doar pentru acest modal */
#parkMapModal.modal { z-index: 400000; }
#parkMapModal + .modal-backdrop { z-index: 399990; }

/* (opțional) când există modal deschis, coboară header-ul ca să nu intre peste */
.modal-open header,
.modal-open .header,
.modal-open .site-header,
.modal-open .navbar { z-index: 10 !important; }

/* ================================
   CTA map (buton)
   ================================ */
.obx-cta-map{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.65rem .95rem;border-radius:999px;border:0;cursor:pointer;
  color:#fff;background:linear-gradient(135deg,#ff7a18,#f39121 55%,#ffb703);
  box-shadow:0 6px 18px rgba(243,145,33,.25);
  font-weight:600; transition:transform .12s ease, box-shadow .12s ease;
}
.obx-cta-map:hover{ transform:translateY(-1px); box-shadow:0 10px 28px rgba(243,145,33,.35); }
.obx-cta-map:active{ transform:translateY(0); }
.obx-cta-map__icon{ fill:currentColor; opacity:.95; }
.obx-cta-map__ping{
  position:relative; width:.5rem;height:.5rem; border-radius:50%; background:#fff; opacity:.9;
  box-shadow:0 0 0 0 rgba(255,255,255,.75); margin-left:.1rem;
  animation:obxPing 1.6s cubic-bezier(.2,.6,.4,1) infinite;
}
@keyframes obxPing{
  0%{ box-shadow:0 0 0 0 rgba(255,255,255,.75); }
  100%{ box-shadow:0 0 0 12px rgba(255,255,255,0); }
}

/* ================================
   Grilă „unit tiles”
   ================================ */
.obx-unit-grid{
  display:grid; gap:.6rem;
  grid-template-columns:repeat(auto-fit, minmax(110px, 1fr));
}
.obx-unit{ position:relative; display:block; }
.obx-unit input{ position:absolute; inset:0; opacity:0; pointer-events:none; }
.obx-unit__label{
  display:flex; align-items:center; justify-content:center;
  min-height:44px; border:1.5px solid #e5e7eb; border-radius:12px;
  background:#fff; font-weight:600; letter-spacing:.2px;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .05s ease;
  user-select:none; cursor:pointer;
}
.obx-unit__label:hover{ border-color:#f39121; box-shadow:0 0 0 3px rgba(243,145,33,.12); }
.obx-unit input:checked + .obx-unit__label{
  border-color:#f39121; background:linear-gradient(0deg, rgba(243,145,33,.06), transparent 70%);
  box-shadow:0 0 0 3px rgba(243,145,33,.18);
}
.obx-unit input:disabled + .obx-unit__label{
  color:#9ca3af;background:#f9fafb;text-decoration:line-through;cursor:not-allowed;opacity:.7;
}

/* responsive tweak */
@media (max-width: 420px){
  .obx-unit-grid{ grid-template-columns:repeat(auto-fit, minmax(95px, 1fr)); }
  .obx-unit__label{ min-height:40px; font-weight:600; }
}

/* ================================
   GARANȚIE – blocări în coș / mini-coș
   ================================ */
/* Ascunde orice acțiune de remove în rândurile marcate ca garanție */
.obx-deposit-row a[href*="delete"],
.obx-deposit-row a[href*="remove"],
.obx-deposit-row .remove,
.obx-deposit-row .btn-remove,
.obx-deposit-row [name*="remove"],
.obx-deposit-row [name*="del"],
.obx-deposit-row [data-action="remove"] {
  display: none !important;
}

/* Dezactivează cantitatea / inputurile în rândurile de garanție */
.obx-deposit-row input[type="number"],
.obx-deposit-row input[type="text"],
.obx-deposit-row .amount,
.obx-deposit-row .input-group {
  opacity: .6;
  pointer-events: none;
}

/* Tag mic cu lacăt (dacă e injectat din JS) */
.obx-deposit-tag{
  display:inline-flex; align-items:center; gap:.4rem;
  font-size:.875rem; color:#444;
}
.obx-deposit-tag:before{ content:"🔒"; }


.product-card {
  border: 1px solid #ddd;        /* chenar fix */
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.product-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
}

/* titlul are spațiu clar */
.product-card .card-title {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

/* descrierea nu se mai lipește de titlu */
.product-card .short-desc {
  font-size: 0.9rem;
  color: #555;
  margin-bottom: 1rem;
  min-height: 40px;  /* previne suprapuneri/sărituri */
  line-height: 1.4;
}

/* secțiunea de preț și buton */
.product-card .price {
  margin-top: auto;
  margin-bottom: 0.75rem;
}

.text-orange {
  color: #e67e22;
}

.btn-orange {
  background: #e67e22;
  border: none;
  color: #fff;
  padding: 0.75rem;
  border-radius: 8px;
  font-weight: 600;
  transition: background 0.3s;
}

.btn-orange:hover {
  background: #cf6d18;
}
body {
  font-family: 'Inter', sans-serif;
}
.no-availability {
  display: block;
  width: 100%;
  text-align: center;
  font-size: 15px;
  font-weight: 500;
  margin: 12px 0;
}
.basketQuantity-label {
  font-size: 12px;
  color: #555;
  margin-top: 4px;
}
.basketQuantity-label {
  font-size: 12px;
  color: #444;
  font-weight: 500;
}

.footer-payment-cards img {
    display: inline-block;
    height: auto;
    max-height: 28px;
}
/* === ORANGEBOX NAVBAR CLEAN VERSION === */

/* Containerul general */
#mainnav #navigation {
  display: flex;
  justify-content: space-between; /* distribuie egal între stânga și dreapta */
  align-items: center;
  gap: 36px; /* spațiu între iteme */
  padding: 0 48px; /* echilibru între logo și iconițe */
  position: relative;
  z-index: 20;
  flex-wrap: nowrap;
  overflow: visible;
}

/* Elemente din meniu */
#mainnav #navigation .nav-item {
  flex: 0 0 auto;
  white-space: nowrap;
  margin: 0;
}

#mainnav #navigation .nav-item a {
  font-family: 'Inter', sans-serif !important;
  font-weight: 600;
  font-size: 15px;
  color: #222 !important;
  text-decoration: none;
  padding: 6px 10px;
  position: relative;
  transition: color 0.2s ease;
}

/* Hover efect brand */
#mainnav #navigation .nav-item a:hover {
  color: #ff6600 !important;
}

#mainnav #navigation .nav-item a::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 2px;
  background-color: #ff6600;
  border-radius: 2px;
  transform: translateX(-50%);
  transition: width 0.25s ease;
}

#mainnav #navigation .nav-item a:hover::after {
  width: 70%;
}

/* Dropdown stabil și frumos */
.nav-item.has-subs {
  position: relative;
}

.nav-item.has-subs > .dropdown-menu {
  position: absolute !important;
  top: 100%;
  left: 0;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 6px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  padding: 6px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: all 0.25s ease;
  z-index: 9999;
}

.nav-item.has-subs:hover > .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-item.has-subs .dropdown-menu a {
  display: block;
  padding: 8px 16px;
  color: #333 !important;
  text-decoration: none;
  font-weight: 400;
}

.nav-item.has-subs .dropdown-menu a:hover {
  color: #ff6600 !important;
  background: rgba(255,102,0,0.06);
}

/* === Responsive corect (păstrează layoutul pe tablete mari) === */
@media (max-width: 992px) {
  #mainnav #navigation {
    padding: 0 24px;
    gap: 24px;
  }
  #mainnav #navigation .nav-item a {
    font-size: 14px;
  }
}
/* === Corecție afișare submeniu peste imagine / slider === */
.nav-item.has-subs > .dropdown-menu {
  background: #ffffff !important; /* fundal complet alb */
  backdrop-filter: blur(2px); /* mic efect anti-spărtură, opțional */
  border: 1px solid #eee;
  box-shadow: 0 6px 16px rgba(0,0,0,0.08);
  z-index: 2000; /* peste slider și orice imagine */
  isolation: isolate; /* forțează strat propriu */
}

/* Previne ca imaginile de dedesubt să fie vizibile */
.header,
#mainnav {
  position: relative;
  z-index: 1500;
  background: #fff;
}
/* === ORANGEBOX FIX: submeniul peste slider === */

/* ridicăm bara și submeniurile deasupra oricărui element din homepage */
.header,
#mainnav,
#navigation,
.nav-item.has-subs,
.nav-item.has-subs > .dropdown-menu {
  position: relative !important;
  z-index: 5000 !important;
}

/* fundal complet alb pentru dropdown */
.nav-item.has-subs > .dropdown-menu {
  background: #fff !important;
  border: 1px solid #e5e5e5;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  isolation: isolate;
}

/* înlăturăm orice transparență din containerul de sus (sliderul) */
.slider,
.main-banner,
.hero,
#content,
.section-hero {
  position: relative;
  z-index: 0 !important;
}
/* === ORANGEBOX HARD FIX — dropdown peste orice element === */

/* containerul principal al meniului */
#mainnav {
  position: relative;
  z-index: 9999 !important;
}

/* dropdown-ul */
.nav-item.has-subs > .dropdown-menu {
  position: fixed !important; /* mutăm complet din layout, peste tot */
  top: 90px !important; /* ajustează dacă bara e mai înaltă sau mai mică */
  left: auto !important;
  right: auto !important;
  min-width: 240px;
  background: #ffffff !important;
  border: 1px solid #e5e5e5;
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  z-index: 10000 !important;
}

/* ascundere / afișare cu tranziție lină */
.nav-item.has-subs > .dropdown-menu {
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: all 0.25s ease;
}

.nav-item.has-subs:hover > .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* blocăm sliderul să nu mai interfereze */
.slider,
.main-banner,
.hero,
#content,
.section-hero {
  z-index: 1 !important;
  position: relative !important;
}
/* === FIX FINAL: dropdown curat peste imagine, fără interferențe === */
.header,
.header .navbar,
.header .navbar-collapse,
.header .navbar-nav,
.header .nav-item {
  overflow: visible !important;
  position: relative;
  z-index: 1001;
}

.nav-item.has-subs {
  position: relative;
}

.nav-item.has-subs > .dropdown-menu,
.nav-item.has-subs > .nav-level-2 {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100vw; /* full width pe ecran */
  background: #fff !important;
  border-top: 1px solid #eee;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.1);
  display: none;
  padding: 20px 0;
  z-index: 5000 !important;
}

.nav-item.has-subs:hover > .dropdown-menu,
.nav-item.has-subs:hover > .nav-level-2 {
  display: block;
}

/* facem sliderul și conținutul de sub el să stea mereu mai jos */
.slider,
.main-banner,
.hero,
#content,
.section-hero {
  position: relative !important;
  z-index: 1 !important;
}
/* === ORANGEBOX FINAL FIX + Accent portocaliu subtil === */

/* asigurăm că meniul nu e tăiat și e mereu peste slider */
.header,
.header .navbar,
.header .navbar-collapse,
.header .navbar-nav,
.header .nav-item {
  overflow: visible !important;
  position: relative;
  z-index: 1001;
}

/* elementele cu submeniu */
.nav-item.has-subs {
  position: relative;
}

/* dropdownul principal */
.nav-item.has-subs > .dropdown-menu,
.nav-item.has-subs > .nav-level-2 {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100vw; /* se întinde pe toată lățimea ecranului */
  background: #fff !important;
  border-top: 2px solid #ff6600; /* linie portocalie subtilă */
  box-shadow: 0 8px 24px rgba(255, 102, 0, 0.15); /* umbră portocalie transparentă */
  display: none;
  padding: 20px 0;
  z-index: 5000 !important;
  opacity: 0;
  transform: translateY(-6px);
  transition: all 0.25s ease-in-out;
}

/* la hover, dropdownul devine vizibil și apare lin */
.nav-item.has-subs:hover > .dropdown-menu,
.nav-item.has-subs:hover > .nav-level-2 {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

/* conținutul intern din dropdown */
.nav-item.has-subs > .dropdown-menu .nav-link,
.nav-item.has-subs > .nav-level-2 .nav-link {
  color: #333 !important;
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 400;
  padding: 6px 18px;
  text-decoration: none;
  transition: all 0.2s ease;
}

/* hover pe linkuri din submeniu */
.nav-item.has-subs > .dropdown-menu .nav-link:hover,
.nav-item.has-subs > .nav-level-2 .nav-link:hover {
  background: rgba(255, 102, 0, 0.06);
  color: #ff6600 !important;
  border-radius: 4px;
}

/* sliderul și conținutul de dedesubt sunt "coborâte" vizual */
.slider,
.main-banner,
.hero,
#content,
.section-hero {
  position: relative !important;
  z-index: 1 !important;
}
/* === ORANGEBOX REFINED TOP BANNER === */

/* containerul general de sub meniu */
.section-hero,
.main-banner,
.slider {
  background: linear-gradient(180deg, #fff 0%, #fffaf6 100%) !important;
  box-shadow: 0 2px 12px rgba(255, 102, 0, 0.05); /* umbră portocalie difuză */
  border: none !important;
  position: relative;
  z-index: 1;
  transition: all 0.3s ease-in-out;
}

/* imaginea din banner — ușor mai moale și mai aerisită */
.section-hero img,
.main-banner img,
.slider img {
  border-radius: 8px;
  object-fit: cover;
  opacity: 0.95;
  transition: opacity 0.3s ease;
}

.section-hero img:hover,
.main-banner img:hover,
.slider img:hover {
  opacity: 1;
}

/* textul principal (h1, h2) – rafinat */
.section-hero h1,
.section-hero h2,
.main-banner h1,
.main-banner h2 {
  font-family: 'Inter', sans-serif !important;
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: -0.4px;
  color: #222;
  margin-bottom: 0.5rem;
}

/* subtitlu / descriere */
.section-hero p,
.main-banner p {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #444;
  margin-top: 0;
  opacity: 0.9;
}

/* opțional: o linie portocalie foarte subțire sub text */
.section-hero::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 2px;
  background-color: rgba(255, 102, 0, 0.3);
  border-radius: 2px;
}
/* === ORANGEBOX HERO REFINED FIX – aplicat pe homepage === */

/* fundalul gri al bannerului mare de pe homepage */
.cms-homepage .hero,
.cms-homepage .banner,
.cms-homepage .cms-element-slider,
.cms-homepage .main-banner,
.cms-homepage .content-main {
  background: linear-gradient(180deg, #ffffff 0%, #fffaf6 100%) !important;
  box-shadow: 0 2px 10px rgba(255, 102, 0, 0.06);
  border: none !important;
  padding: 40px 0 20px 0 !important;
  transition: all 0.3s ease;
}

/* textul principal din banner */
.cms-homepage h1,
.cms-homepage .cms-element-slider h1,
.cms-homepage .hero h1 {
  font-family: 'Oswald', sans-serif;
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: -0.4px;
  color: #222 !important;
  margin-bottom: 0.5rem;
  text-align: center;
}

/* subtitlul */
.cms-homepage p,
.cms-homepage .hero p {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  font-weight: 400;
  color: #444;
  text-align: center;
  margin-bottom: 0;
}

/* linie portocalie elegantă sub text */
.cms-homepage h1::after {
  content: "";
  display: block;
  margin: 12px auto 0;
  width: 80px;
  height: 2px;
  background: rgba(255, 102, 0, 0.4);
  border-radius: 2px;
}

/* imaginea din slider — ușor blur și fade */
.cms-homepage img,
.cms-homepage .cms-element-slider img {
  opacity: 0.9;
  filter: brightness(0.98) contrast(1.02);
  transition: opacity 0.3s ease, filter 0.3s ease;
}

.cms-homepage img:hover,
.cms-homepage .cms-element-slider img:hover {
  opacity: 1;
  filter: brightness(1) contrast(1.05);
}
/* === ORANGEBOX: compensare banner sub meniu fix === */
body .cms-homepage,
body .cms-page,
body #content,
body main {
  padding-top: 60px !important; /* ajustează între 100–140px în funcție de înălțimea meniului */
}
/* === ORANGEBOX: Eliminare coloana Specificații din pagina de produs === */
.details-info .article-specs,
.product-specs,
.specifications,
#specifications,
.details-info-right,
.details-box .specifications,
#productMain .specifications,
#details-related-specs {
  display: none !important;
}

/* === Extinde zona de Descriere pe toată lățimea === */
.details-info-left {
  width: 100% !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

/* === Ajustare padding și echilibru vizual === */
.details-info-left .description {
  padding-right: 0 !important;
}
@media (max-width: 991.98px) {
  .navbar-collapse {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh; /* să ocupe întreaga înălțime */
    background-color: #fff; /* fundal alb (poți schimba culoarea) */
    overflow-y: auto;
    z-index: 1050; /* peste restul elementelor */
    padding: 1.5rem;
  }

  /* ca body-ul să nu se miște în fundal când e deschis meniul */
  body.nav-open {
    overflow: hidden;
  }
}
/* === OBX: culoare portocalie pentru bulina cosului === */
.minibasket-btn .counter,
.minibasket-btn .badge,
.header .counter,
.header .badge,
.navbar .counter,
.navbar .badge {
    background-color: #ff6600 !important;   /* portocaliu OrangeBox */
    color: #fff !important;
    font-weight: 600;
    border: 1px solid #e95c00 !important;
}

/* efect mic la hover pe iconita cosului */
.minibasket-btn:hover .counter,
.navbar .minibasket-btn:hover .badge {
    background-color: #e95c00 !important;   /* portocaliu mai inchis */
    transform: scale(1.05);
    transition: all 0.2s ease-in-out;
}


/* === OBX: Stil buton "Adauga o alta boxa sau rafturi" === */
.btn-orangebox-add {
    background-color: #ff6600 !important;     /* portocaliu standard OrangeBox */
    color: #fff !important;
    font-weight: 600;
    border: 1px solid #e95c00 !important;
    transition: all 0.25s ease-in-out;
}

.btn-orangebox-add:hover {
    background-color: #e95c00 !important;     /* portocaliu mai inchis la hover */
    color: #fff !important;
    transform: scale(1.02);
    box-shadow: 0 0 10px rgba(233, 92, 0, 0.4);
}
/* === OBX: Stil buton portocaliu + responsive pentru mobile === */
.btn-orangebox-add {
    background-color: #ff6600 !important;     /* portocaliu standard OrangeBox */
    color: #fff !important;
    font-weight: 600;
    border: 1px solid #e95c00 !important;
    transition: all 0.25s ease-in-out;
    text-align: center;
}

.btn-orangebox-add:hover {
    background-color: #e95c00 !important;     /* portocaliu mai inchis la hover */
    color: #fff !important;
    transform: scale(1.02);
    box-shadow: 0 0 10px rgba(233, 92, 0, 0.4);
}

/* === Variante pentru ecrane mici === */
@media (max-width: 480px) {
    .btn-orangebox-add {
        font-size: 14px !important;
        padding: 10px 8px !important;
        gap: 6px;
        border-radius: 8px;
    }
    .btn-orangebox-add svg {
        width: 18px;
        height: 18px;
    }
}




/* === OBX FIX: pop-up utilizator vizibil peste bara de meniu === */
.menu-dropdowns .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
    right: 0;
    left: auto;
    z-index: 9999 !important;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 6px;
    box-shadow: 0 8px 18px rgba(0,0,0,0.1);
    overflow: visible !important;
}

/* bara principală să nu taie meniul */
.header, .navbar, .site-header, #mainnav {
    overflow: visible !important;
    z-index: 1000 !important;
}
<style>
/* ===== Align reviews section with content ===== */
#reviews,
#review,
.product-reviews {
  max-width: 1000px;
  margin: 2rem auto;
  padding: 0 1rem;
}

/* === ORANGEBOX - User Account Page === */
.account-dashboard {
  max-width: 900px;
  margin: 0 auto;
}

.account-dashboard h1 {
  background: #f7f7f7;
  padding: 25px 10px;
  border-radius: 10px;
  color: #fd7e14;
  font-weight: 700;
  text-align: center;
  margin-bottom: 30px;
}

.account-dashboard p {
  font-size: 15px;
  line-height: 1.6;
}

.account-dashboard .card {
  border: 1px solid #e3e3e3;
  border-radius: 10px;
  background: #fff;
  margin-bottom: 25px;
  padding: 22px 26px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  transition: transform 0.2s ease;
}

.account-dashboard .card:hover {
  transform: translateY(-2px);
}

.account-dashboard h4 {
  font-weight: 600;
  margin-bottom: 10px;
  color: #333;
}

.account-dashboard svg {
  margin-right: 8px;
  vertical-align: middle;
}

.account-dashboard .btn {
  display: inline-block;
  background: #fd7e14;
  color: #fff;
  border-radius: 6px;
  font-weight: 500;
  text-transform: none;
  padding: 6px 16px;
  border: none;
}

.account-dashboard .btn:hover {
  opacity: 0.9;
  color: #fff;
}

.account-dashboard .btn-outline-secondary {
  border: 1px solid #ccc;
  background: #fff;
  color: #333;
}

.account-dashboard .btn-outline-secondary:hover {
  background: #f7f7f7;
}
.btn-primary {
  background-color: #fd7e14; /* portocaliul OBX */
  border-color: #fd7e14;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: #ff8c1a !important;
  border-color: #ff8c1a !important;
}
.btn-outline-primary {
  color: #ff8c1a !important; /* culoarea brandului OrangeBox */
  border-color: #ff8c1a !important;
}
.btn-outline-primary:hover {
  background-color: #ff8c1a !important;
  color: #fff !important;
}
.dd-shortcode-text-image-row .card-title.h2 {
  color: #111 !important;  /* negru intens */
}

.dd-shortcode-text-image-row .card-text {
  color: #333 !important;  /* gri foarte închis, lizibil */
}
div.container div.cat-list {
  display: none !important;
}
/* ===========================================================
   ORANGEBOX – stil butoane checkout (forțare totală)
   =========================================================== */

/* Toate butoanele principale */
body .btn-primary,
body button.btn-primary,
body input.btn-primary,
body a.btn-primary,
body .nextStep,
body button.nextStep,
body input.nextStep,
body a.nextStep,
body input[type="submit"].btn-primary,
body button[type="submit"],
body input[type="submit"],
body button.submitButton,
body input[name="nextStep"],
body input[name="order"],
body input[name="userform"],
body button[name="userform"],
body button[name="order"],
body button[name="nextStep"],
body button[name="payment"],
body input[name="payment"] {
    background-color: #f37021 !important;   /* Orange principal */
    border-color: #f37021 !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.15) !important;
    transition: all 0.25s ease-in-out !important;
}

/* Hover / focus */
body .btn-primary:hover,
body button.btn-primary:hover,
body input.btn-primary:hover,
body .nextStep:hover,
body button.nextStep:hover,
body input.nextStep:hover,
body a.nextStep:hover,
body input[type="submit"]:hover,
body button[type="submit"]:hover,
body button.submitButton:hover,
body button[name="nextStep"]:hover,
body button[name="order"]:hover,
body button[name="userform"]:hover {
    background-color: #d85e10 !important;   /* Orange mai închis */
    border-color: #d85e10 !important;
    color: #fff !important;
}

/* Buton Înapoi */
body .backStep,
body button.backStep,
body a.backStep,
body input.backStep {
    background-color: transparent !important;
    border: 2px solid #f37021 !important;
    color: #f37021 !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    transition: all 0.25s ease-in-out !important;
}

body .backStep:hover,
body button.backStep:hover,
body a.backStep:hover,
body input.backStep:hover {
    background-color: #f37021 !important;
    color: #ffffff !important;
}

/* Buton edit (creion) */
body .editButton,
body button.editButton,
body a.editButton {
    background-color: #f37021 !important;
    border: none !important;
    color: #ffffff !important;
}

body .editButton:hover,
body button.editButton:hover,
body a.editButton:hover {
    background-color: #d85e10 !important;
}

/* Asigură-te că nu rămâne verde */
body .btn-primary,
body .nextStep {
    background-image: none !important;
}
/* === ORANGEBOX - forțare culori butoane "highlight" === */

/* Buton Urmator, Trimite comanda etc. */
body .btn-highlight,
body button.btn-highlight,
body input.btn-highlight,
body a.btn-highlight {
    background-color: #f37021 !important;   /* Orange principal */
    border-color: #f37021 !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    letter-spacing: 0.5px;
    transition: all 0.25s ease-in-out !important;
}

/* Hover */
body .btn-highlight:hover,
body button.btn-highlight:hover,
body input.btn-highlight:hover,
body a.btn-highlight:hover {
    background-color: #d85e10 !important;   /* Orange mai închis */
    border-color: #d85e10 !important;
    color: #ffffff !important;
}

/* În caz că are shadow setat de Apex */
body .btn-highlight:focus {
    box-shadow: none !important;
}
/* ===========================================================
   ORANGEBOX UI – consistent checkout and form styling
   =========================================================== */

/* === 1. BUTTONS === */
body .btn-primary,
body .btn-highlight,
body button.btn-primary,
body button.btn-highlight,
body input.btn-primary,
body input.btn-highlight,
body a.btn-primary,
body a.btn-highlight {
    background-color: #f37021 !important;
    border-color: #f37021 !important;
    color: #fff !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    transition: all 0.25s ease-in-out !important;
}

body .btn-primary:hover,
body .btn-highlight:hover,
body button.btn-primary:hover,
body button.btn-highlight:hover {
    background-color: #d85e10 !important;
    border-color: #d85e10 !important;
}

body .btn-primary:active,
body .btn-highlight:active {
    transform: scale(0.98);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

/* === 2. BACK BUTTON === */
body .backStep,
body button.backStep,
body a.backStep,
body input.backStep {
    background-color: transparent !important;
    border: 2px solid #f37021 !important;
    color: #f37021 !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    border-radius: 4px !important;
    transition: all 0.25s ease-in-out;
}

body .backStep:hover {
    background-color: #f37021 !important;
    color: #fff !important;
}

/* === 3. FORM INPUTS === */
body input[type="text"],
body input[type="email"],
body input[type="password"],
body input[type="tel"],
body input[type="number"],
body select,
body textarea {
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 8px 10px;
    font-size: 14px;
    transition: border-color 0.25s ease;
}

body input:focus,
body select:focus,
body textarea:focus {
    border-color: #f37021 !important;
    box-shadow: 0 0 0 2px rgba(243, 112, 33, 0.2);
    outline: none;
}

/* === 4. CHECKBOXES & RADIOS === */
body input[type="checkbox"],
body input[type="radio"] {
    accent-color: #f37021 !important; /* pentru browsere moderne */
}

/* === 5. ALERTS / MESSAGES === */
.alert-success {
    background-color: rgba(243, 112, 33, 0.1);
    border-left: 4px solid #f37021;
    color: #333;
}

.alert-danger,
.alert-error {
    background-color: #fff2f0;
    border-left: 4px solid #cc0000;
    color: #cc0000;
}

/* === 6. LINKS === */
a {
    color: #f37021;
    text-decoration: none;
    transition: color 0.2s ease;
}

a:hover {
    color: #d85e10;
    text-decoration: underline;
}

/* === 7. MISC === */
button:disabled,
input:disabled,
.btn:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}
/* ===========================================================
   ORANGEBOX – Dark Footer Styling
   =========================================================== */

footer,
.footer,
.site-footer {
    background-color: #2d2d2d !important;
    color: #ffffff !important;
    padding-top: 40px;
    padding-bottom: 40px;
}

/* Titluri coloane footer */
footer h4,
.footer h4,
.site-footer h4 {
    color: #f37021 !important;
    font-weight: 600;
    margin-bottom: 15px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Linkuri footer */
footer a,
.footer a,
.site-footer a {
    color: #ffffff !important;
    opacity: 0.9;
    text-decoration: none;
    transition: all 0.2s ease;
}

footer a:hover,
.footer a:hover,
.site-footer a:hover {
    color: #f37021 !important;
    opacity: 1;
    text-decoration: underline;
}

/* Buton newsletter */
footer .btn,
.footer .btn,
.site-footer .btn,
footer input[type="submit"],
.footer input[type="submit"] {
    background-color: #f37021 !important;
    border: 1px solid #f37021 !important;
    color: #fff !important;
    font-weight: 600;
    text-transform: uppercase;
    transition: all 0.3s ease;
    border-radius: 4px;
}

footer .btn:hover,
.footer .btn:hover,
.site-footer .btn:hover {
    background-color: #d85e10 !important;
    border-color: #d85e10 !important;
}

/* Input email newsletter */
footer input[type="email"],
.footer input[type="email"],
.site-footer input[type="email"] {
    background-color: #444 !important;
    border: 1px solid #666 !important;
    color: #fff !important;
    border-radius: 4px;
    padding: 8px 10px;
}

footer input[type="email"]:focus {
    border-color: #f37021 !important;
    box-shadow: 0 0 0 2px rgba(243,112,33,0.2);
}

/* Icone social media */
footer .social-icons a,
.footer .social-icons a,
.site-footer .social-icons a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    background-color: #f37021;
    border-radius: 50%;
    color: #fff;
    margin-right: 6px;
    transition: all 0.3s ease;
}

footer .social-icons a:hover {
    background-color: #d85e10;
    transform: scale(1.1);
}
/* Corectare vizibilitate mesaje de eroare */
.alert,
.messagebox,
.status.error,
.status.errorbox,
.status.error-message,
.status.errorMsg {
    background-color: #ffe6e6 !important;  /* roz pal / fundal de eroare */
    color: #b30000 !important;             /* text roșu închis */
    border: 1px solid #ff4d4d !important;  /* contur roșu */
    padding: 12px 15px;
    border-radius: 6px;
    font-weight: 600;
}
/* Mesaje de succes */
.status.success,
.status.message,
.status.ok {
    background-color: #e8f8e8 !important;
    color: #1a7f1a !important;
    border: 1px solid #60c060 !important;
    padding: 12px 15px;
    border-radius: 6px;
    font-weight: 600;
}
