/*
 Theme Name: Hello Elementor Child
 Template: hello-elementor
 Version: 1.0
 Author: Castalia
*/

/* ═══════════════════════════════════════════════════
   CASTALIA — DESIGN TOKENS (schimbă culorile AICI)
   ═══════════════════════════════════════════════════ */
:root {
  /* — Culori principale — */
  --c-blue:        #0265c2;
  --c-blue-dark:   #095eb1;
  --c-blue-deep:   #0a3d8f;
  --c-blue-card1:  #095eb1;
  --c-blue-card2:  #095448;

  --c-teal:        #1e8c7a;
  --c-teal-dark:   #0f6b5c;
  --c-teal-darker: #095448;

  --c-magenta:     #d4359a;
  --c-magenta-dark:#aa2178;

  --c-purple:      #5c3fbf;
  --c-purple-dark: #4a2fa0;
  --c-purple-text: #4a3f72;
  --c-purple-soft: #8a7aaa;
  --c-purple-bg:   #ede8f5;

  --c-title:       #1a3a7a;
  --c-title-em-1:  #2176c7;
  --c-title-em-2:  #5c3fbf;

  --c-bg:          aliceblue;
  --c-bg-card:     #fdf8f0;
  --c-dark-text:   #1a1535;
  --c-mint:        #7fffd4;

  --c-whatsapp:    #25d366;
  --c-whatsapp-dk: #20b558;
  --c-facebook:    #1877f2;
  --c-facebook-dk: #1665d8;
}

body,
.cs-complex,
.cs-hero,
.cs-hero-right {
  background: var(--c-bg) !important;
}


/* ═══════════════════════════════
   CASTALIA HEADER
═══════════════════════════════ */

.cs-header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: rgba(from var(--c-blue-dark) r g b / .9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 12px 30px;
  width: 100%;
}

.cs-header-inner {
  max-width: 1300px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

/* LOGO */
.cs-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

img.custom-logo {
    width: 200px;
}
img.cs-logo  {
  height: 25px;
  width: auto;
  object-fit: contain;
}
.cs-logo-text {
  font-family: 'Nunito', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  color: #ffffff;
}

/* NAV PILL */
.cs-nav-pill {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cs-nav-pill .cs-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  background: rgba(255, 255, 255, 0.15);
  border: 1.5px solid rgba(255, 255, 255, 0.3);
  border-radius: 100px;
  padding: 7px 16px;
  list-style: none;
  margin: 0;
  padding-left: 16px;
}


/* DROPDOWN - fix hover gap */
.cs-menu li {
  position: relative;
  list-style: none;
}



/* punte invizibila intre link si dropdown */
.cs-menu li ul::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 0;
  right: 0;
  height: 10px;
}

.cs-menu li:hover > ul {
  display: block;
}


.cs-menu li a {
  font-family: 'Nunito', sans-serif;
  font-size: .82rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  padding: 5px 10px;
  border-radius: 100px;
  transition: all .2s ease;
  white-space: nowrap;
  display: block;
}

.cs-menu li a:hover,
.cs-menu li.current-menu-item > a {
  background: rgba(255, 255, 255, 0.25);
  color: #ffffff;
}

/* DROPDOWN */
.cs-menu li ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #ffffff;
  border-radius: 14px;
  padding: 8px;
  list-style: none;
  min-width: 180px;
  box-shadow: 0 10px 30px rgba(from var(--c-blue-dark) r g b / .2);
  z-index: 100;
  /* adaugam padding-top ca sa nu dispara cand mutam mouse-ul */
  margin-top: 0;
}

.cs-menu li:hover > ul {
  display: block;
}

.cs-menu li ul li a {
  color: var(--c-blue-deep);
  font-size: .8rem;
  border-radius: 8px;
  padding: 7px 12px;
}

.cs-menu li ul li a:hover {
  background: rgba(from var(--c-blue-dark) r g b / .08);
  color: rgba(from var(--c-blue-dark) r g b / 1);
}

/* ACTIONS */
.cs-actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 12px;
}

.cs-tel {
  font-family: 'Nunito', sans-serif;
  font-size: .82rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: color .2s;
}
.cs-tel:hover { color: #ffffff; }

.cs-cta {
  font-family: 'Nunito', sans-serif;
  font-size: .82rem;
  font-weight: 800;
  color: rgba(from var(--c-blue-dark) r g b / 1);
  background: #ffffff;
  padding: 8px 18px;
  border-radius: 100px;
  text-decoration: none;
  transition: all .25s;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(0,0,0,.15);
}
.cs-cta:hover {
  background: #f0f0f0;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.2);
}

/* MOBILE */
@media (max-width: 1024px) {
  .cs-menu li a {
    font-size: .75rem;
    padding: 5px 7px;
  }
}

@media (max-width: 768px) {
  .cs-header { padding: 10px 16px; }
  .cs-logo img { height: 40px; }
  .cs-nav-pill { display: none; }
  .cs-tel { display: none; }
}
.co-card-1 {
  display: flex;
  flex-direction: column;
}
.c1-footer {
  margin-top: auto;
}


/* ═══════════════════════════════
   HERO SECTION
═══════════════════════════════ */

.cs-hero {
  display: grid;
  grid-template-columns: 52fr 48fr;
  min-height: 90vh;
  background: var(--c-purple-bg);
  overflow: hidden;
  position: relative;
}

.cs-hero-left {
  position: relative;
  overflow: hidden;
  min-height: 500px;
}

.cs-hero-img {
  position: absolute;
  inset: 0;
  background: url('https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1400&q=85') center/cover no-repeat;
  transform: scale(1.04);
}

.cs-hero-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(from var(--c-blue-dark) r g b / .15) 0%, transparent 70%);
}

.cs-hero-left::after {
  content: '';
  position: absolute;
  top: 0; right: -40px; bottom: 0;
  width: 80px;
  background: var(--c-purple-bg);
  clip-path: ellipse(40px 52% at 100% 50%);
  z-index: 2;
}

.cs-hero-badge {
  position: absolute;
  bottom: 3rem;
  left: 2rem;
  z-index: 5;
  background: rgba(255,255,255,.97);
  border-radius: 16px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 8px 32px rgba(from var(--c-blue-dark) r g b / .18);
}

.cs-badge-dot {
  position: absolute;
  top: -.4rem; right: -.4rem;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--c-teal);
  border: 2px solid #fff;
}

.cs-badge-icon { font-size: 1.6rem; line-height: 1; }

.cs-badge-text strong {
  display: block;
  font-size: .9rem;
  font-weight: 700;
  color: var(--c-dark-text);
  font-family: 'Nunito', sans-serif;
}

.cs-badge-text span {
  font-size: .75rem;
  color: var(--c-purple-soft);
  font-family: 'Nunito', sans-serif;
}

.cs-hero-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 5rem 4rem 4rem 4.5rem;
  background: var(--c-purple-bg);
  position: relative;
  z-index: 3;
}

.cs-hero-eyebrow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 1.4rem;
}

.cs-ey-line {
  width: 28px; height: 2.5px;
  background: linear-gradient(90deg, var(--c-teal), var(--c-magenta));
  border-radius: 2px;
  flex-shrink: 0;
}

.cs-ey-txt {
  font-family: 'Nunito', sans-serif;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-teal);
}

.cs-hero-h1 {
  font-family: 'Fraunces', serif;
  font-size: clamp(3rem, 5vw, 5rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -.025em;
  color: var(--c-dark-text);
  margin-bottom: 1.4rem;
}

.cs-hero-h1 em {
  font-style: italic;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cs-hero-p {
  font-family: 'Nunito', sans-serif;
  font-size: 1.05rem;
  color: var(--c-purple-text);
  line-height: 1.8;
  max-width: 420px;
  margin-bottom: 2.2rem;
}

.cs-hero-btns {
  display: flex;
  gap: 14px;
  margin-bottom: 3rem;
  flex-wrap: wrap;
}

.cs-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--c-teal), var(--c-teal-dark));
  color: #fff !important;
  padding: 14px 28px;
  border-radius: 100px;
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none !important;
  box-shadow: 0 8px 28px rgba(from var(--c-teal) r g b / .35);
  transition: all .3s;
}
.cs-btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 34px rgba(from var(--c-teal) r g b / .55);
}

.cs-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--c-magenta), var(--c-magenta-dark));
  color: #fff !important;
  padding: 14px 28px;
  border-radius: 100px;
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none !important;
  box-shadow: 0 8px 28px rgba(from var(--c-magenta) r g b / .35);
  transition: all .3s;
}
.cs-btn-secondary:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 34px rgba(from var(--c-magenta) r g b / .55);
}

.cs-hero-stats {
  display: flex;
  gap: 2.5rem;
  padding-top: 2.2rem;
  border-top: 2px solid rgba(from var(--c-purple) r g b / .12);
}

.cs-stat-num {
  font-family: 'Fraunces', serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cs-stat-lbl {
  font-family: 'Nunito', sans-serif;
  font-size: .78rem;
  font-weight: 600;
  color: var(--c-purple-soft);
  margin-top: .2rem;
  line-height: 1.4;
}

@media (max-width: 900px) {
  .cs-hero { grid-template-columns: 1fr; min-height: auto; }
  .cs-hero-left { height: 320px; }
  .cs-hero-left::after { display: none; }
  .cs-hero-right { padding: 3rem 2rem; }
  .cs-hero-h1 { font-size: 2.8rem; }
}

/* ═══════════════════════════════
   MARQUEE
═══════════════════════════════ */

.cs-marquee {
      background: linear-gradient(90deg, var(--c-blue-deep), var(--c-blue), var(--c-blue-dark));
      padding: 14px 0;
      overflow: hidden;
      margin: 0;
      border-radius: 0;
      box-shadow: 0 8px 28px rgba(from var(--c-blue-dark) r g b / .35);
  }

.cs-marquee-track {
  display: flex;
  width: max-content;
  animation: cs-marquee-scroll 28s linear infinite;
}

@keyframes cs-marquee-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.cs-marquee-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 28px;
  white-space: nowrap;
  font-family: 'Nunito', sans-serif;
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
  border-right: 1px solid rgba(255,255,255,.2);
}

.cs-m-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,.7);
  flex-shrink: 0;
}
/* ═══════════════════════════════
   HAMBURGER & MOBILE MENU
═══════════════════════════════ */

/* buton hamburger — ascuns pe desktop */
.cs-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 38px;
  height: 38px;
  background: rgba(255,255,255,.2);
  border: 1.5px solid rgba(255,255,255,.3);
  border-radius: 8px;
  cursor: pointer;
  padding: 0;
  transition: background .2s;
}
.cs-hamburger:hover {
  background: rgba(255,255,255,.3);
}
.cs-hamburger span {
  display: block;
  width: 18px;
  height: 2px;
  background: #ffffff;
  border-radius: 2px;
  transition: all .3s;
}

/* animatie X cand e deschis */
.cs-ham-active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.cs-ham-active span:nth-child(2) {
  opacity: 0;
}
.cs-ham-active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* meniu mobil — ascuns default */
.cs-mobile-menu {
  display: none;
  background: rgba(from var(--c-blue-dark) r g b / .98);
  padding: 16px 20px;
  border-top: 1px solid rgba(255,255,255,.15);
}

.cs-mobile-menu.cs-mobile-open {
  display: block;
}

.cs-mobile-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cs-mobile-nav li a {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  font-weight: 700;
  color: rgba(255,255,255,.9);
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 10px;
  transition: background .2s;
}

.cs-mobile-nav li a:hover,
.cs-mobile-nav li.current-menu-item > a {
  background: rgba(255,255,255,.15);
  color: #ffffff;
}

/* submeniu mobil */
.cs-mobile-nav li ul {
  list-style: none;
  margin: 4px 0 0 14px;
  padding: 0;
}

.cs-mobile-nav li ul li a {
  font-size: .85rem;
  padding: 8px 14px;
  color: rgba(255,255,255,.7);
}

/* MOBILE breakpoint */
@media (max-width: 768px) {
  .cs-hamburger { display: flex; }
  .cs-nav-pill { display: none; }
  .cs-tel { display: none; }
  .cs-cta { 
    padding: 7px 14px;
    font-size: .78rem;
  }
}

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */

.cs-footer {
  background: rgba(from var(--c-blue-dark) r g b / .95);
  padding: 40px 30px;
  margin-top: 0;
}


.cs-footer-inner {
  max-width: 1300px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 30px;
  text-align: center;
}

.cs-footer-copy {
  font-family: 'Nunito', sans-serif;
  font-size: 16px;
  color: white;
  font-weight: 500;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.1);
  width: 100%;
  text-align: center;
}






/* Logo */
.cs-footer-logo img {
  height: 60px;
  width: auto;
  opacity: .9;
}
.cs-footer-logo-text {
  font-family: 'Fraunces', serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: #ffffff;
}

/* Contact links */
.cs-footer-contact {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px;
}

.cs-footer-link {
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  transition: color .2s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.cs-footer-link:hover {
  color: #ffffff;
}

/* Social buttons */
.cs-footer-social {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.cs-footer-social-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 20px;
  border-radius: 100px;
  font-family: 'Nunito', sans-serif;
  font-size: .85rem;
  font-weight: 700;
  text-decoration: none;
  transition: all .25s;
}

.cs-fb {
  background: var(--c-facebook);
  color: #ffffff;
}
.cs-fb:hover {
  background: var(--c-facebook-dk);
  transform: translateY(-2px);
  color: #ffffff;
}

.cs-wa {
  background: var(--c-whatsapp);
  color: #ffffff;
}
.cs-wa:hover {
  background: var(--c-whatsapp-dk);
  transform: translateY(-2px);
  color: #ffffff;
}


/* Responsive */
@media (max-width: 600px) {
  .cs-footer { padding: 30px 20px; }
  .cs-footer-contact { flex-direction: column; gap: 12px; }
}

/* ═══════════════════════════════
   SECTIUNEA COMPLEX
═══════════════════════════════ */

.cs-complex {
  background: var(--c-bg);
  padding: 60px 30px;
  text-align: center;
}

.cs-complex-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 12px;
}

.cs-complex-h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  font-weight: 700;
  color: var(--c-dark-text);
  letter-spacing: -.02em;
  margin-bottom: 20px;
  line-height: 1.15;
}

.cs-complex-h2 em {
  font-style: italic;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cs-complex-intro {
  font-family: 'Nunito', sans-serif;
  font-size: 1rem;
  color: var(--c-purple-text);
  line-height: 1.8;
  max-width: 780px;
  margin: 0 auto 48px;
}

/* GRID 3 CARDURI */
.cs-complex-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: left;
}

/* CARD */
.cs-complex-card {
  background: #ffffff;
  border-radius: 22px;
  padding: 32px 28px;
  box-shadow: 0 4px 24px rgba(from var(--c-purple) r g b / .08);
  border: 2px solid transparent;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}

.cs-complex-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--c-teal), var(--c-magenta));
  opacity: 0;
  transition: opacity .3s;
}

.cs-complex-card:hover {
  border-color: rgba(from var(--c-teal) r g b / .2);
  box-shadow: 0 12px 40px rgba(from var(--c-purple) r g b / .14);
  transform: translateY(-4px);
}

.cs-complex-card:hover::before {
  opacity: 1;
}

/* card featured */
.cs-complex-card--featured {
  background: var(--c-blue);
  border-color: transparent;
  box-shadow: 0 12px 40px rgba(from var(--c-teal-dark) r g b / .35);
}

.cs-complex-card--featured::before {
  opacity: 1;
  background: linear-gradient(90deg, var(--c-mint), var(--c-magenta));
}

.cs-complex-card--featured .cs-cc-title {
  color: #ffffff;
}

.cs-complex-card--featured .cs-cc-desc {
  color: rgba(255,255,255,.7);
}

.cs-complex-card--featured .cs-cc-list li {
  color: rgba(255,255,255,.88);
  border-bottom-color: rgba(255,255,255,.1);
}

.cs-complex-card--featured .cs-cc-list li::before {
  color: var(--c-mint);
}

/* icon */

/* Portile Deltei — card albastru (refoloseste variabilele --c-blue) */
.cs-complex-card--blue {
  background: var(--c-blue);
  border-color: transparent;
  box-shadow: 0 12px 40px rgba(from var(--c-blue-dark) r g b / .35);
}

.cs-complex-card--blue::before {
  opacity: 1;
  background: linear-gradient(90deg, var(--c-title-em-1), var(--c-blue));
}

.cs-complex-card--blue .cs-cc-title {
  color: #ffffff;
}

.cs-complex-card--blue .cs-cc-desc {
  color: rgba(255,255,255,.7);
}

.cs-complex-card--blue .cs-cc-list li {
  color: rgba(255,255,255,.88);
  border-bottom-color: rgba(255,255,255,.1);
}

.cs-complex-card--blue .cs-cc-list li::before {
  color: rgba(255,255,255,.6);
}
.cs-cc-icon {
  font-size: 2.2rem;
  margin-bottom: 14px;
  line-height: 1;
}

/* titlu card */
.cs-cc-title {
  font-family: 'Fraunces', serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--c-dark-text);
  margin-bottom: 8px;
  line-height: 1.2;
}

/* descriere card */
.cs-cc-desc {
  font-family: 'Nunito', sans-serif;
  font-size: .88rem;
  color: var(--c-purple-soft);
  margin-bottom: 20px;
  line-height: 1.5;
  font-weight: 600;
}

/* lista */
.cs-cc-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.cs-cc-list li {
  font-family: 'Nunito', sans-serif;
  font-size: .88rem;
  color: var(--c-purple-text);
  font-weight: 600;
  padding: 8px 0;
  border-bottom: 1px solid rgba(from var(--c-purple) r g b / .08);
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.4;
}

.cs-cc-list li:last-child {
  border-bottom: none;
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .cs-complex-grid {
    grid-template-columns: 1fr;
    max-width: 500px;
  }
  .cs-complex { padding: 40px 20px; }
}

/* ═══════════════════════════════
   TARIFE
═══════════════════════════════ */

/* liste normale - span + strong */
.cs-cc-list li span {
  flex: 1;
  color: var(--c-purple-text);
}
.cs-cc-list li strong {
  color: var(--c-teal-dark);
  font-weight: 800;
  white-space: nowrap;
}

/* carduri tarife albe */
.cs-tarife-card {
  background: #ffffff;
  border-radius: 22px;
  padding: 32px 28px;
  box-shadow: 0 4px 24px rgba(from var(--c-purple) r g b / .08);
  border: 2px solid transparent;
  transition: all .3s;
}
.cs-tarife-card:hover {
  border-color: rgba(from var(--c-teal) r g b / .2);
  box-shadow: 0 12px 40px rgba(from var(--c-purple) r g b / .14);
  transform: translateY(-4px);
}
.cs-tarife-card .cs-cc-title {
  color: var(--c-dark-text) !important;
}
.cs-tarife-card .cs-cc-desc {
  color: var(--c-purple-soft) !important;
}
.cs-tarife-card .cs-cc-list li {
  color: var(--c-purple-text) !important;
  border-bottom-color: rgba(from var(--c-purple) r g b / .08) !important;
}
.cs-tarife-card .cs-cc-list li span {
  color: var(--c-purple-text) !important;
}
.cs-tarife-card .cs-cc-list li strong {
  color: var(--c-blue-deep) !important;
}

/* grid info extra */
.cs-tarife-extra {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 22px auto 0;
  text-align: left;
}

/* featured teal - suprascrie tot cu !important */
.cs-tarife-card.cs-complex-card--featured {
  background: linear-gradient(145deg, var(--c-teal-dark), var(--c-teal-darker)) !important;
  border-color: transparent !important;
  box-shadow: 0 12px 40px rgba(from var(--c-teal-dark) r g b / .35) !important;
}
.cs-tarife-card.cs-complex-card--featured .cs-cc-title {
  color: #ffffff !important;
}
.cs-tarife-card.cs-complex-card--featured .cs-cc-desc {
  color: rgba(255,255,255,.75) !important;
}
.cs-tarife-card.cs-complex-card--featured .cs-cc-list li {
  color: rgba(255,255,255,.88) !important;
  border-bottom-color: rgba(255,255,255,.1) !important;
}
.cs-tarife-card.cs-complex-card--featured .cs-cc-list li span {
  color: rgba(255,255,255,.88) !important;
}
.cs-tarife-card.cs-complex-card--featured .cs-cc-list li strong {
  color: var(--c-mint) !important;
}

/* note de jos */
.cs-tarife-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  max-width: 1200px;
  margin: 28px auto 0;
}
.cs-tarife-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 100px;
  font-family: 'Nunito', sans-serif;
  font-size: .88rem;
  font-weight: 600;
  line-height: 1.4;
}
.cs-note-green {
  background: rgba(from var(--c-teal) r g b / .1);
  color: var(--c-teal-dark);
  border: 1.5px solid rgba(from var(--c-teal) r g b / .2);
}
.cs-note-blue {
  background: rgba(from var(--c-blue-dark) r g b / .08);
  color: var(--c-blue-dark);
  border: 1.5px solid rgba(from var(--c-blue-dark) r g b / .15);
}
.cs-note-orange {
  background: rgba(from var(--c-magenta) r g b / .08);
  color: var(--c-magenta-dark);
  border: 1.5px solid rgba(from var(--c-magenta) r g b / .15);
}

@media (max-width: 900px) {
  .cs-tarife-extra {
    grid-template-columns: 1fr;
    max-width: 500px;
  }
  .cs-tarife-notes {
    flex-direction: column;
    align-items: center;
  }
}

/* ═══════════════════════════════
   CLASA NOUA - cs-card-teal
   independenta de cs-complex
═══════════════════════════════ */
.cs-card-teal {
  background: linear-gradient(145deg, var(--c-teal-dark), var(--c-teal-darker)) !important;
  border-color: transparent !important;
  box-shadow: 0 12px 40px rgba(from var(--c-teal-dark) r g b / .35) !important;
}
.cs-card-teal::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--c-mint), var(--c-magenta));
  opacity: 1;
}
.cs-card-teal .cs-cc-title {
  color: #ffffff !important;
}
.cs-card-teal .cs-cc-desc {
  color: rgba(255,255,255,.75) !important;
}
.cs-card-teal .cs-cc-list li {
  color: rgba(255,255,255,.88) !important;
  border-bottom-color: rgba(255,255,255,.1) !important;
}
.cs-card-teal .cs-cc-list li span {
  color: rgba(255,255,255,.88) !important;
}
.cs-card-teal .cs-cc-list li strong {
  color: var(--c-mint) !important;
}

/* ═══════════════════════════════
   POLITICI REZERVARE
═══════════════════════════════ */

.cs-politici-card {
  background: #ffffff;
  border-radius: 22px;
  padding: 40px 44px;
  box-shadow: 0 4px 24px rgba(from var(--c-purple) r g b / .08);
  max-width: 860px;
  margin: 0 auto;
  text-align: left;
  border-top: 4px solid;
  border-image: linear-gradient(90deg, var(--c-teal), var(--c-magenta)) 1;
  border-radius: 22px;
}

.cs-politici-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cs-politici-list > li {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(from var(--c-purple) r g b / .08);
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  color: var(--c-purple-text);
  line-height: 1.7;
}

.cs-politici-list > li:last-child {
  border-bottom: none;
}

.cs-pol-nr {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  color: #ffffff;
  font-family: 'Fraunces', serif;
  font-size: .85rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}

.cs-pol-text {
  flex: 1;
  min-width: 0;
}

.cs-politici-list strong {
  color: var(--c-dark-text);
  font-weight: 800;
  display: inline;
}

.cs-politici-list p {
  margin: 0 0 10px;
}

.cs-pol-sub {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cs-pol-sub li {
  font-size: .85rem;
  color: var(--c-purple-soft);
  padding-left: 8px;
  line-height: 1.5;
}

@media (max-width: 600px) {
  .cs-politici-card {
    padding: 24px 20px;
  }
}

/* ═══════════════════════════════
   OFERTE 2026 - clase noi
═══════════════════════════════ */

.co-section {
  background: var(--c-bg);
  padding: 40px 30px 50px;
  font-family: 'Nunito', sans-serif;
}

.co-section > h2 {
  font-family: 'Fraunces', serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--c-title);
  letter-spacing: -.02em;
  text-align: center;
  margin-bottom: 32px;
}

.co-section > h2 em {
  font-style: italic;
  background: linear-gradient(135deg, var(--c-title-em-1), var(--c-title-em-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.co-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1300px;
  margin: 0 auto;
}

.co-card {
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(from var(--c-purple) r g b / .18);
  transition: transform .3s, box-shadow .3s;
  display: flex;
  flex-direction: column;
}

.co-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 70px rgba(from var(--c-purple) r g b / .25);
}

/* CARD DARK - Paste */
.co-card-dark { background: var(--c-blue); }
.co-card-dark .co-card-top { background: rgba(0,0,0,.2); padding: 20px 22px; }
.co-card-dark .co-eyebrow { font-size: .85rem; font-weight: 700; color: rgba(255,255,255,.7); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 4px; }
.co-card-dark .co-card-title { font-family: 'Fraunces', serif; font-size: 2rem; font-weight: 700; color: #fff; line-height: 1; margin-bottom: 8px; }
.co-card-dark .co-badge { display: inline-block; background: var(--c-blue); color: #fff; border-radius: 100px; padding: 3px 12px; font-size: .72rem; font-weight: 800; }
.co-card-dark .co-card-body { padding: 18px 22px; flex: 1; display: flex; flex-direction: column; }
.co-card-dark .co-card-footer { background: rgba(0,0,0,.2); padding: 12px 22px; display: flex; align-items: center; justify-content: space-between; color: #fff; font-size: .85rem; font-weight: 700; margin-top: auto; }
.co-card-dark .co-brand { font-family: 'Fraunces', serif; font-size: 1.1rem; font-weight: 700; opacity: .85; }

/* CARD GRADIENT - 1-4 Mai */
.co-card-gradient { background: linear-gradient(160deg, var(--c-teal-dark) 0%, var(--c-magenta-dark) 100%); }
.co-card-gradient .co-card-imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; padding: 14px 14px 8px; }
.co-img-placeholder { border-radius: 10px; aspect-ratio: 3/2; background: rgba(255,255,255,.15); }
.co-card-gradient .co-card-top { padding: 20px 22px; }
.co-card-gradient .co-eyebrow { font-size: .85rem; font-weight: 700; color: rgba(255,255,255,.72); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 4px; }
.co-card-gradient .co-card-title--big { font-family: 'Fraunces', serif; font-size: 2rem; font-weight: 700; color: #fff; line-height: 1; margin-bottom: 4px; }
.co-card-gradient .co-card-title { font-family: 'Fraunces', serif; font-size: 2rem; font-weight: 700; color: #fff; line-height: 1; margin-bottom: 8px; }
.co-card-gradient .co-badge { display: inline-block; background: rgba(255,255,255,.25); color: #fff; border-radius: 100px; padding: 3px 12px; font-size: .72rem; font-weight: 800; }
.co-card-gradient .co-card-body { padding: 18px 22px; flex: 1; display: flex; flex-direction: column; }
.co-card-gradient .co-card-footer--gradient { background: rgba(0,0,0,.28); padding: 12px 18px; display: flex; align-items: center; justify-content: space-between; color: #fff; font-size: .85rem; font-weight: 700; margin-top: auto; }
.co-card-gradient .co-card-footer { background: rgba(0,0,0,.28); padding: 12px 22px; display: flex; align-items: center; justify-content: space-between; color: #fff; font-size: .85rem; font-weight: 700; margin-top: auto; }
.co-card-gradient .co-brand { font-family: 'Fraunces', serif; font-size: 1.1rem; font-weight: 700; opacity: .85; }

/* CARD LIGHT - Rusalii */
.co-card-light { background: var(--c-bg-card); }
.co-card-light .co-card-top { padding: 18px 20px 12px; }
.co-eyebrow--teal { font-size: .85rem; font-weight: 700; color: var(--c-purple-text); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 4px; }
.co-castalia-badge { font-size: .8rem; font-weight: 700; color: var(--c-teal); margin-bottom: 4px; }
.co-card-title--rusalii { font-family: 'Fraunces', serif; font-size: 2rem; font-weight: 700; color: var(--c-magenta); line-height: 1; margin-bottom: 8px; }
.co-badge--teal { display: inline-block; background: var(--c-teal); color: #fff; border-radius: 100px; padding: 3px 12px; font-size: .72rem; font-weight: 800; }
.co-card-light .co-card-body { padding: 12px 20px; flex: 1; display: flex; flex-direction: column; }
.co-card-light .co-card-footer--light { background: var(--c-purple); padding: 12px 20px; display: flex; align-items: center; justify-content: space-between; color: rgba(255,255,255,.8); font-size: .82rem; font-weight: 600; margin-top: auto; }
.co-card-light .co-card-footer--light strong { color: #fff; font-weight: 800; }

/* COMUNE */
.co-dates { font-size: .82rem; font-weight: 600; color: rgba(255,255,255,.75); margin-bottom: 12px; }
.co-dates--dark { color: var(--c-purple-soft); }

.co-features { list-style: none; margin: 0 0 14px; padding: 0; }
.co-features li { font-size: .85rem; color: rgba(255,255,255,.88); margin-bottom: 8px; line-height: 1.4; display: flex; gap: 6px; }
.co-features li strong { color: #fff; font-weight: 800; }
.co-features--dark li { color: var(--c-purple-text); }
.co-features--dark li strong { color: var(--c-dark-text); }

.co-pricing-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: auto; padding-top: 14px; }
.co-price-item { flex: 1; background: rgba(0,0,0,.18); border-radius: 10px; padding: 10px 12px; }
.co-price-lbl { font-size: .72rem; color: rgba(255,255,255,.7); font-weight: 600; margin-bottom: 2px; }
.co-price-val { font-family: 'Fraunces', serif; font-size: 1.1rem; font-weight: 700; color: #fff; }
.co-price-val span { font-size: .65rem; opacity: .7; font-weight: 400; font-family: 'Nunito', sans-serif; }

.co-price-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.co-price-table td { font-size: .75rem; padding: 5px 4px; border-bottom: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.85); font-family: 'Nunito', sans-serif; }
.co-price-table td strong { color: #fff; font-weight: 800; }
.co-price-table tr:last-child td { border-bottom: none; }

.co-price-box-light { background: rgba(from var(--c-teal) r g b / .08); border-radius: 12px; padding: 12px 14px; margin-top: 10px; }
.co-price-box-row { display: flex; justify-content: space-between; padding: 5px 0; border-bottom: 1px solid rgba(from var(--c-purple) r g b / .08); font-size: .8rem; font-family: 'Nunito', sans-serif; }
.co-price-box-row:last-child { border-bottom: none; }
.co-price-box-row span { color: var(--c-purple-text); font-weight: 600; }
.co-price-box-row strong { color: var(--c-teal-dark); font-weight: 800; }

@media (max-width: 900px) {
  .co-grid { grid-template-columns: 1fr; }
  .co-section > h2 { font-size: 1.8rem; }
}

.e-gallery-masonry .e-gallery-image{
    border-radius: 30px;
}

/* ═══════════════════════════════
   EXCURSII
═══════════════════════════════ */

.cs-excursie-badge {
  display: inline-block;
  background: linear-gradient(135deg, var(--c-teal), var(--c-teal-dark));
  color: #fff;
  border-radius: 100px;
  padding: 3px 14px;
  font-family: 'Nunito', sans-serif;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  margin-bottom: 10px;
}

.cs-excursie-badge--light {
  background: rgba(255,255,255,.25);
}

.cs-excursie-badge--dark {
  background: linear-gradient(135deg, var(--c-magenta), var(--c-magenta-dark));
}

.cs-excursie-pret {
  margin-top: 16px;
  font-family: 'Fraunces', serif;
  font-size: 2rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cs-excursie-pret span {
  font-family: 'Nunito', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  -webkit-text-fill-color: var(--c-purple-soft);
}

.cs-excursie-pret--light {
  background: none;
  -webkit-text-fill-color: var(--c-mint);
  color: var(--c-mint);
}

.cs-excursie-pret--light span {
  -webkit-text-fill-color: rgba(255,255,255,.6);
}

.cs-excursie-pret--featured {
  font-family: 'Fraunces', serif;
  font-size: 2rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
  flex-shrink: 0;
}

.cs-excursie-pret--featured span {
  font-family: 'Nunito', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  -webkit-text-fill-color: var(--c-purple-soft);
}

/* TRASEU 4 - full width */
.cs-excursie-traseu4 {
  max-width: 1200px;
  margin: 22px auto 0;
  background: #ffffff;
  border-radius: 22px;
  padding: 28px 32px;
  box-shadow: 0 4px 24px rgba(from var(--c-purple) r g b / .08);
  border: 2px solid transparent;
  display: flex;
  align-items: center;
  gap: 24px;
  text-align: left;
  transition: all .3s;
}

.cs-excursie-traseu4:hover {
  border-color: rgba(from var(--c-teal) r g b / .2);
  box-shadow: 0 12px 40px rgba(from var(--c-purple) r g b / .14);
  transform: translateY(-2px);
}

.cs-excursie-t4-content {
  flex: 1;
}

.cs-excursie-t4-content h3 {
  margin-bottom: 8px;
}

.cs-excursie-t4-content p {
  font-family: 'Nunito', sans-serif;
  font-size: .88rem;
  color: var(--c-purple-text);
  line-height: 1.6;
  font-weight: 600;
}

/* NOTE */
.cs-excursie-note {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  max-width: 1200px;
  margin: 28px auto 0;
}

@media (max-width: 768px) {
  .cs-excursie-traseu4 {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .cs-excursie-note {
    flex-direction: column;
  }
}

/* grid 4 coloane excursii */
.cs-excursii-grid4 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
    max-width: 1200px;
    margin: 0 auto;
    text-align: left;
  }
@media (max-width: 600px) {
    .cs-excursii-grid4 { grid-template-columns: 1fr; }
  }


/* ═══════════════════════════════
   EXCURSII
═══════════════════════════════ */

.cs-excursie-badge {
  display: inline-block;
  background: linear-gradient(135deg, var(--c-teal), var(--c-teal-dark));
  color: #fff;
  border-radius: 100px;
  padding: 3px 14px;
  font-family: 'Nunito', sans-serif;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  margin-bottom: 10px;
}

.cs-excursie-badge--light {
  background: rgba(255,255,255,.25);
}

.cs-excursie-badge--dark {
  background: linear-gradient(135deg, var(--c-magenta), var(--c-magenta-dark));
}

.cs-excursie-pret {
  margin-top: 16px;
  font-family: 'Fraunces', serif;
  font-size: 2rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cs-excursie-pret span {
  font-family: 'Nunito', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  -webkit-text-fill-color: var(--c-purple-soft);
}

.cs-excursie-pret--light {
  background: none;
  -webkit-text-fill-color: var(--c-mint);
  color: var(--c-mint);
}

.cs-excursie-pret--light span {
  -webkit-text-fill-color: rgba(255,255,255,.6);
}

.cs-excursie-pret--featured {
  font-family: 'Fraunces', serif;
  font-size: 2rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--c-teal), var(--c-magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
  flex-shrink: 0;
}

.cs-excursie-pret--featured span {
  font-family: 'Nunito', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  -webkit-text-fill-color: var(--c-purple-soft);
}

/* TRASEU 4 - full width */
.cs-excursie-traseu4 {
  max-width: 1200px;
  margin: 22px auto 0;
  background: #ffffff;
  border-radius: 22px;
  padding: 28px 32px;
  box-shadow: 0 4px 24px rgba(from var(--c-purple) r g b / .08);
  border: 2px solid transparent;
  display: flex;
  align-items: center;
  gap: 24px;
  text-align: left;
  transition: all .3s;
}

.cs-excursie-traseu4:hover {
  border-color: rgba(from var(--c-teal) r g b / .2);
  box-shadow: 0 12px 40px rgba(from var(--c-purple) r g b / .14);
  transform: translateY(-2px);
}

.cs-excursie-t4-content {
  flex: 1;
}

.cs-excursie-t4-content h3 {
  margin-bottom: 8px;
}

.cs-excursie-t4-content p {
  font-family: 'Nunito', sans-serif;
  font-size: .88rem;
  color: var(--c-purple-text);
  line-height: 1.6;
  font-weight: 600;
}

/* NOTE */
.cs-excursie-note {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  max-width: 1200px;
  margin: 28px auto 0;
}

@media (max-width: 768px) {
  .cs-excursie-traseu4 {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .cs-excursie-note {
    flex-direction: column;
  }
}



/* grid agrement - 3 coloane */
.cs-agrement-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 900px;
  margin: 0 auto;
  text-align: left;
}

@media (max-width: 600px) {
  .cs-agrement-grid { grid-template-columns: 1fr; }
}



/* ═══════════════════════════════
   PROMO BANNER
═══════════════════════════════ */

.cs-promo-banner {
  background: linear-gradient(160deg, var(--c-blue-deep) 0%, var(--c-blue-dark) 50%, var(--c-blue) 100%);
  border-radius: 22px;
  padding: 36px 40px;
  text-align: center;
  max-width: 900px;
  margin: 0 auto 40px;
  box-shadow: 0 16px 50px rgba(from var(--c-blue-dark) r g b / .4);
  position: relative;
  overflow: hidden;
}

.cs-promo-banner::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
}

.cs-promo-banner::after {
  content: '';
  position: absolute;
  bottom: -40px; left: -40px;
  width: 150px; height: 150px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
}

.cs-promo-badge {
  display: inline-block;
  background: rgba(255,255,255,.18);
  color: #fff;
  border-radius: 100px;
  padding: 4px 16px;
  font-family: 'Nunito', sans-serif;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}

.cs-promo-title {
  font-family: 'Fraunces', serif;
  font-size: 2.8rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
  margin-bottom: 6px;
  position: relative;
  z-index: 1;
}

.cs-promo-sub {
  font-family: 'Nunito', sans-serif;
  font-size: .9rem;
  color: rgba(255,255,255,.7);
  font-weight: 600;
  margin-bottom: 28px;
  position: relative;
  z-index: 1;
}

.cs-promo-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 28px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.cs-promo-item {
  padding: 0 32px;
  text-align: center;
}

.cs-promo-lbl {
  font-family: 'Nunito', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  color: rgba(255,255,255,.7);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.cs-promo-pret {
  font-family: 'Fraunces', serif;
  font-size: 2rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
}

.cs-promo-pret span {
  font-family: 'Nunito', sans-serif;
  font-size: .75rem;
  font-weight: 600;
  color: rgba(255,255,255,.65);
  margin-left: 2px;
}

.cs-promo-divider {
  width: 1px;
  height: 50px;
  background: rgba(255,255,255,.2);
  flex-shrink: 0;
}

.cs-promo-banner .cs-btn-primary {
  position: relative;
  z-index: 1;
  background: #ffffff;
  color: var(--c-blue-deep) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
}

.cs-promo-banner .cs-btn-primary:hover {
  background: #f0f0f0;
  box-shadow: 0 12px 30px rgba(0,0,0,.3);
}

@media (max-width: 600px) {
  .cs-promo-banner { padding: 28px 20px; }
  .cs-promo-title { font-size: 2rem; }
  .cs-promo-grid { flex-direction: column; gap: 16px; }
  .cs-promo-divider { width: 60px; height: 1px; }
  .cs-promo-item { padding: 0; }
}


/* ═══════════════════════════════
   CONTACT INFO
═══════════════════════════════ */
.cs-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: left;
}

.cs-contact-text {
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  color: var(--c-purple-text);
  line-height: 1.8;
  font-weight: 600;
}

.cs-contact-link {
  color: var(--c-teal);
  font-weight: 700;
  text-decoration: none;
  transition: color .2s;
}
.cs-contact-link:hover { color: var(--c-teal-dark); }

.cs-contact-social {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

@media (max-width: 768px) {
  .cs-contact-grid { grid-template-columns: 1fr; max-width: 500px; }
}
.cs-card-acces {
    background: linear-gradient(135deg, rgba(from var(--c-blue-dark) r g b / .08), rgba(from var(--c-teal) r g b / .1));
    border: 2px solid rgba(from var(--c-blue-dark) r g b / .2) !important;
  }
  
  .cs-card-acces .cs-cc-title {
    color: var(--c-blue-dark);
  }
  
  .cs-card-acces .cs-cc-list li {
    color: var(--c-dark-text);
    border-bottom-color: rgba(from var(--c-blue-dark) r g b / .1);
  }
  
  .cs-card-acces .cs-cc-list li span {
    color: var(--c-purple-text);
  }
  
  .cs-card-acces .cs-cc-list li strong {
    color: var(--c-blue-dark);
  }
  
 .cs-maps-btn {
     display: inline-block;
     margin-top: 14px;
     padding: 9px 18px;
     background: rgba(from var(--c-blue-dark) r g b / .08);
     border: 1.5px solid rgba(from var(--c-blue-dark) r g b / .2);
     border-radius: 100px;
     font-family: 'Nunito', sans-serif;
     font-size: .82rem;
     font-weight: 700;
     color: var(--c-blue-dark);
     text-decoration: none;
     transition: all .2s;
   }
   .cs-maps-btn:hover {
     background: rgba(from var(--c-blue-dark) r g b / .15);
     transform: translateY(-2px);
   }
   
   /* ═══════════════════════════════
   PROMO BANNER
═══════════════════════════════ */

.cs-promo-banner {
  background: linear-gradient(160deg, var(--c-blue-deep) 0%, var(--c-blue-dark) 50%, var(--c-blue) 100%);
  border-radius: 22px;
  padding: 36px 40px;
  text-align: center;
  max-width: 900px;
  margin: 0 auto 40px;
  box-shadow: 0 16px 50px rgba(from var(--c-blue-dark) r g b / .4);
  position: relative;
  overflow: hidden;
}

.cs-promo-banner::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
}

.cs-promo-banner::after {
  content: '';
  position: absolute;
  bottom: -40px; left: -40px;
  width: 150px; height: 150px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
}

.cs-promo-badge {
  display: inline-block;
  background: rgba(255,255,255,.18);
  color: #fff;
  border-radius: 100px;
  padding: 4px 16px;
  font-family: 'Nunito', sans-serif;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}

.cs-promo-title {
  font-family: 'Fraunces', serif;
  font-size: 2.8rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
  margin-bottom: 6px;
  position: relative;
  z-index: 1;
}

.cs-promo-sub {
  font-family: 'Nunito', sans-serif;
  font-size: .9rem;
  color: rgba(255,255,255,.7);
  font-weight: 600;
  margin-bottom: 28px;
  position: relative;
  z-index: 1;
}

.cs-promo-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 28px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.cs-promo-item {
  padding: 0 32px;
  text-align: center;
}

.cs-promo-lbl {
  font-family: 'Nunito', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  color: rgba(255,255,255,.7);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.cs-promo-pret {
  font-family: 'Fraunces', serif;
  font-size: 2rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
}

.cs-promo-pret span {
  font-family: 'Nunito', sans-serif;
  font-size: .75rem;
  font-weight: 600;
  color: rgba(255,255,255,.65);
  margin-left: 2px;
}

.cs-promo-divider {
  width: 1px;
  height: 50px;
  background: rgba(255,255,255,.2);
  flex-shrink: 0;
}

.cs-promo-banner .cs-btn-primary {
  position: relative;
  z-index: 1;
  background: #ffffff;
  color: var(--c-blue-deep) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
}

.cs-promo-banner .cs-btn-primary:hover {
  background: #f0f0f0;
  box-shadow: 0 12px 30px rgba(0,0,0,.3);
}

@media (max-width: 600px) {
  .cs-promo-banner { padding: 28px 20px; }
  .cs-promo-title { font-size: 2rem; }
  .cs-promo-grid { flex-direction: column; gap: 16px; }
  .cs-promo-divider { width: 60px; height: 1px; }
  .cs-promo-item { padding: 0; }
}

/* ═══════════════════════════════
   CONTACT INFO
═══════════════════════════════ */
.cs-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: left;
}

.cs-contact-text {
  font-family: 'Nunito', sans-serif;
  font-size: .92rem;
  color: var(--c-purple-text);
  line-height: 1.8;
  font-weight: 600;
}

.cs-contact-link {
  color: var(--c-teal);
  font-weight: 700;
  text-decoration: none;
  transition: color .2s;
}
.cs-contact-link:hover { color: var(--c-teal-dark); }

.cs-contact-social {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

@media (max-width: 768px) {
  .cs-contact-grid { grid-template-columns: 1fr; max-width: 500px; }
}

/* ═══════════════════════════════
   REGIM MASA - pret box
═══════════════════════════════ */
.cs-masa-pret-box {
  background: rgba(from var(--c-teal) r g b / .07);
  border-radius: 12px;
  padding: 12px 14px;
  margin-top: 16px;
}

.cs-masa-pret-box--light {
  background: rgba(255,255,255,.15);
}

.cs-masa-pret-row {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  border-bottom: 1px solid rgba(from var(--c-purple) r g b / .08);
  font-family: 'Nunito', sans-serif;
  font-size: .85rem;
}

.cs-masa-pret-row:last-child { border-bottom: none; }
.cs-masa-pret-row span { color: var(--c-purple-text); font-weight: 600; }
.cs-masa-pret-row strong { color: var(--c-teal-dark); font-weight: 800; }

.cs-masa-pret-box--light .cs-masa-pret-row { border-bottom-color: rgba(255,255,255,.15);color:white; }
.cs-masa-pret-box--light .cs-masa-pret-row span { color: rgba(255,255,255,.8); }
.cs-masa-pret-box--light .cs-masa-pret-row strong { color: var(--c-mint); }

.cs-masa-pret-box--light .cs-masa-pret-row span {
  color: rgba(255,255,255,.9) !important;
  font-weight: 700 !important;
}
.cs-masa-pret-box--light .cs-masa-pret-row strong {
  color: #ffffff !important;
  font-weight: 900 !important;
}
.cs-masa-pret-box--light .cs-masa-pret-row {
  border-bottom-color: rgba(255,255,255,.2) !important;
}

/* ===== RUSALII 2026 – card violet/purple ===== */
.co-card-purple .co-card-top,
.co-card-purple .co-card-body {
  padding-left: 24px;
  padding-right: 24px;
}

.co-card-purple .co-card-top {
  padding-top: 24px;
  padding-bottom: 16px;
}

.co-card-purple .co-card-body {
  padding-bottom: 20px;
}
.co-card-purple {
  background: linear-gradient(160deg, var(--c-purple-dark) 0%, var(--c-purple) 50%, var(--c-purple) 100%);
  color: #fff;
  border: none;
  display: flex;
  flex-direction: column;
}
.co-card-purple .co-card-body {
    flex: 1;
  }

.co-card-purple .co-eyebrow {
  color: rgba(255,255,255,.75);
  letter-spacing: .12em;
}

.co-card-purple .co-castalia-badge--light {
  color: var(--c-purple-bg);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .08em;
}

.co-card-purple .co-card-title {
  color: #fff;
}

.co-card-purple .co-badge {
  background: rgba(255,255,255,.2);
  color: #fff;
  border: 1px solid rgba(255,255,255,.35);
}

.co-card-purple .co-dates {
  color: rgba(255,255,255,.85);
}

.co-card-purple .co-features li {
  color: rgba(255,255,255,.92);
}

.co-card-purple .co-features strong {
  color: #fff;
}

.co-card-purple .co-pricing-row {
  background: rgba(0,0,0,.25);
  border-radius: 10px;
  padding: 14px 16px;
  margin-top: 16px;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.co-card-purple .co-price-item {
  flex: 1;
  text-align: center;
}

.co-card-purple .co-price-lbl {
  color: rgba(255,255,255,.75);
  font-size: .72rem;
  margin-bottom: 4px;
}

.co-card-purple .co-price-val {
  color: #fff;
  font-size: 1.15rem;
  font-weight: 800;
}

.co-card-footer--purple {
  background: rgba(0,0,0,.3);
  color: rgba(255,255,255,.9);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  font-size: .85rem;
  border-top: 1px solid rgba(255,255,255,.15);
}

.co-card-footer--purple strong {
  color: #fff;
}

/* ═══════════════════════════════════════════════════
   RESTAURANT — Carduri mini Demipensiune / Pensiune completă
   ═══════════════════════════════════════════════════ */

.cs-masa-mini-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
}

.cs-masa-mini-card {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 12px;
  padding: 14px 16px;
}

.cs-masa-mini-title {
  font-family: 'Fraunces', serif;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 6px;
}

.cs-masa-mini-desc {
  font-size: .82rem;
  color: rgba(255,255,255,.75);
  line-height: 1.5;
  margin: 0 0 10px;
}

.cs-masa-mini-pret {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cs-masa-mini-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .83rem;
  padding: 4px 0;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.cs-masa-mini-row:last-child {
  border-bottom: none;
}

.cs-masa-mini-row span {
  color: rgba(255,255,255,.8);
}

.cs-masa-mini-row strong {
  color: #fff;
  font-weight: 800;
}

/* ═══════════════════════════════════════════════════
   RESTAURANT — Secțiunea Informații utile pentru oaspeți
   ═══════════════════════════════════════════════════ */

.cs-info-oaspeti {
  background: var(--c-bg);
  padding: 40px 30px 50px;
  font-family: 'Nunito', sans-serif;
}

.cs-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  max-width: 960px;
  margin: 0 auto 32px;
}

@media (max-width: 700px) {
  .cs-info-grid { grid-template-columns: 1fr; }
}

.cs-info-block {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cs-info-block p {
  font-size: .95rem;
  line-height: 1.7;
  color: var(--c-dark-text);
  margin: 0;
}

.cs-info-nota {
  background: rgba(from var(--c-teal) r g b / .08);
  border-left: 3px solid var(--c-teal);
  border-radius: 0 8px 8px 0;
  padding: 10px 14px !important;
  font-style: italic;
  font-size: .88rem !important;
  color: var(--c-blue-deep) !important;
}

.cs-ore-card {
  background: var(--c-blue);
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 16px;
}

.cs-ore-title {
  font-family: 'Fraunces', serif;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 14px;
}

.cs-ore-list {
  list-style: none;
  padding: 0;
  margin: 0 0 10px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cs-ore-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.15);
}

.cs-ore-list li:last-child {
  border-bottom: none;
}

.cs-ore-masa {
  font-weight: 700;
  color: rgba(255,255,255,.9);
  font-size: .9rem;
}

.cs-ore-interval {
  color: #fff;
  font-weight: 800;
  font-size: .9rem;
}

.cs-ore-nota {
  font-size: .78rem;
  color: rgba(255,255,255,.65);
  font-style: italic;
  margin: 0;
}

.cs-info-exterior {
  background: #fff;
  border: 1px solid rgba(from var(--c-blue) r g b / .15);
  border-radius: 16px;
  padding: 24px 28px;
  max-width: 960px;
  margin: 0 auto;
  text-align: center;
}

.cs-info-exterior .cs-cc-icon {
  font-size: 2rem;
  margin-bottom: 10px;
}

.cs-info-ext-title {
  font-family: 'Fraunces', serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--c-blue-deep);
  margin: 0 0 12px;
}

.cs-info-exterior p {
  font-size: .95rem;
  line-height: 1.7;
  color: var(--c-dark-text);
  margin: 0 0 8px;
}

.cs-info-exterior p:last-child {
  margin: 0;
}

/* ═══════════════════════════════
   CLASA NOUA - cs-card-blue
   (inlocuieste cs-card-teal cu --c-blue)
═══════════════════════════════ */
.cs-card-blue {
  background: var(--c-blue) !important;
  border-color: transparent !important;
  box-shadow: 0 12px 40px rgba(from var(--c-blue-dark) r g b / .35) !important;
}
.cs-card-blue::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--c-title-em-1), var(--c-blue-dark));
  opacity: 1;
}
.cs-card-blue .cs-cc-title {
  color: #ffffff !important;
}
.cs-card-blue .cs-cc-desc {
  color: rgba(255,255,255,.85) !important;
}
.cs-card-blue .cs-cc-list li {
  color: rgba(255,255,255,.92) !important;
  border-bottom-color: rgba(255,255,255,.15) !important;
}
.cs-card-blue .cs-cc-list li span {
  color: rgba(255,255,255,.92) !important;
}
.cs-card-blue .cs-cc-list li strong {
  color: #ffffff !important;
}

/* Note inline sub tarifele camerelor */
.cs-tarife-notes--inline {
  margin: 0 0 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}


/* ═══════════════════════════════════════════════════
   PRINT — păstrează culorile și stilurile la Ctrl+P
   ═══════════════════════════════════════════════════ */
@media print {
  * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }

  /* Ascunde bara WordPress admin și elementele inutile */
  #wpadminbar,
  .cs-marquee,
  .elementor-edit-mode,
  #gdpr-cookie-notice,
  .pum-overlay {
    display: none !important;
  }

  /* Header fix la print */
  .cs-header {
    position: relative !important;
  }

  /* Evită tăierea cardurilor între pagini */
  .co-card,
  .cs-complex-card,
  .cs-tarife-card,
  .cs-politici-card,
  .cs-promo-banner,
  .cs-info-exterior,
  .cs-ore-card {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  /* Evită tăierea secțiunilor */
  .co-section,
  .cs-complex,
  .cs-info-oaspeti {
    break-before: auto;
    page-break-before: auto;
  }
}