/* =====================================================
   BASE.CSS — Tema ACASĂ LA BUNICI
   Variabile CSS, tipografie, componente comune
   Fără @media queries — acoperite în fișierele bp-*.css
   ===================================================== */

/* =====================================================
   VARIABILE GLOBALE
   ===================================================== */
:root {
  /* Culori principale */
  --color-primary:        #B20009;
  --color-primary-light:  #D4000B;
  --color-primary-dark:   #8A0007;
  --color-secondary:      #5A8A6E;
  --color-secondary-light:#7AAE8E;
  --color-accent:         #E67E22;
  --color-accent-dark:    #D35400;

  /* Culori neutre */
  --color-light:          #F4F6F7;
  --color-light-2:        #EBF5FB;
  --color-dark:           #2C2224;
  --color-text:           #4A5568;
  --color-text-light:     #718096;
  --color-white:          #FFFFFF;
  --color-border:         #E2E8F0;

  /* Tipografie */
  --font-heading: 'Playfair Display', serif;
  --font-body:    'Open Sans', sans-serif;

  /* Dimensiuni fonturi */
  --font-size-base: 17px;
  --font-size-sm:   15px;
  --font-size-lg:   19px;
  --line-height-base: 1.7;

  /* Spațiere secțiuni */
  --section-padding:    80px 0;
  --section-padding-sm: 50px 0;

  /* Border radius */
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-full: 50px;

  /* Umbre */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.12);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.18);

  /* Tranziții */
  --transition-base: all 0.3s ease;

  /* Header */
  --header-height: 68px;
}

/* =====================================================
   OVERRIDE BOOTSTRAP — sincronizare cu tema noastră
   ===================================================== */
:root {
  --bs-primary:         #B20009;
  --bs-primary-rgb:     178, 0, 9;
  --bs-link-color:      #B20009;
  --bs-link-hover-color:#8A0007;
  --bs-link-color-rgb:  178, 0, 9;
}
.text-primary        { color: var(--color-primary)       !important; }
.text-secondary      { color: var(--color-secondary)     !important; }
.bg-primary          { background-color: var(--color-primary) !important; }
.btn-primary         { background-color: var(--color-primary); border-color: var(--color-primary); }
.btn-primary:hover   { background-color: var(--color-primary-dark); border-color: var(--color-primary-dark); }

/* =====================================================
   RESET & BASE
   ===================================================== */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-white);
  overflow-x: hidden;
}

/* Offset body pentru header fix — toate paginile */
body {
  padding-top: var(--header-height);
}

/* =====================================================
   TIPOGRAFIE
   ===================================================== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--color-dark);
  line-height: 1.3;
  margin-bottom: 1rem;
}
h1 { font-size: 2.8rem; letter-spacing: -0.02em; line-height: 1.2; }
h2 { font-size: 2.2rem; }
h3 { font-size: 1.7rem; }
h4 { font-size: 1.4rem; }
h5 { font-size: 1.15rem; }
h6 { font-size: 1rem; }

p {
  margin-bottom: 1.2rem;
  color: var(--color-text);
}

a {
  color: var(--color-primary-light);
  text-decoration: none;
  transition: var(--transition-base);
}
a:hover { color: var(--color-primary); }

img { max-width: 100%; height: auto; }

ul, ol { padding-left: 1.5rem; }

strong { color: var(--color-dark); }

/* =====================================================
   BUTOANE
   ===================================================== */
.btn-calb {
  font-family: var(--font-heading);
  font-weight: 700;
  border-radius: var(--radius-full);
  padding: 13px 34px;
  transition: var(--transition-base);
  font-size: 1rem;
  border: 2px solid transparent;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  text-decoration: none;
}

.btn-calb-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}
.btn-calb-primary:hover {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn-calb-accent {
  background-color: var(--color-accent);
  color: var(--color-white);
  border-color: var(--color-accent);
}
.btn-calb-accent:hover {
  background-color: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn-calb-outline-white {
  background-color: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,0.7);
}
.btn-calb-outline-white:hover {
  background-color: var(--color-white);
  color: var(--color-primary);
  transform: translateY(-2px);
}

.btn-calb-outline-primary {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-calb-outline-primary:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: translateY(-2px);
}

.btn-calb-lg {
  padding: 16px 42px;
  font-size: 1.1rem;
}

/* =====================================================
   HEADER / NAVIGAȚIE
   ===================================================== */
#main-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: var(--color-white);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  transition: box-shadow 0.35s ease;
  padding: 0;
  overflow: visible; /* permite logo să depășească bara în jos */
}

#main-header.scrolled {
  --header-height: 52px; /* ← suprascrie variabila local → toți copiii se micșorează */
  box-shadow: var(--shadow-md);
}

/* ── Elemente header la scroll: text și iconițe mai mici ── */
#main-header.scrolled .main-nav > li > a {
  font-size: 0.88rem;
  padding: 5px 10px;
}
#main-header.scrolled .header-cta-btn {
  width: 40px;
  height: 40px;
  font-size: 1rem;
}
#main-header.scrolled .header-social-link {
  width: 28px;
  height: 28px;
  font-size: 0.75rem;
}

.header-inner {
  height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  overflow: visible;
  transition: height 0.35s ease;
}

/* Logo */
.site-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  flex-shrink: 0;
  overflow: visible;
}

/* Grid stacking: logo + stemă ocupă aceeași celulă → cross-fade curat */
.logo-imgs {
  display: grid;
  overflow: visible;
}
/* Ambele imagini suprapuse; justify-self: start previne stretch-ul în grid cell
   → lățimea imaginii = proporțional cu înălțimea (aspect ratio natural) */
.logo-imgs img {
  grid-area: 1 / 1;
  justify-self: start;   /* nu întinde imaginea să umple celula */
  width: auto;
  height: auto;
  max-height: var(--header-height); /* proporție naturală, limitată la înălțimea header-ului */
  transform-origin: left center;
  transition: opacity 0.35s ease, filter 0.4s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), max-height 0.35s ease, max-width 0.4s ease;
}

/* Stemă: dimensiune proprie — mai compactă decât logo-ul principal */
.logo-stema {
  max-height: calc(var(--header-height) - 20px); /* ~48px — proporție pentru emblemă */
}

/* ── LA TOP: logo principal coboară puțin sub bara de meniu ── */
#main-header:not(.scrolled) .logo-main {
  filter: drop-shadow(0 8px 20px rgba(0,0,0,0.22));
  opacity: 1;
  max-height: calc(var(--header-height) - 8px); /* puțin mai mic decât bara */
  transform: translateY(20px);                   /* iese în jos din meniu */
  max-width: 300px;                              /* valoare generoasă — permite tranziție animată spre 0 */
}
#main-header:not(.scrolled) .logo-stema {
  opacity: 0;
  pointer-events: none;
  transform: scale(0.72) translateY(-6px); /* mică și ușor sus — gata să „aterizeze" */
}

/* ── LA SCROLL: stemă vizibilă, logo principal se retrage în bara ── */
#main-header.scrolled .logo-main {
  opacity: 0;
  pointer-events: none;
  transform: translateY(0);           /* revine în bara la scroll */
  max-height: var(--header-height);
  max-width: 0;                       /* se comprimă → grid cell se îngustează → meniul vine stânga */
  overflow: hidden;
}
#main-header.scrolled .logo-stema {
  filter: drop-shadow(0 3px 10px rgba(0,0,0,0.20));
  opacity: 1;
  transform: scale(1) translateY(0); /* aterizează în poziția finală */
}
.logo-text-wrap {
  display: flex;
  flex-direction: column;
}
.logo-text-main {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--color-primary);
  line-height: 1.2;
}
.logo-text-sub {
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--color-text-light);
  font-weight: 400;
}

/* Navigație desktop */
.main-nav {
  display: flex;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 2px;
}
.main-nav > li > a {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--color-dark);
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  transition: var(--transition-base);
  white-space: nowrap;
  display: block;
}
.main-nav > li > a:hover,
.main-nav > li.active > a {
  color: var(--color-primary);
  background-color: var(--color-light);
}

/* ── Dropdown meniu desktop ──────────────────────────────── */
.has-dropdown { position: relative; }

.nav-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: var(--color-white);
  min-width: 230px;
  border-radius: var(--radius-md);
  box-shadow: 0 8px 32px rgba(0,0,0,0.14);
  border-top: 3px solid var(--color-primary);
  list-style: none;
  padding: 8px 0;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
  z-index: 1050;
}
.has-dropdown:hover .nav-dropdown,
.has-dropdown:focus-within .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  color: var(--color-dark);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 500;
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease, padding-left 0.15s ease;
  white-space: nowrap;
}
.nav-dropdown li a:hover {
  background: var(--color-light);
  color: var(--color-primary);
  padding-left: 24px;
}
.nav-dropdown li a i { width: 16px; text-align: center; color: var(--color-primary-light); }

.dropdown-arrow {
  font-size: 0.7rem;
  margin-left: 4px;
  transition: transform 0.2s ease;
  vertical-align: middle;
}
.has-dropdown:hover .dropdown-arrow { transform: rotate(180deg); }

/* ── Dropdown offcanvas mobil ────────────────────────────── */
.offcanvas-submenu-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  /* Identic cu .offcanvas-nav-list li a */
  padding: 15px 20px;
  cursor: pointer;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  text-align: left;
  transition: var(--transition-base);
}
.offcanvas-submenu-toggle:hover,
.offcanvas-submenu-toggle[aria-expanded="true"] {
  color: var(--color-primary);
  background-color: var(--color-light);
  padding-left: 26px;
}
.submenu-arrow {
  transition: transform 0.25s ease;
  flex-shrink: 0;
}
.offcanvas-submenu-toggle[aria-expanded="true"] .submenu-arrow {
  transform: rotate(180deg);
}
.offcanvas-submenu {
  list-style: none;
  padding: 4px 0 4px 16px;
  margin: 0;
  border-left: 2px solid var(--color-primary-light);
  margin-left: 12px;
  margin-bottom: 4px;
}
.offcanvas-submenu li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  color: var(--color-text);
  font-size: 0.9rem;
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: background 0.15s ease, color 0.15s ease;
}
.offcanvas-submenu li a:hover {
  background: rgba(46,134,193,0.08);
  color: var(--color-primary);
}
.offcanvas-submenu li a i { width: 14px; text-align: center; }

/* Buton telefon / contact în header */
.header-cta-btn {
  width: 50px;
  height: 50px;
  padding: 0;
  border-radius: 50%;
  background-color: #25A244;
  color: var(--color-white) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  transition: var(--transition-base);
  flex-shrink: 0;
  text-decoration: none;
  box-shadow: 0 3px 12px rgba(37,162,68,0.40);
}
.header-cta-btn:hover {
  background-color: #1E8A39;
  color: var(--color-white) !important;
  transform: translateY(-2px);
  box-shadow: 0 5px 18px rgba(37,162,68,0.55);
}

/* Iconițe social media în header (desktop only — ascuns pe mobil via d-none d-lg-flex) */
.header-social {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.header-social-link {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1.5px solid rgba(178,0,9,0.30);
  background-color: rgba(178,0,9,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  font-size: 0.85rem;
  text-decoration: none;
  transition: var(--transition-base);
  flex-shrink: 0;
}
.header-social-link:hover {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* Buton hamburger mobil */
.hamburger-btn {
  display: none;
  background: none;
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-sm);
  padding: 8px 11px;
  cursor: pointer;
  color: var(--color-primary);
  font-size: 1.2rem;
  line-height: 1;
  transition: var(--transition-base);
}
.hamburger-btn:hover {
  background-color: var(--color-light);
}

/* =====================================================
   HERO / SLIDER — Bootstrap 5 Carousel full-height
   ===================================================== */

/* ── Container carousel ── */
.hero-carousel { position: relative; overflow: hidden; }

/* ── Fiecare slide = fostul .hero-section ── */
.hero-slide {
  position: relative;
  min-height: calc(100vh - var(--header-height));
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}

/* Necesar pentru Bootstrap carousel: slide-urile active/în tranziție să fie flex */
.hero-carousel .carousel-item.active,
.hero-carousel .carousel-item-next,
.hero-carousel .carousel-item-prev {
  display: flex;
  align-items: center;
}

/* ── Fundaluri per slide (imaginea pe ::before, overlay separat) ── */

/* Stratul de imagine — ::before pe fiecare slide, sub overlay */
.hero-slide::before {
  content: '';
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  will-change: transform;
}

/* Overlay-ul — element .hero-overlay existent în HTML, peste imagine, sub conținut */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

/* Slide 1 — text stânga + panel dreapta: gradient LATERAL (dreapta mai luminoasă) */
.hero-slide-1::before {
  background-image: url("../../images/slider/slide-1-ingrijire.jpg");
}
.hero-slide-1 .hero-overlay {
  background: linear-gradient(90deg,
    rgba(0,0,0,0.72) 0%,
    rgba(0,0,0,0.55) 40%,
    rgba(0,0,0,0.25) 75%,
    rgba(0,0,0,0.10) 100%);
}

/* Slide 2 — text centrat: VIGNETTE radial + subiect mutat în dreapta */
.hero-slide-2::before {
  background-image: url("../../images/slider/slide-2-medical.jpg");
  background-position: 75% center;
}
.hero-slide-2 .hero-overlay {
  background: radial-gradient(ellipse at center,
    rgba(0,0,0,0.60) 0%,
    rgba(0,0,0,0.40) 55%,
    rgba(0,0,0,0.25) 100%);
}

/* Slide 3 — text centrat: VIGNETTE radial */
.hero-slide-3::before {
  background-image: url("../../images/slider/slide-3-social.jpg");
}
.hero-slide-3 .hero-overlay {
  background: radial-gradient(ellipse at center,
    rgba(0,0,0,0.55) 0%,
    rgba(0,0,0,0.35) 55%,
    rgba(0,0,0,0.20) 100%);
}

/* ── Ken Burns: zoom lent DOAR pe imagine (::before), nu și pe overlay ── */
@keyframes heroKenBurns {
  from { transform: scale(1);    }
  to   { transform: scale(1.08); }
}
.hero-carousel .carousel-item.active.hero-slide::before {
  animation: heroKenBurns 12s ease-out forwards;
}
@media (prefers-reduced-motion: reduce) {
  .hero-carousel .carousel-item.active.hero-slide::before {
    animation: none;
  }
}

/* ── Layout container conținut + panel ── */
.hero-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  width: 100%;
}
.hero-container-centered {
  justify-content: center;
}

/* ── Controale prev/next ── */
.hero-ctrl {
  width: 44px;
  opacity: 1;
}
.carousel-control-prev.hero-ctrl { left: 10px; }
.carousel-control-next.hero-ctrl { right: 10px; }
.hero-ctrl-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,0.12);
  border: 1.5px solid rgba(255,255,255,0.35);
  border-radius: 50%;
  backdrop-filter: blur(6px);
  transition: background 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
  font-size: 0.7rem;
  color: var(--color-white);
}
.hero-ctrl:hover .hero-ctrl-icon {
  background: rgba(255,255,255,0.25);
  border-color: rgba(255,255,255,0.65);
  transform: scale(1.1);
}

/* ── Indicatori puncte ── */
.hero-indicators {
  bottom: 56px;
  gap: 0;
  z-index: 10;
}
.hero-indicators [data-bs-target] {
  /* Vizual: punct mic 7×7 px */
  width: 7px;
  height: 7px;
  border-radius: 50px;
  background: rgba(255,255,255,0.40);
  background-clip: padding-box;
  opacity: 1;
  flex-shrink: 0;
  cursor: pointer;
  transition: width 0.35s ease, background 0.3s ease;
  /* Zona de click transparentă */
  box-sizing: content-box;
  border: 10px solid transparent;
  margin: 0 3px;
  padding: 0;
}
.hero-indicators [data-bs-target].active {
  width: 26px;         /* pill elongat când activ */
  background: var(--color-white);
  background-clip: padding-box;
}

/* ── Iconițe beneficii pe slides 2 și 3 ── */
.hero-feature-icons {
  display: flex;
  gap: 32px;
  margin-top: 40px;
  flex-wrap: wrap;
}
.hfi {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  color: rgba(255,255,255,0.88);
}
.hfi i {
  font-size: 2rem;
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.12);
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,0.2);
}
.hfi span {
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.3px;
}

/* ── Conținut centrat (slides 2 & 3) ── */
.hero-content-centered {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}
.hero-content-centered .hero-badge { margin: 0 auto 22px; }
.hero-content-centered .hero-subtitle { max-width: 640px; margin: 0 auto 28px; }
.hero-content-centered .hero-buttons { justify-content: center; }
.hero-content-centered .hero-feature-icons { justify-content: center; }

/* ── .hero-section (alias backward compat) ── */
.hero-section {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 55%, var(--color-primary-light) 100%);
  overflow: hidden;
}

/* Decorații de fundal */
.hero-decor {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.hero-decor::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -5%;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(39,174,96,0.12) 0%, transparent 70%);
}
.hero-decor::after {
  content: '';
  position: absolute;
  bottom: -15%;
  left: -5%;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(230,126,34,0.1) 0%, transparent 70%);
}

/* Imagine hero de fundal (opțional) */
.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(21,67,96,0.90) 0%,
    rgba(27,79,114,0.78) 50%,
    rgba(27,79,114,0.45) 100%
  );
}

.hero-content {
  position: relative;
  z-index: 2;
  flex: 1;                /* ocupă spațiul disponibil în flex row */
  padding: 60px 0 60px;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: rgba(255,255,255,0.15);
  color: var(--color-white);
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: var(--radius-full);
  padding: 7px 18px;
  font-size: 0.88rem;
  font-family: var(--font-heading);
  font-weight: 600;
  letter-spacing: 0.5px;
  margin-bottom: 22px;
}

.hero-title {
  font-size: 3.4rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.15;
  margin-bottom: 22px;
}
.hero-title .hl { color: #7DCEA0; }

.hero-subtitle {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.85);
  line-height: 1.8;
  margin-bottom: 38px;
  max-width: 560px;
}

.hero-buttons {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
  margin-bottom: 55px;
}

/* Mini-statistici sub butoane */
.hero-mini-stats {
  display: flex;
  gap: 35px;
  flex-wrap: wrap;
}
.hero-mini-stat {
  text-align: center;
}
.hero-mini-stat .mstat-num {
  display: block;
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
}
.hero-mini-stat .mstat-num em { color: #7DCEA0; font-style: normal; }
.hero-mini-stat .mstat-lbl {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.72);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Panel dreapta hero */
.hero-panel {
  position: relative;
  z-index: 2;
  flex: 0 0 430px;        /* lățime fixă — nu crește/scade */
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.hero-panel-card {
  background-color: rgba(255,255,255,0.10);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: var(--radius-lg);
  padding: 35px 30px;
  color: var(--color-white);
  max-width: 430px;
  width: 100%;
}
.hero-panel-card h3 {
  color: var(--color-white);
  font-size: 1.4rem;
  margin-bottom: 20px;
}
.hero-feature-list {
  list-style: none;
  padding: 0;
  margin: 0 0 25px;
}
.hero-feature-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  font-size: 0.95rem;
  color: rgba(255,255,255,0.88);
}
.hero-feature-list li:last-child { border-bottom: none; }
.hero-feature-list li i {
  color: #7DCEA0;
  font-size: 1.05rem;
  width: 20px;
  flex-shrink: 0;
}

/* =====================================================
   SECȚIUNI COMUNE
   ===================================================== */
.section-calb {
  padding: var(--section-padding);
}
.section-calb-sm {
  padding: var(--section-padding-sm);
}
.section-light { background-color: var(--color-light); }
.section-primary-bg {
  background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
}
.section-dark-bg { background-color: var(--color-dark); }

/* Titlu secțiune */
.section-header {
  margin-bottom: 50px;
}
.section-label {
  display: inline-block;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--color-secondary);
  margin-bottom: 12px;
}
.section-title {
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--color-dark);
  margin-bottom: 15px;
  line-height: 1.25;
}
.section-title .hl { color: var(--color-primary); }
.section-desc {
  font-size: 1.05rem;
  color: var(--color-text-light);
  line-height: 1.75;
  max-width: 620px;
}
.section-desc.centered { margin: 0 auto; }
/* Când e în header-ul centrat al secțiunii → centrat automat */
.section-header .section-desc {
  margin-left: auto;
  margin-right: auto;
}

.section-divider {
  width: 55px;
  height: 4px;
  background: linear-gradient(to right, var(--color-primary), var(--color-secondary));
  border-radius: 2px;
  margin: 14px 0 18px;
}
.section-divider.centered { margin: 14px auto 18px; }

/* =====================================================
   BANDĂ CIFRE / STATS BAR
   ===================================================== */
.stats-bar-section {
  background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
  padding: 45px 0;
}
.stat-box {
  text-align: center;
  padding: 15px 10px;
  border-right: 1px solid rgba(255,255,255,0.15);
}
.stat-box:last-child { border-right: none; }
.stat-box .snum {
  display: block;
  font-family: var(--font-heading);
  font-size: 2.8rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
  margin-bottom: 8px;
}
.stat-box .snum em { color: #7DCEA0; font-style: normal; }
.stat-box .slbl,
.stat-box .slabel {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.78);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* =====================================================
   CARDURI SERVICII
   ===================================================== */
.service-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 38px 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: var(--transition-base);
  height: 100%;
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}
.service-card-bar {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(to right, var(--color-primary), var(--color-secondary));
  transform: scaleX(0);
  transition: transform 0.3s ease;
}
.service-card:hover { box-shadow: var(--shadow-md); transform: translateY(-5px); }
.service-card:hover .service-card-bar { transform: scaleX(1); }

.service-icon {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-light-2), #D6EAF8);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 22px;
  font-size: 1.9rem;
  color: var(--color-primary);
  transition: var(--transition-base);
}
.service-card:hover .service-icon {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
  color: var(--color-white);
}
.service-card h3 {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--color-dark);
}
.service-card p {
  color: var(--color-text-light);
  font-size: 0.93rem;
  margin-bottom: 22px;
  line-height: 1.7;
}
.service-card-link {
  color: var(--color-primary-light);
  font-weight: 700;
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: var(--transition-base);
}
.service-card-link:hover { gap: 10px; color: var(--color-primary); }

/* =====================================================
   DESPRE NOI
   ===================================================== */
.about-img-wrap {
  position: relative;
}
.about-img-main {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.about-img-main img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  display: block;
}
/* Placeholder imagine */
.about-img-placeholder {
  width: 100%;
  height: 480px;
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-secondary) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
}
.about-img-placeholder i { font-size: 5rem; color: rgba(255,255,255,0.25); }

.about-badge-box {
  position: absolute;
  bottom: 25px;
  right: -15px;
  background-color: var(--color-primary);
  border-radius: var(--radius-md);
  padding: 20px 24px;
  text-align: center;
  box-shadow: var(--shadow-md);
  min-width: 130px;
}
.about-badge-box .abnum {
  display: block;
  font-family: var(--font-heading);
  font-size: 2.4rem;
  font-weight: 800;
  color: #7DCEA0;
  line-height: 1;
  margin-bottom: 5px;
}
.about-badge-box .abtxt {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.85);
  font-weight: 600;
  line-height: 1.3;
}

.feature-row {
  display: flex;
  gap: 14px;
  margin-bottom: 22px;
  align-items: flex-start;
}
.feature-icon-box {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  background-color: var(--color-light-2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  font-size: 1.15rem;
  flex-shrink: 0;
}
.feature-row h5 { font-size: 1rem; font-weight: 700; margin-bottom: 4px; }
.feature-row p  { font-size: 0.9rem; color: var(--color-text-light); margin-bottom: 0; }

/* =====================================================
   DE CE NOI / AVANTAJE
   ===================================================== */
.why-section { background-color: var(--color-light); }

.advantage-card {
  text-align: center;
  padding: 30px 20px;
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-base);
  height: 100%;
  border: 1px solid var(--color-border);
}
.advantage-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.advantage-icon {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background-color: var(--color-light-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.9rem;
  color: var(--color-primary);
  margin: 0 auto 20px;
  transition: var(--transition-base);
}
.advantage-card:hover .advantage-icon {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
  color: var(--color-white);
}
.advantage-card h4 { font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; }
.advantage-card p  { font-size: 0.92rem; color: var(--color-text-light); margin-bottom: 0; }

/* =====================================================
   PAȘI — CUM DEVII REZIDENT
   ===================================================== */
.steps-section { background-color: var(--color-white); }

.step-card {
  text-align: center;
  padding: 30px 20px;
  position: relative;
}
/* Cerc cu numărul pasului */
.step-number {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
  box-shadow: 0 4px 16px rgba(27, 79, 114, 0.28);
  position: relative;
  z-index: 1;
}
/* Cerc decorativ cu iconița pasului */
.step-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background-color: var(--color-light);
  border: 2px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 1.75rem;
  color: var(--color-primary);
  transition: background-color var(--transition), border-color var(--transition), color var(--transition);
}
.step-card:hover .step-icon {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}
/* Linie conectoare între pași — aliniată cu centrul lui .step-number */
.step-card::after {
  content: '';
  position: absolute;
  top: 56px; /* padding-top(30) + step-number-height(52)/2 = 56px */
  left: calc(50% + 36px);
  width: calc(100% - 72px);
  height: 2px;
  background: linear-gradient(to right, var(--color-primary-light), var(--color-border));
}
.step-card:last-child::after { display: none; }

.step-card h3 { font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; }
.step-card p  { font-size: 0.92rem; color: var(--color-text-light); margin-bottom: 0; }

/* =====================================================
   TESTIMONIALE
   ===================================================== */
.testimonials-section { background-color: var(--color-light); }

.testimonial-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 32px 28px;
  border: 1px solid var(--color-border);
  height: 100%;
  transition: var(--transition-base);
  position: relative;
}
.testimonial-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }

.quote-icon {
  font-size: 3.5rem;
  color: var(--color-primary);
  opacity: 0.12;
  font-family: Georgia, serif;
  line-height: 1;
  margin-bottom: 5px;
}
.testimonial-stars { color: #F1C40F; margin-bottom: 14px; font-size: 0.95rem; }
.testimonial-text {
  font-size: 0.97rem;
  color: var(--color-text);
  line-height: 1.8;
  font-style: italic;
  margin-bottom: 22px;
}
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.t-avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--color-white);
  flex-shrink: 0;
}
.t-name {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--color-dark);
  margin-bottom: 2px;
}
.t-rel { font-size: 0.82rem; color: var(--color-text-light); }

/* =====================================================
   GALERIE FOTO (homepage)
   ===================================================== */
.gallery-section { background-color: var(--color-white); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.gallery-thumb {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-sm);
  aspect-ratio: 4/3;
  cursor: pointer;
}
.gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
  display: block;
}
.gallery-thumb:hover img { transform: scale(1.06); }
.gallery-thumb-overlay {
  position: absolute;
  inset: 0;
  background: rgba(27,79,114,0.52);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.gallery-thumb:hover .gallery-thumb-overlay { opacity: 1; }
.gallery-thumb-overlay i { font-size: 2rem; color: var(--color-white); }

/* ── Lightbox cu navigare ─────────────────────────────────────────────── */
.calb-lb {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
.calb-lb-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 92vw;
  max-height: 90vh;
}
.calb-lb-stage img {
  max-width: 92vw;
  max-height: 82vh;
  border-radius: 6px;
  box-shadow: 0 12px 50px rgba(0,0,0,0.6);
  object-fit: contain;
}
.calb-lb-caption {
  margin-top: 0.75rem;
  color: rgba(255,255,255,0.85);
  font-size: 0.95rem;
  text-align: center;
  max-width: 80vw;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
}
.calb-lb-btn {
  position: absolute;
  background: rgba(255,255,255,0.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.2);
  cursor: pointer;
  font-size: 1.6rem;
  line-height: 1;
  padding: 0;
  width: 48px; height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.2s;
  z-index: 10;
}
.calb-lb-btn:hover { background: rgba(255,255,255,0.2); transform: scale(1.08); }
.calb-lb-close { top: 22px; right: 24px; font-size: 2rem; }
.calb-lb-prev  { left: 24px;  top: 50%; transform: translateY(-50%); }
.calb-lb-next  { right: 24px; top: 50%; transform: translateY(-50%); }
.calb-lb-prev:hover { transform: translateY(-50%) scale(1.08); }
.calb-lb-next:hover { transform: translateY(-50%) scale(1.08); }
.calb-lb-counter {
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.85);
  font-size: 0.95rem;
  background: rgba(0,0,0,0.45);
  padding: 4px 12px;
  border-radius: 14px;
}
@media (max-width: 576px) {
  .calb-lb-btn { width: 40px; height: 40px; font-size: 1.3rem; }
  .calb-lb-close { top: 12px; right: 12px; }
  .calb-lb-prev  { left: 8px; }
  .calb-lb-next  { right: 8px; }
}

/* Placeholder galerie (fără imagini) */
.gallery-ph {
  width: 100%;
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary-light));
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}
.gallery-ph i { font-size: 2.5rem; color: rgba(255,255,255,0.3); }

/* =====================================================
   ȘTIRI / NOUTĂȚI
   ===================================================== */
.news-section { background-color: var(--color-light); }

.news-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  transition: var(--transition-base);
  height: 100%;
  display: flex;
  flex-direction: column;
}
.news-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }

.news-card-thumb {
  width: 100%;
  height: 195px;
  object-fit: cover;
  display: block;
}
.news-card-thumb-ph {
  width: 100%;
  height: 195px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.news-card-thumb-ph i { font-size: 3rem; color: rgba(255,255,255,0.3); }

.news-card-body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.news-date {
  font-size: 0.82rem;
  color: var(--color-text-light);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.news-card-body h4 {
  font-size: 1.08rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 10px;
  line-height: 1.4;
  flex-grow: 1;
}
.news-card-body h4 a { color: inherit; }
.news-card-body h4 a:hover { color: var(--color-primary); }
.news-card-body p {
  font-size: 0.91rem;
  color: var(--color-text-light);
  margin-bottom: 18px;
  line-height: 1.65;
}
.news-read-more {
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--color-primary-light);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: var(--transition-base);
  margin-top: auto;
}
.news-read-more:hover { gap: 10px; color: var(--color-primary); }

/* =====================================================
   CATEG SUBPAGE CARDS
   ===================================================== */
.categ-subpg-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0,0,0,0.07);
  border: 1px solid #f0e8e8;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.categ-subpg-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 24px rgba(139,0,0,0.13);
}
.categ-icon-wrap {
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.92);
  font-size: 2.2rem;
  flex-shrink: 0;
}
.categ-icon-wrap.c-1 { background: linear-gradient(135deg, #8B0000 0%, #C0392B 100%); }
.categ-icon-wrap.c-2 { background: linear-gradient(135deg, #6D1A1A 0%, #A93226 100%); }
.categ-icon-wrap.c-0 { background: linear-gradient(135deg, #922B21 0%, #CB4335 100%); }
.categ-card-body {
  padding: 22px 24px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.categ-card-title {
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 8px;
}
.categ-card-title a { color: #1a1a1a; text-decoration: none; transition: color 0.2s; }
.categ-card-title a:hover { color: var(--color-primary); }
.categ-card-desc {
  font-size: 0.91rem;
  color: #666;
  line-height: 1.65;
  flex-grow: 1;
  margin-bottom: 16px;
}
.categ-subpagini-section {
  background: #FDF6F6;
  border-radius: 16px;
  padding: 36px 32px;
  margin-top: 16px;
}

/* =====================================================
   CTA BANNER
   ===================================================== */
.cta-section {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
  padding: 75px 0;
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute;
  top: -40%; right: -5%;
  width: 450px; height: 450px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
}
.cta-section::after {
  content: '';
  position: absolute;
  bottom: -40%; left: 5%;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: rgba(39,174,96,0.08);
}
.cta-section h2 {
  color: var(--color-white);
  font-size: 2.2rem;
  font-weight: 800;
  margin-bottom: 15px;
}
.cta-section p {
  color: rgba(255,255,255,0.82);
  font-size: 1.08rem;
  margin-bottom: 0;
}
.cta-phone-big {
  font-family: var(--font-heading);
  font-size: 2.2rem;
  font-weight: 800;
  color: #7DCEA0;
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  text-decoration: none;
  transition: var(--transition-base);
}
.cta-phone-big:hover { color: var(--color-white); }
.cta-section .cta-content { position: relative; z-index: 1; }

/* =====================================================
   CONTACT RAPID
   ===================================================== */
.contact-section { background-color: var(--color-light); }

.contact-info-panel {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 38px;
  box-shadow: var(--shadow-sm);
}
.contact-item {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
  align-items: flex-start;
}
.contact-item:last-child { margin-bottom: 0; }
.contact-item-icon {
  width: 50px;
  height: 50px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  color: var(--color-white);
  flex-shrink: 0;
}
.contact-item-icon.ico-blue   { background-color: var(--color-primary); }
.contact-item-icon.ico-green  { background-color: var(--color-secondary); }
.contact-item-icon.ico-orange { background-color: var(--color-accent); }
.contact-item-icon.ico-dark   { background-color: var(--color-dark); }

.contact-item-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-text-light);
  font-weight: 600;
  margin-bottom: 3px;
}
.contact-item-value {
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-dark);
  margin-bottom: 0;
  line-height: 1.4;
}
.contact-item-value a { color: var(--color-dark); }
.contact-item-value a:hover { color: var(--color-primary); }

.map-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.map-wrap iframe {
  display: block;
  width: 100%;
  height: 350px;
  border: none;
}

/* Contact form în pagina contact */
.contact-form-wrap {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 38px;
  box-shadow: var(--shadow-sm);
}

/* =====================================================
   PAGE HEADER (banner pagini interioare)
   ===================================================== */
.page-banner {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
  padding: 60px 0;
  position: relative;
  overflow: hidden;
}
.page-banner.has-img {
  background-size: cover;
  background-position: center;
}
.page-banner.has-img::after {
  content: '';
  position: absolute;
  inset: 0;
  /* Overlay roșu-brand translucid: imaginea transpare prin tenta primary */
  background: linear-gradient(135deg,
    rgba(138, 0, 7, 0.78) 0%,
    rgba(178, 0, 9, 0.62) 100%);
}
.page-banner-content { position: relative; z-index: 2; }
.page-banner h1 {
  color: var(--color-white);
  font-size: 2.2rem;
  font-weight: 800;
  margin-bottom: 12px;
}
.page-banner .breadcrumb-item a    { color: rgba(255,255,255,0.75); }
.page-banner .breadcrumb-item.active { color: rgba(255,255,255,0.55); }
.page-banner .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.4); }
.page-banner .breadcrumb { background: none; padding: 0; margin: 0; }

/* =====================================================
   CONȚINUT PAGINI STANDARD
   ===================================================== */
.page-content {
  padding: var(--section-padding);
}
.page-content h2 { color: var(--color-primary); }
.page-content h3 { color: var(--color-primary-dark); }
.page-content h4 { color: var(--color-dark); }

/* ── Liste cu iconițe (list-benefits / list-documents / gallery-categories) ──
   Iconița e injectată via CSS ::before pe <li> cu font-family Font Awesome,
   deci conținutul din DB NU mai are nevoie de <i class="fa-..."> (pe care
   editorul WYSIWYG îl strică). Markup preferat:
   <ul class="list-benefits"><li><i></i> text</li></ul>
   Tag-ul gol <i></i> e păstrat doar ca placeholder vizual în CMS (ascuns în front).
*/
.list-benefits,
.list-documents,
.gallery-categories {
  list-style: none;
  padding-left: 0;
  margin: 1rem 0 1.5rem;
}
.list-benefits > li,
.list-documents > li,
.gallery-categories > li {
  position: relative;
  padding: 0.55rem 0 0.55rem 2.25rem;
  margin-bottom: 0.25rem;
  line-height: 1.55;
  border-bottom: 1px dashed rgba(138, 0, 7, 0.12);
}
.list-benefits > li:last-child,
.list-documents > li:last-child,
.gallery-categories > li:last-child {
  border-bottom: 0;
}

/* Iconița generică — check pentru beneficii, file pentru documente, folder pentru galerie */
.list-benefits > li::before,
.list-documents > li::before,
.gallery-categories > li::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  left: 0;
  top: 0.75rem;
  width: 1.6rem;
  text-align: center;
  color: var(--color-primary);
  font-size: 1rem;
  line-height: 1.2;
}
.list-benefits > li::before      { content: "\f00c"; } /* fa-check */
.list-documents > li::before     { content: "\f15c"; } /* fa-file-lines */
.gallery-categories > li::before { content: "\f07b"; } /* fa-folder */

/* Placeholder <i> gol — ascuns (există doar pentru ca WYSIWYG să îl păstreze) */
.list-benefits > li > i,
.list-documents > li > i,
.gallery-categories > li > i { display: none; }

/* Dacă totuși există un <i> cu clase FA concrete, respectă-l (backward compat) */
.list-benefits > li > i.fa-solid,
.list-benefits > li > i.fa-regular,
.list-benefits > li > i.fa-brands,
.list-documents > li > i.fa-solid,
.list-documents > li > i.fa-regular,
.list-documents > li > i.fa-brands,
.gallery-categories > li > i.fa-solid,
.gallery-categories > li > i.fa-regular,
.gallery-categories > li > i.fa-brands {
  display: inline-block;
  position: absolute;
  left: 0;
  top: 0.75rem;
  width: 1.6rem;
  text-align: center;
  color: var(--color-primary);
  font-size: 1.05rem;
  line-height: 1;
}
/* Când <i> cu clasă FA e prezent, ascunde ::before ca să nu dubleze */
.list-benefits > li:has(> i.fa-solid)::before,
.list-benefits > li:has(> i.fa-regular)::before,
.list-benefits > li:has(> i.fa-brands)::before,
.list-documents > li:has(> i.fa-solid)::before,
.list-documents > li:has(> i.fa-regular)::before,
.list-documents > li:has(> i.fa-brands)::before,
.gallery-categories > li:has(> i.fa-solid)::before,
.gallery-categories > li:has(> i.fa-regular)::before,
.gallery-categories > li:has(> i.fa-brands)::before { content: none; }

/* Variantă mai compactă, fără separatoare */
.list-benefits.list-flush > li,
.list-documents.list-flush > li,
.gallery-categories.list-flush > li {
  border-bottom: 0;
  padding-top: 0.3rem;
  padding-bottom: 0.3rem;
}

/* =====================================================
   GOOGLE REVIEWS CTA — banner deasupra testimonialelor
   ===================================================== */
.google-reviews-cta {
  margin: 2rem 0 2.5rem;
}
.gr-card {
  background: #fff;
  border: 1px solid rgba(66, 133, 244, 0.18);
  border-radius: var(--radius-md, 14px);
  padding: 1.5rem 1.75rem;
  box-shadow: 0 6px 18px rgba(66, 133, 244, 0.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.gr-head {
  display: flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
}
.gr-logo {
  flex-shrink: 0;
  width: 54px;
  height: 54px;
  background: #fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%234285F4' d='M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z'/><path fill='%2334A853' d='M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z'/><path fill='%23FBBC05' d='M5.84 14.1c-.22-.66-.35-1.36-.35-2.1s.13-1.44.35-2.1V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l3.66-2.83z'/><path fill='%23EA4335' d='M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.83C6.71 7.31 9.14 5.38 12 5.38z'/></svg>") center/60% no-repeat;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}
.gr-rating {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  margin-bottom: 0.15rem;
}
.gr-score {
  font-size: 1.8rem;
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1;
}
.gr-stars {
  color: #f5b301;
  font-size: 1.15rem;
  letter-spacing: 1px;
  font-family: Arial, sans-serif; /* asigură glif ★ uniform */
  line-height: 1;
}
.gr-label {
  margin: 0;
  font-size: 0.92rem;
  color: #555;
}
.gr-actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.gr-actions .btn-calb { margin: 0; }
.gr-actions .fa-brands.fa-google { color: inherit; }

@media (max-width: 767px) {
  .gr-card {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }
  .gr-head { justify-content: center; }
  .gr-actions { justify-content: center; }
}

/* =====================================================
   TESTIMONIALE — wall of love (masonry cu CSS columns)
   ===================================================== */
.testimonials-wall {
  columns: 1;
  column-gap: 1.5rem;
  margin-top: 2rem;
}
@media (min-width: 768px)  { .testimonials-wall { columns: 2; } }
@media (min-width: 1200px) { .testimonials-wall { columns: 3; } }

.testimonial-card {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  display: inline-block;
  width: 100%;
  background: #fff;
  border: 1px solid rgba(138, 0, 7, 0.08);
  border-radius: var(--radius-md, 12px);
  padding: 1.75rem 1.5rem 1.5rem;
  margin: 0 0 2.5rem;
  box-shadow: 0 4px 12px rgba(138, 0, 7, 0.06);
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease;
}
.testimonial-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(138, 0, 7, 0.12);
}

.testimonial-stars {
  color: #f5b301;
  font-size: 1rem;
  letter-spacing: 1px;
  margin-bottom: 0.75rem;
  font-family: Arial, sans-serif; /* asigură glif ★ uniform */
  line-height: 1;
}
/* Dacă stelele au fost șterse de WYSIWYG, CSS le re-adaugă automat */
.testimonial-stars:empty::before { content: "★★★★★"; }
.gr-stars:empty::before { content: "★★★★★"; }

.testimonial-quote-icon {
  color: var(--color-primary);
  opacity: 0.18;
  font-size: 2.4rem;
  position: absolute;
  top: 1rem;
  right: 1.2rem;
  line-height: 1;
  font-style: normal;
}
.testimonial-quote-icon::before {
  content: "\f10d"; /* fa-quote-left */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
}

.testimonial-text {
  font-size: 0.97rem;
  line-height: 1.65;
  color: #333;
  margin: 0 0 1rem;
  font-style: italic;
}
.testimonial-text::before { content: '„'; color: var(--color-primary); font-weight: 700; }
.testimonial-text::after  { content: '"'; color: var(--color-primary); font-weight: 700; }

.testimonial-author {
  border-top: 1px dashed rgba(138, 0, 7, 0.15);
  padding-top: 0.75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}
.testimonial-name {
  color: var(--color-primary-dark);
  font-size: 0.95rem;
}
.testimonial-date {
  font-size: 0.82rem;
  color: #888;
}
.testimonial-date::before {
  content: "\f133"; /* fa-calendar */
  font-family: "Font Awesome 6 Free";
  font-weight: 400;
  margin-right: 0.35rem;
}

/* Galerie imagini în pagini */
.galerie {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
  margin-top: 30px;
}
.galerie a {
  display: block;
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.galerie img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  transition: transform 0.3s ease;
  display: block;
}
.galerie a:hover img { transform: scale(1.06); }

/* Meniu lateral */
.sidebar-widget {
  background-color: var(--color-light);
  border-radius: var(--radius-md);
  padding: 28px;
  border-left: 4px solid var(--color-primary);
}
.sidebar-widget-title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 15px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  gap: 8px;
}
.chenar_submenu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.chenar_submenu li {
  border-bottom: 1px solid var(--color-border);
}
.chenar_submenu li:last-child { border-bottom: none; }
.chenar_submenu li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 6px;
  color: var(--color-text);
  font-weight: 600;
  font-size: 0.93rem;
  transition: var(--transition-base);
}
.chenar_submenu li a:hover,
.chenar_submenu li.active a {
  color: var(--color-primary);
  padding-left: 12px;
}
.chenar_submenu li a::after {
  content: '\f054';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  font-size: 0.7rem;
  color: var(--color-border);
}

/* =====================================================
   FOOTER
   ===================================================== */
#main-footer {
  background-color: var(--color-dark);
  background-image:
    linear-gradient(rgba(15, 25, 38, 0.55), rgba(15, 25, 38, 0.55)),
    url('../../images/bck-footer.jpg');
  background-size: cover;
  background-position: center top;
  padding: 70px 0 0;
}
.footer-col { margin-bottom: 40px; }

.footer-logo-text-main {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--color-white);
}
.footer-logo-text-sub {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.55);
  margin-bottom: 15px;
}
.footer-about-text {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.60);
  line-height: 1.8;
  margin-bottom: 20px;
}
.footer-social {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.footer-social-link {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-color: rgba(255,255,255,0.09);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.65);
  font-size: 0.95rem;
  transition: var(--transition-base);
  text-decoration: none;
}
.footer-social-link:hover {
  background-color: var(--color-primary-light);
  color: var(--color-white);
  transform: translateY(-2px);
}

.footer-col-title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--color-primary-light);
  display: inline-block;
}
.footer-nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-nav-list li { margin-bottom: 9px; }
.footer-nav-list a {
  color: rgba(255,255,255,0.60);
  font-size: 0.92rem;
  transition: var(--transition-base);
  display: flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
}
.footer-nav-list a::before {
  content: '›';
  color: var(--color-primary-light);
  font-size: 1.1rem;
  line-height: 0;
}
.footer-nav-list a:hover { color: var(--color-white); padding-left: 4px; }

.footer-contact-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
  color: rgba(255,255,255,0.62);
  font-size: 0.92rem;
}
.footer-contact-list li i {
  color: var(--color-primary-light);
  font-size: 1rem;
  margin-top: 2px;
  width: 16px;
  flex-shrink: 0;
}
.footer-contact-list a {
  color: rgba(255,255,255,0.75);
  text-decoration: none;
}
.footer-contact-list a:hover { color: var(--color-white); }

.footer-schedule-list {
  list-style: none;
  padding: 0;
  margin: 0 0 22px;
}
.footer-schedule-list li {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  font-size: 0.88rem;
  color: rgba(255,255,255,0.60);
}
.footer-schedule-list .fday { font-weight: 600; color: rgba(255,255,255,0.8); }
.footer-schedule-list .fhours { color: #7DCEA0; }

.footer-bottom {
  margin-top: 10px;
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,0.09);
}
.footer-bottom p {
  margin: 0;
  font-size: 0.87rem;
  color: rgba(255,255,255,0.38);
  text-align: center;
}
.footer-bottom a { color: rgba(255,255,255,0.55); text-decoration: none; }
.footer-bottom a:hover { color: var(--color-white); }

/* =====================================================
   OFFCANVAS MOBIL
   ===================================================== */
.offcanvas-calb .offcanvas-header {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-border);
  padding: 14px 20px;
}
.offcanvas-calb .btn-close { filter: none; }
.offcanvas-calb .offcanvas-body { padding: 0; }

/* Logo din headerul offcanvas — dimensiune controlată */
.offcanvas-calb .offcanvas-header .site-logo img {
  height: auto;      /* anulează atributul HTML height="46" */
  max-height: 44px;
  max-width: 160px;
  width: auto;
}

.offcanvas-nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.offcanvas-nav-list li {
  border-bottom: 1px solid var(--color-border);
}
.offcanvas-nav-list li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 20px;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  transition: var(--transition-base);
}
.offcanvas-nav-list li a:hover,
.offcanvas-nav-list li.active a {
  color: var(--color-primary);
  background-color: var(--color-light);
  padding-left: 26px;
}
.offcanvas-contact-box {
  padding: 20px;
  background-color: var(--color-light);
  border-top: 1px solid var(--color-border);
}
.offcanvas-contact-box p {
  font-size: 0.88rem;
  color: var(--color-text-light);
  margin-bottom: 5px;
}
.offcanvas-contact-box a {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--color-primary);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
/* Butoanele .btn-calb din contact box își păstrează culoarea proprie */
.offcanvas-contact-box a.btn-calb-primary { color: var(--color-white); }
.offcanvas-contact-box a.btn-calb-primary:hover { color: var(--color-white); }
.offcanvas-contact-box a.btn-calb-outline { color: var(--color-primary); }
.offcanvas-contact-box a.btn-calb-accent { color: var(--color-white); }

/* =====================================================
   FORMULARE
   ===================================================== */
.form-control, .form-select {
  border-radius: var(--radius-sm);
  border-color: var(--color-border);
  padding: 12px 16px;
  font-size: 0.97rem;
  font-family: var(--font-body);
  transition: var(--transition-base);
}
.form-control:focus, .form-select:focus {
  border-color: var(--color-primary-light);
  box-shadow: 0 0 0 3px rgba(46,134,193,0.15);
}
.form-label {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-dark);
  margin-bottom: 6px;
}

/* =====================================================
   ALERTE (BS5 compatible - data-bs-dismiss)
   ===================================================== */
.alert { border-radius: var(--radius-sm); font-size: 0.95rem; }
.alert .btn-close { font-size: 0.8rem; }

/* =====================================================
   PAGINARE
   ===================================================== */
.pagination .page-link {
  color: var(--color-primary);
  border-color: var(--color-border);
  font-family: var(--font-heading);
  font-weight: 600;
  transition: var(--transition-base);
}
.pagination .page-item.active .page-link {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}
.pagination .page-link:hover {
  background-color: var(--color-light);
  color: var(--color-primary-dark);
}

/* =====================================================
   CĂUTARE
   ===================================================== */
.search-bar {
  background-color: var(--color-light);
  padding: 25px;
  border-radius: var(--radius-md);
  margin-bottom: 30px;
}
.search-result-item {
  padding: 25px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  margin-bottom: 18px;
  transition: var(--transition-base);
  background-color: var(--color-white);
}
.search-result-item:hover {
  box-shadow: var(--shadow-sm);
  border-color: var(--color-primary-light);
}
.search-result-item h4 a { color: var(--color-primary); }
.search-result-item h4 a:hover { color: var(--color-primary-dark); }
.search-result-item p { font-size: 0.93rem; color: var(--color-text-light); margin-bottom: 8px; }
.search-result-url { font-size: 0.82rem; color: var(--color-secondary); }

/* =====================================================
   SCROLL TO TOP
   ===================================================== */
#scroll-top {
  position: fixed;
  bottom: 28px;
  right: 28px;
  width: 46px;
  height: 46px;
  background-color: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 990;
  box-shadow: var(--shadow-md);
  opacity: 0;
  transform: translateY(15px);
  transition: var(--transition-base);
  font-size: 1rem;
}
#scroll-top.visible { opacity: 1; transform: translateY(0); }
#scroll-top:hover { background-color: var(--color-primary-dark); transform: translateY(-3px); }

/* =====================================================
   BUTON FLOTANT WHATSAPP
   ===================================================== */
#whatsapp-btn {
  position: fixed;
  bottom: 28px;
  left: 28px;
  width: 56px;
  height: 56px;
  background-color: #25D366;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  text-decoration: none;
  z-index: 990;
  box-shadow: 0 4px 16px rgba(37,211,102,0.45);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  animation: waPulse 2.8s ease-in-out infinite;
}
#whatsapp-btn:hover {
  transform: scale(1.12);
  box-shadow: 0 6px 24px rgba(37,211,102,0.60);
  animation: none;
  color: #fff;
}
/* Tooltip */
.wa-tooltip {
  position: absolute;
  left: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%);
  background: #1a1a1a;
  color: #fff;
  font-size: 0.78rem;
  font-family: var(--font-heading);
  font-weight: 600;
  padding: 5px 10px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.wa-tooltip::before {
  content: '';
  position: absolute;
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  border-right-color: #1a1a1a;
}
#whatsapp-btn:hover .wa-tooltip { opacity: 1; }
/* Animație puls subtilă */
@keyframes waPulse {
  0%, 100% { box-shadow: 0 4px 16px rgba(37,211,102,0.45); }
  50%       { box-shadow: 0 4px 28px rgba(37,211,102,0.75); }
}

/* =====================================================
   UTILITARE
   ===================================================== */
.fw-600 { font-weight: 600 !important; }
.fw-700 { font-weight: 700 !important; }
.fw-800 { font-weight: 800 !important; }

.c-primary      { color: var(--color-primary) !important; }
.c-secondary    { color: var(--color-secondary) !important; }
.c-accent       { color: var(--color-accent) !important; }
.c-white        { color: var(--color-white) !important; }
.c-muted        { color: var(--color-text-light) !important; }

.bg-calb-light  { background-color: var(--color-light) !important; }
.bg-calb-primary{ background-color: var(--color-primary) !important; }

.rounded-calb   { border-radius: var(--radius-md) !important; }

/* Animate on scroll helper */
.anim-reveal {
  opacity: 0;
  transform: translateY(25px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.anim-reveal.visible { opacity: 1; transform: translateY(0); }

/* =====================================================
   HERO — clase suplimentare
   ===================================================== */
/* Aliasuri pentru hero-mini-stats items */
.hstat {
  text-align: center;
}
.hstat-num {
  display: block;
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
}
.hstat-label {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.72);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.hstat-div {
  width: 1px;
  height: 40px;
  background-color: rgba(255,255,255,0.25);
  align-self: center;
}

/* Panel hero — elemente de stil */
.hero-panel-title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.hero-panel-list {
  list-style: none;
  padding: 0;
  margin: 0 0 22px;
}
.hero-panel-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  font-size: 0.93rem;
  color: rgba(255,255,255,0.88);
}
.hero-panel-list li:last-child { border-bottom: none; }
.hero-panel-tel {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.1rem;
  color: #7DCEA0;
  text-decoration: none;
  padding: 12px 0 0;
  border-top: 1px solid rgba(255,255,255,0.15);
  transition: var(--transition-base);
}
.hero-panel-tel:hover { color: var(--color-white); }

/* Indicator scroll în hero */
.hero-scroll-hint {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.55);
  font-size: 1.2rem;
  animation: bounceY 1.8s infinite ease-in-out;
  z-index: 2;
}
@keyframes bounceY {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}

/* =====================================================
   HEADER — clase suplimentare
   ===================================================== */
.logo-icon-placeholder {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary-light), var(--color-secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  font-size: 1.4rem;
  flex-shrink: 0;
}
/* Linii hamburger (alternativă la icon FA) */
.hamburger-line {
  display: block;
  width: 22px;
  height: 2px;
  background-color: currentColor;
  border-radius: 2px;
  transition: var(--transition-base);
}
.hamburger-btn { flex-direction: column; gap: 5px; }

/* =====================================================
   FOOTER — clase suplimentare
   ===================================================== */
.footer-top {
  padding: 60px 0 30px;
}
.footer-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  margin-bottom: 15px;
}
.footer-logo-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary-light), var(--color-secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  font-size: 1.3rem;
  flex-shrink: 0;
}
.footer-logo-name {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--color-white);
  line-height: 1.2;
}
.footer-logo-tagline {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.55);
}
.footer-about {
  font-size: 0.91rem;
  color: rgba(255,255,255,0.60);
  line-height: 1.8;
  margin-bottom: 20px;
}
/* Aliasuri footer col title */
.footer-heading {
  font-family: var(--font-heading);
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--color-primary-light);
  display: flex;
  align-items: center;
  gap: 8px;
}
/* Aliasuri footer nav list */
.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-links li { margin-bottom: 9px; }
.footer-links a {
  color: rgba(255,255,255,0.60);
  font-size: 0.92rem;
  transition: var(--transition-base);
  display: flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
}
.footer-links a i { font-size: 0.65rem; color: var(--color-primary-light); }
.footer-links a:hover { color: var(--color-white); padding-left: 4px; }

/* Orar footer */
.footer-schedule { margin-bottom: 20px; }
.footer-schedule-row {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  font-size: 0.88rem;
  color: rgba(255,255,255,0.60);
}
.footer-schedule-row span:first-child { font-weight: 600; color: rgba(255,255,255,0.80); }
.footer-schedule-row span:last-child  { color: #7DCEA0; }
.footer-schedule-note {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--color-accent);
  padding-top: 10px;
  font-weight: 600;
}

/* Social icons în footer (linkuri directe fără clasă extra) */
.footer-social a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-color: rgba(255,255,255,0.09);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.65);
  font-size: 0.95rem;
  transition: var(--transition-base);
  text-decoration: none;
}
.footer-social a:hover {
  background-color: var(--color-primary-light);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* Footer bottom bar */
.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-copyright {
  margin: 0;
  font-size: 0.87rem;
  color: rgba(255,255,255,0.38);
}
.footer-copyright a {
  color: rgba(255,255,255,0.55);
  text-decoration: none;
}
.footer-copyright a:hover { color: var(--color-white); }
.footer-bottom-links {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}
.footer-bottom-links a {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.38);
  text-decoration: none;
  transition: var(--transition-base);
}
.footer-bottom-links a:hover { color: var(--color-white); }

/* =====================================================
   DESPRE NOI — clase suplimentare
   ===================================================== */
.about-badge {
  position: absolute;
  bottom: 25px;
  right: -15px;
  background-color: var(--color-primary);
  border-radius: var(--radius-md);
  padding: 18px 22px;
  box-shadow: var(--shadow-md);
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 160px;
}
.about-badge-icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: #7DCEA0;
  flex-shrink: 0;
}
.about-badge-num {
  display: block;
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 800;
  color: #7DCEA0;
  line-height: 1;
  margin-bottom: 3px;
}
.about-badge-txt {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.82);
  font-weight: 600;
}
.about-value-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-dark);
}
.about-value-item i { font-size: 1.1rem; }

/* =====================================================
   GALERIE — clase suplimentare / aliasuri
   ===================================================== */
/* .gallery-item = wrapper <a> pentru gallery-thumb */
.gallery-item {
  display: block;
  text-decoration: none;
}
/* .gallery-overlay = alias pentru .gallery-thumb-overlay */
.gallery-overlay {
  position: absolute;
  inset: 0;
  background: rgba(27,79,114,0.52);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.gallery-thumb:hover .gallery-overlay { opacity: 1; }
.gallery-overlay i { font-size: 2rem; color: var(--color-white); }

/* =====================================================
   CTA SECTION — clase suplimentare
   ===================================================== */
.cta-title {
  color: var(--color-white);
  font-size: 2.2rem;
  font-weight: 800;
  margin-bottom: 15px;
  line-height: 1.25;
}
.cta-subtitle {
  color: rgba(255,255,255,0.82);
  font-size: 1.08rem;
  margin-bottom: 0;
}
.cta-phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 800;
  color: #7DCEA0;
  text-decoration: none;
  transition: var(--transition-base);
}
.cta-phone:hover { color: var(--color-white); }
.cta-bg-decor { display: none; /* decoratii gestionate via ::before/::after pe .cta-section */ }

/* Grup acțiuni CTA — buton + separator + telefon, centrate */
.cta-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
}
.cta-actions-sep {
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.45);
  position: relative;
}
.cta-actions-sep::before,
.cta-actions-sep::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 28px;
  height: 1px;
  background: rgba(255,255,255,0.25);
}
.cta-actions-sep::before { right: calc(100% + 8px); }
.cta-actions-sep::after  { left:  calc(100% + 8px); }
/* Pe desktop → aliniat dreapta, păstrând flex centrat */
@media (min-width: 992px) {
  .cta-actions { align-items: flex-end; }
}

/* Buton alb pentru CTA section */
.btn-calb-white {
  background-color: var(--color-white);
  color: var(--color-primary) !important;
  border: 2px solid var(--color-white);
}
.btn-calb-white:hover {
  background-color: transparent;
  color: var(--color-white) !important;
}

/* =====================================================
   CONTACT — clase suplimentare / aliasuri
   ===================================================== */
.contact-form-title {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.contact-info-wrap {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 38px;
  box-shadow: var(--shadow-sm);
  height: 100%;
}
.contact-info-item {
  display: flex;
  gap: 14px;
  margin-bottom: 22px;
  align-items: flex-start;
}
.contact-info-item:last-child { margin-bottom: 0; }
.contact-info-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background-color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  color: var(--color-white);
  flex-shrink: 0;
}
.contact-info-label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-text-light);
  font-weight: 600;
  margin-bottom: 3px;
}
.contact-info-val {
  font-weight: 600;
  font-size: 0.97rem;
  color: var(--color-dark);
  line-height: 1.5;
}
.contact-info-link {
  color: var(--color-primary) !important;
  text-decoration: none;
  transition: var(--transition-base);
}
.contact-info-link:hover { color: var(--color-primary-dark) !important; }
.contact-map-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* =====================================================
   ȘTIRI (news cards) — clase suplimentare
   ===================================================== */
.news-img-link { display: block; text-decoration: none; }
.news-img-placeholder {
  width: 100%;
  height: 200px;
  background: linear-gradient(135deg, var(--color-light) 0%, var(--color-border) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: var(--color-border);
}

/* =====================================================
   FOOTER — linkuri rapide (2 coloane)
   ===================================================== */
.footer-links-grid .footer-links {
  column-count: 2;
  column-gap: 8px;
}
.footer-links-grid .footer-links li {
  break-inside: avoid;
  margin-bottom: 6px;
}

/* =====================================================
   TPL-PAGINA-TARIFE — Pagina tarife
   ===================================================== */
.tarife-intro { max-width: 700px; margin: 0 auto; }
.tarife-section { padding: 70px 0; background: var(--color-light); }
.tarif-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: 36px 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  border: 2px solid var(--color-border);
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.tarif-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary);
}
.tarif-card--popular {
  border-color: var(--color-primary);
  background: linear-gradient(135deg, #fff 80%, rgba(139,0,0,0.04) 100%);
}
.tarif-card-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-primary);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  padding: 4px 16px;
  border-radius: 20px;
  white-space: nowrap;
  letter-spacing: 0.03em;
}
.tarif-card-icon {
  width: 60px; height: 60px;
  background: rgba(139,0,0,0.08);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  color: var(--color-primary);
  margin: 0 auto 16px;
}
.tarif-card-type {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin-bottom: 4px;
}
.tarif-card-name {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--color-dark);
  margin-bottom: 8px;
}
.tarif-card-beds {
  font-size: 0.9rem;
  color: var(--color-text);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.tarif-card-features {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  text-align: left;
  flex: 1;
}
.tarif-card-features li {
  padding: 5px 0;
  font-size: 0.92rem;
  color: var(--color-text);
  display: flex;
  align-items: center;
  gap: 8px;
}
.tarif-card-features li .fa-check {
  color: var(--color-secondary);
  font-size: 0.8rem;
}
.tarif-card-cta {
  display: flex;
  justify-content: center;
  margin-top: auto;
}
.tarife-note {
  color: var(--color-text-muted);
  font-size: 0.95rem;
  background: #fff;
  border-radius: var(--radius-md);
  padding: 16px 24px;
  border-left: 4px solid var(--color-primary);
  display: inline-block;
}
.tarife-incluse-section {
  padding: 10px 0;
  background: var(--color-white);
}
.tarife-inclus-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: var(--color-light);
  border-radius: var(--radius-md);
  font-size: 0.97rem;
  font-weight: 600;
  color: var(--color-dark);
  height: 100%;
}
.tarife-inclus-item i {
  color: var(--color-primary);
  font-size: 1.25rem;
  width: 26px;
  flex-shrink: 0;
}
.tarife-cta-section {
  padding: 70px 0;
  background: var(--color-primary);
}
.tarife-cta-box { color: #fff; }
.tarife-cta-box h2 {
  font-size: 2rem;
  font-weight: 800;
  margin-bottom: 14px;
}
.tarife-cta-box p {
  font-size: 1.05rem;
  opacity: 0.85;
  margin-bottom: 30px;
}
.tarife-cta-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

/* =====================================================
   TPL-PAGINA-ECHIPA — Pagina echipă
   ===================================================== */
.echipa-intro { max-width: 700px; margin: 0 auto; }
.echipa-section { padding: 70px 0; background: var(--color-light); }
.echipa-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  transition: transform 0.25s, box-shadow 0.25s;
  height: 100%;
}
.echipa-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
}
.echipa-card-photo {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--color-light);
}
.echipa-card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.4s;
}
.echipa-card:hover .echipa-card-photo img { transform: scale(1.04); }
.echipa-card-photo-placeholder {
  width: 100%; height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  color: var(--color-border);
  background: linear-gradient(135deg, var(--color-light) 0%, #e8e0e0 100%);
}
.echipa-card-info { padding: 20px; }
.echipa-card-name {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 4px;
}
.echipa-card-role {
  font-size: 0.88rem;
  color: var(--color-primary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}
.echipa-card-bio {
  font-size: 0.9rem;
  color: var(--color-text);
  line-height: 1.6;
}
.echipa-empty { color: var(--color-text-muted); }
.echipa-cta-section {
  padding: 70px 0;
  background: var(--color-white);
}
.echipa-cta-box {
  background: var(--color-light);
  border-radius: var(--radius-lg);
  padding: 50px 40px;
  max-width: 600px;
  margin: 0 auto;
}
.echipa-cta-box i { color: var(--color-primary); }
.echipa-cta-box h2 {
  font-size: 1.8rem;
  font-weight: 800;
  margin: 16px 0 12px;
}
.echipa-cta-box p {
  color: var(--color-text);
  margin-bottom: 24px;
}

/* =====================================================
   ECHIPA — fotografie de grup + carduri roluri + valori
   ===================================================== */
.echipa-team-photo {
  margin: 30px auto 50px;
  max-width: 1100px;
  text-align: center;
}
.echipa-team-photo figure {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
  border: 4px solid var(--color-white);
}
.echipa-team-photo img {
  width: 100%;
  height: auto;
  display: block;
}
.echipa-team-photo figcaption {
  margin-top: 14px;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  font-style: italic;
}

.role-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 28px 22px;
  text-align: center;
  height: 100%;
  transition: transform 0.25s, box-shadow 0.25s;
}
.role-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.role-card-icon {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-light) 0%, #f1e4e4 100%);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  font-size: 1.7rem;
}
.role-card h3 {
  font-family: var(--font-heading, inherit);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 8px;
}
.role-card p {
  font-size: 0.92rem;
  color: var(--color-text);
  line-height: 1.55;
  margin: 0;
}

.values-section {
  background: var(--color-light);
  padding: 50px 0;
  margin: 50px -15px 0;
  border-radius: var(--radius-lg);
}
.values-section .values-title {
  text-align: center;
  font-size: 1.6rem;
  margin-bottom: 30px;
  color: var(--color-dark);
}
.value-card {
  text-align: center;
  padding: 20px 14px;
}
.value-card-icon {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--color-primary);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  font-size: 1.4rem;
  box-shadow: 0 4px 12px rgba(138, 0, 7, 0.18);
}
.value-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 4px;
}
.value-card p {
  font-size: 0.88rem;
  color: var(--color-text-muted);
  margin: 0;
  line-height: 1.5;
}


/* =====================================================
   TPL-PAGINA-ADMITERE — Cum devii rezident
   ===================================================== */
.admitere-intro { max-width: 700px; margin: 0 auto; }
.admitere-pasi-section {
  padding: 70px 0;
  background: var(--color-light);
}
.admitere-pasi {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.admitere-pas {
  flex: 1;
  min-width: 200px;
  max-width: 240px;
  text-align: center;
  padding: 30px 20px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  position: relative;
}
.admitere-pas-separator {
  display: flex;
  align-items: center;
  padding: 0 10px;
  color: var(--color-primary);
  font-size: 1.3rem;
  margin-top: 60px;
}
.admitere-pas-nr {
  width: 44px; height: 44px;
  background: var(--color-primary);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 800;
  margin: 0 auto 14px;
}
.admitere-pas-icon {
  font-size: 2rem;
  color: var(--color-primary);
  margin-bottom: 12px;
  opacity: 0.8;
}
.admitere-pas-content h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 8px;
}
.admitere-pas-content p {
  font-size: 0.88rem;
  color: var(--color-text);
  line-height: 1.6;
  margin: 0;
}
.admitere-documente-section {
  padding: 70px 0;
  background: var(--color-white);
}
.admitere-documente-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.admitere-documente-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
  font-size: 0.97rem;
  color: var(--color-text);
}
.admitere-documente-list li:last-child { border-bottom: none; }
.admitere-documente-list li i {
  color: var(--color-primary);
  font-size: 1rem;
  margin-top: 2px;
  flex-shrink: 0;
}
.admitere-documente-note {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.admitere-documente-note i { color: var(--color-primary); flex-shrink: 0; margin-top: 2px; }
.admitere-contact-box {
  background: var(--color-light);
  border-radius: var(--radius-lg);
  padding: 36px;
}
.admitere-contact-box h3 {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-dark);
  margin-bottom: 10px;
}
.admitere-contact-box p {
  color: var(--color-text);
  margin-bottom: 24px;
}
.admitere-contact-items { display: flex; flex-direction: column; gap: 14px; }
.admitere-contact-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.admitere-contact-item:hover {
  border-color: var(--color-primary);
  box-shadow: 0 2px 10px rgba(139,0,0,0.1);
}
.admitere-contact-item i {
  color: var(--color-primary);
  font-size: 1.2rem;
  width: 24px;
  flex-shrink: 0;
}
.admitere-contact-item div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.admitere-contact-item strong {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}
.admitere-contact-item span {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-dark);
}

/* =====================================================
   TPL-PAGINA-FAQ — Întrebări frecvente
   ===================================================== */
.faq-intro { max-width: 660px; margin: 0 auto; }
.faq-section {
  padding: 70px 0;
  background: var(--color-light);
}
.faq-accordion { --bs-accordion-border-radius: var(--radius-md); }
.faq-item {
  margin-bottom: 10px;
  border-radius: var(--radius-md) !important;
  border: 1px solid var(--color-border) !important;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.faq-btn {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-dark) !important;
  background: var(--color-white) !important;
  padding: 18px 24px !important;
  display: flex !important;
  align-items: center;
  gap: 12px;
}
.faq-btn:not(.collapsed) {
  color: var(--color-primary) !important;
  background: rgba(139,0,0,0.04) !important;
  box-shadow: none !important;
}
.faq-btn::after { margin-left: auto; flex-shrink: 0; }
.faq-icon {
  color: var(--color-primary);
  font-size: 1.1rem;
  flex-shrink: 0;
}
.faq-body {
  font-size: 0.97rem;
  color: var(--color-text);
  line-height: 1.75;
  padding: 6px 24px 22px 56px !important;
  background: var(--color-white) !important;
}
.faq-cta-section {
  padding: 60px 0;
  background: var(--color-white);
}
.faq-cta-text {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--color-dark);
  margin-bottom: 20px;
}
