/* --- REGULILE @FONT-FACE PENTRU FONTURILE LOCALE --- */
/*
   ATENȚIE: ASIGURĂ-TE CĂ FOLDERELE ȘI NUMELE FIȘIERELOR DE FONTURI SUNT CORECTE PE SERVERUL TĂU,
   CONFORM CU CE AI DESCARCAT DE LA GOOGLE WEBFONTS HELPER ȘI AI PUS ÎN FOLDERUL 'fonts/'
   (ex: 'open-sans-v43-latin_latin-ext-regular.woff2' etc.)
*/
/* open-sans-regular - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/open-sans-v43-latin_latin-ext-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/open-sans-v43-latin_latin-ext-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-700 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/open-sans-v43-latin_latin-ext-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* playfair-display-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/playfair-display-v39-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-700 - latin */
@font-face {
  font-display: swap;
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/playfair-display-v39-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* --- SFÂRȘIT REGULI @FONT-FACE --- */


/* Definirea variabilelor CSS pentru culori */
:root {
    --primary-dark-anthracite: #222222; /* Negru antracit, mat, profund */
    --primary-rich-gold: #B8860B; /* Auriu bogat, clasic, luxos */
    --secondary-warm-beige: #FDF7E7; /* Bej cald, luminos, pentru fundaluri de conținut */
    --accent-terracotta: #C6765A; /* Teracotă/maro ruginiu, pentru căldură și accente spirituale */
    --text-light: #F0F0F0; /* Gri foarte deschis, aproape alb, pentru text pe fundal închis */
    --text-dark: #333333; /* Gri închis, pentru text pe fundal deschis */
    --light-section-bg: #FAFAFA; /* Un alb foarte ușor pentru secțiuni alternate */
    --text-medium: #555555; /* Gri mediu pentru descrieri */

    /* Variabile pentru umbre, pentru consistență și ajustări ușoare */
    --shadow-subtle: 0 4px 15px rgba(0, 0, 0, 0.07); /* Umbră ușoară */
    --shadow-hover: 0 8px 25px rgba(0, 0, 0, 0.12); /* Umbră mai pronunțată la hover */
}

/* Stiluri de bază și resetare */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Open Sans', sans-serif;
    line-height: 1.7; /* Am mărit puțin line-height pentru lizibilitate și aerisire */
    background-color: var(--secondary-warm-beige);
    color: var(--text-dark);
    /* Adăugăm padding-top pentru a compensa înălțimea headerului fix */
    padding-top: 89px; /* Valoare calculată din înălțimea logo-ului și padding-ul headerului */
}

/* Stiluri pentru antet (header) */
header {
    background-color: var(--primary-dark-anthracite);
    color: var(--text-light);
    padding: 1.2rem 0;
    box-shadow: 0 3px 8px rgba(0,0,0,0.4);
    position: fixed; /* Fixează header-ul în viewport */
    top: 0; /* Aliniază-l la partea de sus */
    width: 100%; /* Ocupă toată lățimea */
    z-index: 1000; /* Asigură că rămâne deasupra altor elemente */
    box-shadow: 0 2px 10px rgba(0,0,0,0.2); /* Umbră subtilă pentru a-l face să iasă în evidență */
}

nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 25px;
}

.logo {
    font-size: 0;
}

.logo a {
    display: flex;
    align-items: center;
}

.logo img.site-logo {
    max-height: 65px;
    width: auto;
    display: block;
}

nav ul {
    list-style: none;
    display: flex;
}

nav ul li {
    margin-left: 30px;
}

nav ul li a {
    color: var(--text-light);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.3s ease, transform 0.2s ease;
    font-family: 'Open Sans', sans-serif;
}

nav ul li a:hover {
    color: var(--primary-rich-gold);
    transform: translateY(-2px);
}

/* Stiluri pentru butoanele CTA */
.btn-cta {
    background-color: var(--primary-rich-gold);
    color: var(--primary-dark-anthracite) !important;
    padding: 12px 25px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.2s ease, box-shadow 0.3s ease;
    display: inline-block;
    font-family: 'Open Sans', sans-serif;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
    text-align: center;
}

.btn-cta:hover {
    background-color: #D4AF37;
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    color: var(--primary-dark-anthracite) !important;
}

.btn-cta.secondary-btn {
    background-color: var(--text-medium);
    color: var(--text-light) !important;
    border: 1px solid var(--text-medium);
}

.btn-cta.secondary-btn:hover {
    background-color: var(--primary-dark-anthracite);
    border-color: var(--primary-dark-anthracite);
}

.btn-cta.large {
    padding: 18px 35px;
    font-size: 1.3rem;
    margin-top: 25px;
}

.btn-cta.small {
    padding: 9px 18px;
    font-size: 0.95rem;
}

/* Stiluri pentru secțiunea Hero (Acasă) */
#hero {
    background: linear-gradient(rgba(34, 34, 34, 0.78), rgba(50, 50, 50, 0.78)), url('imagini/hero-spiritual.jpg');
    background-size: cover;
    background-position: center;
    color: #fff;
    text-align: center;
    padding: 120px 25px;
    min-height: 550px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

#hero h1 {
    font-family: 'Playfair Display', serif;
    font-size: 3.8rem;
    margin-bottom: 25px;
    max-width: 900px;
    line-height: 1.2;
}

#hero p {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.6rem;
    margin-bottom: 35px;
    max-width: 750px;
    font-weight: 300;
}

/* Stiluri pentru subsol (footer) */
footer {
    background-color: var(--primary-dark-anthracite);
    color: var(--text-light);
    padding: 25px 0;
    margin-top: 60px;
    font-family: 'Open Sans', sans-serif;
}

footer .container.footer-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 15px;
}

.social-links {
    display: flex;
    gap: 15px;
}

.social-links a {
    display: block;
    line-height: 0;
    transition: transform 0.3s ease;
}

.social-links a:hover {
    transform: translateY(-3px);
}

.social-links .social-icon {
    width: 30px;
    height: 30px;
    vertical-align: middle;
}

/* Stiluri generale pentru secțiunile de conținut */
.page-header {
    background-color: var(--light-section-bg);
    padding: 70px 25px;
    text-align: center;
    margin-bottom: 50px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: var(--text-light);
    padding: 100px 25px;
    min-height: 250px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.page-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(rgba(34, 34, 34, 0.5), rgba(50, 50, 50, 0.5)); /* Opacitate setată la 0.5 */
    z-index: 1;
}
/* Text Shadow mai puternic pentru lizibilitate */
.page-header h1,
.page-header p {
    position: relative;
    z-index: 2;
    color: var(--text-light);
    text-shadow: 0 0 8px rgba(0,0,0,0.8), 0 0 15px rgba(0,0,0,0.6); /* Umbră mai puternică și mai difuză */
}


/* Stiluri specifice pentru fiecare antet de pagină */
.page-header.despre {
    background-image: url('imagini/headers/header-despre.jpg');
}

.page-header.servicii {
    background-image: url('imagini/headers/header-servicii.jpg');
}

.page-header.contact {
    background-image: url('imagini/headers/header-contact.jpg');
}

.page-header.blog-listing {
    background-image: url('imagini/headers/header-blog.jpg');
}

.page-header.blog-post {
    background-image: url('imagini/headers/header-blog-post.jpg');
}

.page-header.evenimente {
    background-image: url('imagini/headers/header-evenimente.jpg');
}

.page-header.faq {
    background-image: url('imagini/headers/header-faq.jpg');
}

.page-header.galerie {
    background-image: url('imagini/headers/header-galerie.jpg');
}

.page-header.legal {
    background-image: url('imagini/headers/header-legal.jpg');
}


.content-section {
    padding: 60px 0;
}

.content-section.light-bg {
    background-color: var(--light-section-bg);
}

.content-section .container {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 25px;
    /* Asigurăm o singură coloană, lată și centrată, pentru toate secțiunile de conținut principale */
    display: flex;
    flex-direction: column; /* Asigură că itemele stau una sub alta */
    align-items: center; /* Centrează blocurile pe orizontală */
    gap: 50px; /* Spațiu între blocurile de conținut */
    flex-wrap: wrap; /* Păstrează pentru siguranță, chiar dacă e pe o singură coloană */
    justify-content: center; /* Păstrează justify-content */
}

.section-title {
    font-family: 'Playfair Display', serif;
    font-size: 2.8rem;
    color: var(--primary-dark-anthracite);
    text-align: center;
    margin-bottom: 25px;
    position: relative;
    width: 100%;
}

.section-title::after {
    content: '';
    display: block;
    width: 80px;
    height: 5px;
    background-color: var(--primary-rich-gold);
    margin: 18px auto 0;
}

.section-description {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.25rem;
    color: var(--text-medium);
    text-align: center;
    max-width: 750px;
    margin: 0 auto 50px;
    width: 100%;
    line-height: 1.7;
}

/* Stiluri pentru secțiunea Despre Mine (index.html) */
#about .container {
    /* Centrare orizontală pentru întreg blocul #about-content */
    display: flex;
    flex-direction: column;
    align-items: center; /* Centrează orizontal conținutul flexbox pe coloană */
    text-align: center;
}

#about .about-content {
    display: flex;
    flex-direction: row;
    gap: 50px;
    align-items: flex-start;
    text-align: left;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 auto;
    max-width: 900px;
}


#about p {
    margin-bottom: 35px;
    font-size: 1.15rem;
    max-width: 750px;
    line-height: 1.7;
}

/* Stil pentru imaginea din secțiunea About de pe index.html */
#about .about-content .about-image {
    max-width: 450px; /* Am mărit de la 350px la 450px */
    height: auto;
    border-radius: 8px;
    box-shadow: var(--shadow-subtle);
    flex-shrink: 0;
}
/* Re-ajustare Responsive pentru secțiunea About de pe index.html */
@media (max-width: 768px) {
    #about .about-content {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    #about .about-content .about-image {
        margin-bottom: 20px;
    }
}


/* Stiluri pentru grila de servicii principale (index.html) */
/* Aceasta este grila de pe pagina HOME, care arată 3 servicii */
.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 35px;
    margin-top: 25px;
    width: 100%;
}

.service-card {
    background-color: #fff;
    padding: 30px; /* Ajustat de la 35px la 30px */
    border-radius: 12px;
    box-shadow: var(--shadow-subtle);
    border: 1px solid rgba(0,0,0,0.1); /* Nou: bordură subtilă default */
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; /* Adaugă border-color la tranziție */
}

.service-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-hover);
    border-color: var(--primary-rich-gold); /* Nou: adaugă culoare la border la hover */
}

.service-card h3 {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    color: var(--primary-dark-anthracite);
    margin-bottom: 15px; /* Ajustat de la 18px la 15px */
    display: flex;
    align-items: center;
}

.service-card p {
    font-family: 'Open Sans', sans-serif;
    color: var(--text-dark);
    margin-bottom: 20px; /* Ajustat de la 30px la 20px */
    line-height: 1.7;
}

/* Stiluri pentru grila "De Ce Să Mă Alegi" (index.html) */
.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 35px;
    margin-top: 25px;
    width: 100%;
}

.feature-item {
    background-color: #fff;
    padding: 35px;
    border-radius: 12px;
    box-shadow: var(--shadow-subtle);
    border-top: 6px solid var(--primary-rich-gold);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.feature-item:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-hover);
}

.feature-item h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    color: var(--primary-dark-anthracite);
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.feature-item p {
    font-family: 'Open Sans', sans-serif;
    color: var(--text-medium);
    line-height: 1.7;
}

.feature-item .feature-icon {
    width: 45px;
    height: 45px;
    margin-right: 15px;
    filter: invert(50%) sepia(80%) saturate(600%) hue-rotate(0deg) brightness(90%) contrast(100%);
}


/* Stiluri pentru Testimoniale (index.html) */
.testimonial-slider {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 35px;
    padding-bottom: 25px;
    margin-top: 25px;
    width: 100%;
}

.testimonial-item {
    flex: 0 0 480px;
    scroll-snap-align: start;
    background-color: #fff;
    padding: 40px;
    border-radius: 12px;
    box-shadow: var(--shadow-subtle);
    border-left: 6px solid var(--primary-rich-gold);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.testimonial-item:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-hover);
}

.testimonial-item .quote {
    font-family: 'Open Sans', sans-serif;
    font-style: italic;
    font-size: 1.25rem;
    color: var(--text-dark);
    margin-bottom: 20px;
    line-height: 1.8;
}

.testimonial-item .author {
    font-family: 'Open Sans', sans-serif;
    font-weight: bold;
    color: var(--primary-dark-anthracite);
    text-align: right;
    margin-top: 15px;
}

/* Stiluri pentru formularul de Contact Rapid (index.html) */
.quick-contact-form {
    max-width: 650px;
    margin: 25px auto 0;
    background-color: #fff;
    padding: 45px;
    border-radius: 12px;
    box-shadow: var(--shadow-subtle);
    width: 100%;
}

.quick-contact-form .form-group {
    margin-bottom: 25px;
}

.quick-contact-form label {
    display: block;
    margin-bottom: 10px;
    font-weight: 600;
    color: var(--text-dark);
    font-family: 'Open Sans', sans-serif;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
    width: calc(100% - 28px);
    padding: 14px;
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: 10px;
    font-size: 1.05rem;
    color: var(--text-dark);
    background-color: var(--light-section-bg);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
    font-family: 'Open Sans', sans-serif;
}

.form-group input[type="text"]:focus,
.form-group input[type="email"]:focus,
.form-group input[type="tel"]:focus,
.form-group textarea:focus {
    border-color: var(--primary-rich-gold);
    box-shadow: 0 0 0 4px rgba(184, 134, 11, 0.3);
    outline: none;
}

.form-group textarea {
    resize: vertical;
    min-height: 140px;
}

.contact-form .btn-cta {
    display: block;
    width: 100%;
    padding: 18px 20px;
    font-size: 1.3rem;
    font-weight: bold;
    border: none;
    cursor: pointer;
    margin-top: 20px;
    font-family: 'Open Sans', sans-serif;
}

.form-note {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.95em;
    color: var(--text-medium);
    margin-top: 25px;
    text-align: center;
    font-style: italic;
}


/* Stiluri specifice pentru pagina Servicii */
#services-list .container {
    display: grid; /* Schimbăm în grid */
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); /* Două coloane pe desktop */
    gap: 35px; /* Spațiu între carduri */
    max-width: 1200px; /* Mărim lățimea maximă a containerului */
    margin: 0 auto;
    padding: 0 25px; /* Păstrăm padding-ul lateral */
    align-items: flex-start; /* Aliniere sus pentru carduri de înălțimi diferite */
    justify-content: center; /* Centrează grila */
}

.service-item {
    background-color: #fff;
    padding: 30px; /* Ajustat de la 35px la 30px */
    border-radius: 12px;
    box-shadow: var(--shadow-subtle);
    border: 1px solid rgba(0,0,0,0.1); /* Nou: bordură subtilă default */
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; /* Adaugă border-color la tranziție */
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start; /* Păstrăm alinierea conținutului cardului */
    height: 100%; /* Important: face cardurile să ocupe toată înălțimea celulei grilei */
}

.service-item:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-hover);
    border-color: var(--primary-rich-gold); /* Nou: adaugă culoare la border la hover */
}

.service-item h3 {
    font-family: 'Playfair Display', serif;
    font-size: 2.2rem;
    color: var(--primary-dark-anthracite);
    margin-bottom: 15px; /* Ajustat de la 18px la 15px */
    display: flex;
    align-items: center;
}

.service-item h3 .service-icon {
    width: 40px;
    height: 40px;
    vertical-align: middle;
    margin-right: 15px;
    filter: invert(50%) sepia(80%) saturate(600%) hue-rotate(0deg) brightness(90%) contrast(100%);
}

.service-item p {
    flex-grow: 1; /* Face ca paragrafele să umple spațiul și să împingă butoanele jos */
    margin-bottom: 20px; /* Ajustat de la 25px la 20px */
    line-height: 1.7;
}

.price-details {
    background-color: var(--light-section-bg);
    padding: 25px;
    border-radius: 10px;
    margin-top: 20px; /* Ajustat de la 25px la 20px */
    border: 1px solid rgba(0,0,0,0.07);
}

.price-details p {
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 8px;
    font-size: 1.15rem;
    color: var(--text-dark);
}

.price-details strong {
    font-family: 'Open Sans', sans-serif;
    color: var(--primary-dark-anthracite);
}

/* Stiluri pentru Acordeonul de Pachete Economice (pagina Servicii) */
.price-details .package-toggle {
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0; /* Ajustează padding-ul pentru un aspect curat */
    border-top: 1px solid rgba(0,0,0,0.12); /* Adaugă o linie separatoare */
    margin-top: 25px; /* Spațiu deasupra */
    transition: color 0.3s ease;
    font-family: 'Playfair Display', serif; /* Aplică fontul Playfair Display */
    font-size: 1.35rem; /* Menține mărimea h4 */
    color: var(--primary-dark-anthracite); /* Culoarea textului */
    margin-bottom: 0; /* Elimină margin-bottom implicită a h4 */
    padding-bottom: 0; /* Elimină padding-bottom implicită a h4 */
}

.price-details .package-toggle:hover {
    color: var(--primary-rich-gold);
}

.price-details .package-toggle .toggle-icon {
    font-size: 1.5rem;
    font-weight: bold;
    transition: transform 0.3s ease;
    color: var(--primary-rich-gold); /* Culoare pentru iconiță */
}

.price-details .package-toggle.open .toggle-icon {
    transform: rotate(45deg); /* Rotim '+' în 'x' sau pur și simplu în '-' pentru ochi */
}

.price-details .package-list {
    list-style: none; /* Asigură că lista nu are bullet points */
    padding: 0; /* Elimină padding-ul implicit al listei */
    margin: 0; /* Elimină margin-ul implicit al listei */
    max-height: 0; /* Ascunde lista inițial */
    overflow: hidden; /* Ascunde conținutul care depășește max-height */
    transition: max-height 0.4s ease-out, opacity 0.4s ease-out, padding 0.4s ease-out; /* Animație fluidă */
    opacity: 0;
    padding: 0 0; /* Asigură că padding-ul este 0 când e închis */
}

.price-details .package-list.open {
    max-height: 500px; /* Suficient de mare pentru a arăta tot conținutul listei */
    opacity: 1;
    padding: 15px 0; /* Padding când este deschis */
}

.price-details ul li {
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 10px;
    font-size: 1.1rem;
    color: var(--text-dark);
    display: flex;
    align-items: baseline;
}

.price-details ul li strong {
    color: var(--accent-terracotta);
    font-weight: 700;
    margin-left: 8px;
}

.price-details ul li::before {
    content: '★';
    color: var(--primary-rich-gold);
    font-size: 1em;
    margin-right: 10px;
    flex-shrink: 0;
}

/* Stiluri pentru grupul de butoane din cardurile de servicii */
.service-actions {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-top: 20px; /* Ajustat de la 25px la 20px */
}

.service-actions .btn-cta {
    width: 100%;
}


/* Stiluri pentru CTA-ul de jos */
.call-to-action-bottom {
    text-align: center;
    margin-top: 60px;
    padding: 40px;
    background-color: var(--light-section-bg);
    border-radius: 12px;
    box-shadow: var(--shadow-subtle);
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

.call-to-action-bottom p {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.4rem;
    margin-bottom: 30px;
    color: var(--primary-dark-anthracite);
}

/* Stiluri specifice pentru Blog și Evenimente */
/* Acestea sunt deja setate pentru o singură coloană lată, așa cum vrei */
.blog-post-preview,
.event-item {
    background-color: #fff;
    border-radius: 10px;
    box-shadow: var(--shadow-subtle);
    padding: 35px;
    margin-bottom: 35px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    flex: 1 1 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    max-width: 700px; /* Lățime maximă pentru previzualizările de blog */
    margin-left: auto;
    margin-right: auto;
}

.blog-post-preview:hover,
.event-item:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-hover);
}

/* Stiluri pentru imaginea din previzualizarea blogului */
.blog-post-preview img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin-bottom: 20px;
    object-fit: cover;
    max-height: 200px;
    width: 100%;
}

.blog-post-preview h3,
.event-item h3 {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    color: var(--primary-dark-anthracite);
    margin-bottom: 15px;
    line-height: 1.2;
}

.blog-post-preview .post-meta,
.event-item .event-meta {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.95rem;
    color: var(--text-medium);
    margin-bottom: 20px;
    width: 100%;
}

.blog-post-preview p { /* Eliminare flex-grow: 1 de aici */
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 25px;
    color: var(--text-dark);
    line-height: 1.7;
}

.blog-post-preview .read-more {
    margin-top: auto;
}


/* Stiluri specifice pentru Pagina de Contact */
.contact-info,
.contact-form {
    /* Setări pentru a ocupa spațiu și a crește la nevoie */
    flex: 1; /* Permite-le să crească pentru a umple spațiul */
    min-width: 380px; /* NOU: Lățime minimă mai mare pentru fiecare coloană */
    padding: 40px;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 12px;
    background-color: #fff;
    box-shadow: var(--shadow-subtle);
}

.contact-info h2,
.contact-form h2 {
    font-family: 'Playfair Display', serif;
    font-size: 2.3rem;
    color: var(--primary-dark-anthracite);
    margin-bottom: 30px;
    text-align: center;
    position: relative;
    width: 100%;
}

.contact-info h2::after,
.contact-form h2::after {
    content: '';
    display: block;
    width: 70px;
    height: 4px;
    background-color: var(--primary-rich-gold);
    margin: 15px auto 0;
}

.contact-info ul {
    list-style: none;
    padding: 0;
}

.contact-info ul li {
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 20px;
    font-size: 1.2rem;
    line-height: 1.6;
    color: var(--text-dark);
}

.contact-info ul li strong {
    font-family: 'Open Sans', sans-serif;
    color: var(--primary-rich-gold);
    margin-right: 12px;
}

.contact-info ul li a {
    color: var(--text-dark);
    text-decoration: none;
    transition: color 0.3s ease;
    font-family: 'Open Sans', sans-serif;
}

.contact-info ul li a:hover {
    color: var(--accent-terracotta);
    text-decoration: underline;
}

.contact-info ul li small {
    display: block;
    font-size: 0.9em;
    color: var(--text-medium);
    margin-top: 8px;
}

.contact-info ul ul {
    margin-top: 10px;
    margin-left: 30px;
    font-size: 1.05rem;
    list-style: disc;
    color: var(--text-medium);
    font-family: 'Open Sans', sans-serif;
}

.contact-info ul ul li {
    margin-bottom: 10px;
}

/* Stiluri pentru formularul de contact (general, folosit și pe home) */
.form-group {
    margin-bottom: 30px;
}

.form-group label {
    display: block;
    margin-bottom: 12px;
    font-weight: 600;
    color: var(--text-dark);
    font-family: 'Open Sans', sans-serif;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
    width: calc(100% - 28px);
    padding: 14px;
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: 10px;
    font-size: 1.05rem;
    color: var(--text-dark);
    background-color: var(--light-section-bg);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
    font-family: 'Open Sans', sans-serif;
}

.form-group input[type="text"]:focus,
.form-group input[type="email"]:focus,
.form-group input[type="tel"]:focus,
.form-group textarea:focus {
    border-color: var(--primary-rich-gold);
    box-shadow: 0 0 0 4px rgba(184, 134, 11, 0.3);
    outline: none;
}

.form-group textarea {
    resize: vertical;
    min-height: 140px;
}

.contact-form .btn-cta {
    display: block;
    width: 100%;
    padding: 18px 20px;
    font-size: 1.3rem;
    font-weight: bold;
    border: none;
    cursor: pointer;
    margin-top: 20px;
    font-family: 'Open Sans', sans-serif;
}

.form-note {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.95em;
    color: var(--text-medium);
    margin-top: 25px;
    text-align: center;
    font-style: italic;
}


/* Stiluri pentru butoanele de programare de pe pagina de contact */
.booking-buttons {
    margin-top: 30px; /* Spațiu de deasupra butoanelor */
    display: flex;
    flex-direction: column; /* Butoanele vor sta una sub alta implicit */
    gap: 15px; /* Spațiu între butoane */
    width: 100%; /* Ocupă lățimea maximă a containerului */
    align-items: center; /* Centrează butoanele pe orizontală */
}

.booking-buttons h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    color: var(--primary-dark-anthracite);
    margin-bottom: 15px;
    text-align: center;
    width: 100%;
}

.booking-buttons .booking-btn {
    width: 90%; /* Lățime pentru butoane */
    max-width: 350px; /* Lățime maximă pentru butoane, le face să arate bine și pe desktop */
    text-align: center; /* Asigură că textul din buton este centrat */
}

/* Responsive de bază */
@media (max-width: 1024px) {
    .content-section .container {
        max-width: 900px;
        padding: 0 25px;
    }
    #hero h1 {
        font-size: 3rem;
    }
    #hero p {
        font-size: 1.4rem;
    }
    .page-header {
        padding: 80px 15px;
        min-height: 200px;
    }
    .page-header h1 {
        font-size: 3rem;
    }
    .page-header p {
        font-size: 1.2rem;
    }
    .section-title {
        font-size: 2.5rem;
    }
    .section-description {
        font-size: 1.15rem;
    }
    .service-item h3 {
        font-size: 2rem;
    }
}

@media (max-width: 768px) {
    /* Ajustări generale pentru mobil */
    nav {
        flex-wrap: wrap;
        justify-content: space-between;
        padding: 0 15px;
    }

    nav .logo {
        margin-bottom: 0;
    }

    /* Meniul de navigare pe mobil (ascuns implicit, arătat cu JS) */
    nav ul {
        display: none; /* Ascunde meniul principal pe mobil */
        flex-direction: column;
        width: 100%;
        background-color: var(--primary-dark-anthracite);
        position: absolute;
        top: 89px; /* Aliniază sub header */
        left: 0;
        right: 0;
        padding: 20px 0;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        box-shadow: 0 5px 15px rgba(0,0,0,0.5);
        z-index: 999;
        transform: translateY(-100%);
        opacity: 0;
        transition: transform 0.4s ease-out, opacity 0.4s ease-out;
    }

    nav ul.open {
        display: flex; /* Afișează meniul când are clasa 'open' */
        transform: translateY(0);
        opacity: 1;
    }

    nav ul li {
        margin: 0;
        text-align: center;
        width: 100%;
    }

    nav ul li a {
        padding: 12px 20px;
        display: block;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }

    nav ul li:last-child a {
        border-bottom: none;
    }

    /* Butonul CTA din NAVIGAȚIE - acum ascuns DOAR acest buton pe mobil */
    .nav-btn-cta { /* NOUĂ REGULĂ */
        display: none;
    }

    /* Stiluri pentru butonul de meniu hamburger (vizibil pe mobil) */
    .hamburger {
        display: flex; /* Asigură că hamburgerul este vizibil și flexbox */
        flex-direction: column; /* Barele vor fi aranjate pe verticală */
        justify-content: space-between; /* Spațiu între bare */
        width: 30px; /* Lățimea totală a hamburgerului */
        height: 22px; /* Înălțimea totală a hamburgerului */
        cursor: pointer;
        padding: 0; /* Elimină padding-ul implicit al butonului */
        background: none; /* Elimină fundalul implicit al butonului */
        border: none; /* Elimină bordura implicită a butonului */
        position: relative; /* Pentru a permite animațiile barelor */
        z-index: 1001; /* Asigură că este deasupra meniului când acesta se deschide */
        margin-left: 20px;
    }

    .hamburger .bar {
        display: block; /* Barele trebuie să fie bloc pentru a avea lățime și înălțime */
        width: 100%; /* Fiecare bară ocupă toată lățimea hamburgerului */
        height: 3px; /* Înălțimea fiecărei bare */
        background-color: var(--text-light); /* Culoarea barelor (gri deschis) */
        border-radius: 2px; /* Margini rotunde pentru bare */
        transition: all 0.3s ease-in-out; /* Animație pentru transformare */
    }

    /* Ajustări responsive pentru alte secțiuni */
    #about .about-content {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    #about .about-content .about-image {
        margin-bottom: 20px;
    }

    #services-list .container {
        grid-template-columns: 1fr; /* O singură coloană pe mobil */
        gap: 30px; /* Ajustează spațiul pe mobil */
    }

    .service-item {
        max-width: 100%; /* Permite cardurilor să ocupe toată lățimea pe mobil */
    }
}

/* Stiluri pentru animația hamburgerului (transformarea în "X") */
.hamburger.is-active .bar:nth-child(1) {
    transform: translateY(9.5px) rotate(45deg);
}

.hamburger.is-active .bar:nth-child(2) {
    opacity: 0;
}

.hamburger.is-active .bar:nth-child(3) {
    transform: translateY(-9.5px) rotate(-45deg);
}

/* Ajustează top-ul meniului când hamburger-ul este vizibil (pe mobil) pentru a nu fi acoperit de alte elemente fixe */
@media (max-width: 768px) {
    header {
        position: relative;
    }
}

/* Stiluri pentru imaginile principale din articolele de blog */
.blog-post-content .blog-main-image {
    max-width: 100%;
    width: auto;
    max-height: 500px;
    object-fit: contain;
    display: block;
    margin: 0 auto 30px;
    border-radius: 10px;
    box-shadow: var(--shadow-subtle);
}

/* Ajustare suplimentară pentru ecrane mai mici (opțional) */
@media (max-width: 768px) {
    .blog-post-content .blog-main-image {
        max-height: 300px;
    }
}

/* Stiluri pentru imaginile din previzualizarea blogului */
.blog-post-preview img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin-bottom: 20px;
    object-fit: cover;
    max-height: 200px;
    width: 100%;
}

/* Stiluri pentru butonul flotant WhatsApp */
.whatsapp-float {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 20px;
    right: 20px;
    background-color: #25D366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 3px #999;
    z-index: 999;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}

.whatsapp-float .whatsapp-icon {
    width: 35px;
    height: 35px;
    max-width: 100%;
    object-fit: contain;
}

.whatsapp-float:hover {
    background-color: #1DA851;
    transform: scale(1.05);
    box-shadow: 3px 3px 5px #777;
}

/* Ajustări pentru mobil (opțional, dacă vrei un buton mai mic pe telefoane) */
@media (max-width: 768px) {
    .whatsapp-float {
        width: 50px;
        height: 50px;
        bottom: 15px;
        right: 15px;
    }
    .whatsapp-float .whatsapp-icon {
        width: 30px;
        height: 30px;
    }
}

/* Stiluri pentru link-urile din footer (Politica de confidentialitate, Termeni si conditii) */
.footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 10px;
    font-size: 0.95rem;
}

.footer-links a {
    color: var(--text-light);
    text-decoration: none;
    transition: color 0.3s ease;
    white-space: nowrap;
}

.footer-links a:hover {
    color: var(--primary-rich-gold);
    text-decoration: underline;
}

.footer-links .link-separator {
    color: var(--text-medium);
}

/* Ajustări Responsive pentru Footer (link-urile legale) */
@media (min-width: 769px) {
    footer .container.footer-content {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
    .footer-links {
        margin-top: 0;
    }
}
/* Re-ajustăm flex-direction pentru footer-content pe mobil dacă am făcut-o row pe desktop */
@media (max-width: 768px) {
    footer .container.footer-content {
        flex-direction: column;
        text-align: center;
    }
}

/* Stiluri pentru pagina "Despre Mine" aprofundată */
.about-expanded-content {
    flex-direction: column;
    gap: 60px;
    align-items: flex-start;
}

.about-section-block {
    width: 100%;
    text-align: left;
}

.about-section-block .section-title {
    text-align: left;
    margin-left: 0;
    margin-right: 0;
}

.about-section-block .section-title::after {
    margin-left: 0;
}

.about-section-block p {
    margin-bottom: 1.2em;
    font-size: 1.1rem;
    color: var(--text-dark);
}

.about-section-block ul {
    list-style: disc;
    margin-left: 25px;
    margin-top: 15px;
    margin-bottom: 25px;
    color: var(--text-dark);
    font-size: 1.1rem;
}

.about-section-block ul li {
    margin-bottom: 8px;
}

/* Stiluri pentru mini-galeria din pagina Despre Mine (dacă adaugi imagini) */
.about-gallery-mini {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin-top: 25px;
}

.about-gallery-mini img.about-image-mini {
    width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: var(--shadow-subtle);
    object-fit: cover;
    max-height: 200px;
}

/* Stiluri pentru grila de imagini din galerie */
.gallery-images {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

.gallery-images img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
    box-shadow: var(--shadow-subtle);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    object-fit: cover;
    max-height: 250px;
    max-width: 350px; /* NOU: Limitează lățimea maximă a imaginii */
    justify-self: center; /* NOU: Centrează imaginea în celula grilei */
}

.gallery-images img:hover {
    transform: scale(1.03);
    box-shadow: var(--shadow-hover);
}

/* Stiluri pentru videoclipuri responsive */
.video-responsive {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 100%;
    background: #000;
    border-radius: 10px;
    box-shadow: var(--shadow-subtle);
}

.video-responsive iframe,
.video-responsive object,
.video-responsive embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

/* Ajustări Responsive pentru Galerie */
@media (max-width: 768px) {
    .gallery-images {
        grid-template-columns: 1fr;
    }
}

/* Asigură că și pe mobil containerul principal al galeriei se aranjează bine */
@media (min-width: 769px) {
    .gallery-grid {
        flex-direction: column;
    }
}
/* Stiluri pentru butonul "Înapoi Sus" */
#back-to-top {
    display: none; /* Ascuns implicit */
    position: fixed; /* Fixat pe ecran */
    bottom: 90px; /* Distanța de la bază (peste butonul WhatsApp) */
    right: 20px; /* Distanța de la dreapta */
    z-index: 998; /* Sub butonul WhatsApp */
    border: none;
    outline: none;
    background-color: var(--primary-rich-gold); /* Culoarea butonului */
    color: var(--primary-dark-anthracite); /* Culoarea săgeții */
    cursor: pointer;
    padding: 12px 18px; /* Dimensiunea butonului */
    border-radius: 50%; /* Face butonul rotund */
    font-size: 1.5rem;
    font-weight: bold;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    transition: background-color 0.3s ease, transform 0.3s ease, opacity 0.3s ease;
    opacity: 0; /* Folosim opacitate pentru animația de fade */
}

#back-to-top:hover {
    background-color: #D4AF37; /* Nuanță mai deschisă la hover */
    transform: scale(1.05);
}

#back-to-top.show { /* Clasa adăugată de JavaScript când trebuie să fie vizibil */
    display: block; /* Afișează butonul */
    opacity: 1; /* Îl face complet vizibil */
}

/* Ajustări pentru mobil */
@media (max-width: 768px) {
    #back-to-top {
        bottom: 70px; /* Ajustează poziția pe mobil */
        right: 15px;
        padding: 10px 15px;
        font-size: 1.2rem;
    }
}

/* --- STILURI MODIFICATE PENTRU SECȚIUNEA FAQ (Intrebari Frecvente) - AFISARE SIMPLĂ --- */

.faq-list { /* Acesta este containerul principal al FAQ-urilor pe pagina faq.html */
    /* Deja moștenește de la .content-section .container: */
    /* display: flex; flex-direction: column; align-items: center; gap: 50px; */
    /* max-width: 1000px; margin: 0 auto; padding: 0 25px; */
    /* Acest gap va gestiona spațiul dintre faq-item-uri și titlurile de secțiune (h2.section-title) */
}

.faq-item {
    background-color: #fff;
    border-radius: 10px;
    box-shadow: var(--shadow-subtle);
    border: 1px solid rgba(0,0,0,0.1); /* Bordură subtilă */
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    width: 100%; /* Ocupă toată lățimea disponibilă */
    /* Nu mai are overflow: hidden, max-height, opacity, etc. */
}

.faq-item:hover {
    transform: translateY(-5px); /* Efect subtil de ridicare la hover */
    box-shadow: var(--shadow-hover);
    border-color: var(--primary-rich-gold); /* Bordură accentuată la hover */
}

.faq-question {
    cursor: default; /* Eliminăm cursorul pointer, nu mai este clickabil */
    padding: 20px 25px; /* Spațiere internă a zonei de întrebare */
    display: flex;
    justify-content: flex-start; /* Aliniem conținutul la stânga (nu mai avem iconița +/ -) */
    align-items: center;
    font-family: 'Playfair Display', serif;
    font-size: 1.6rem; /* Mărime font adaptată pentru header-ul itemului */
    color: var(--primary-dark-anthracite);
    margin-bottom: 0; /* Anulează orice margină de jos implicită a H2 */
    line-height: 1.3;
}

/* Eliminăm complet stilurile pentru iconița +/-, deoarece nu mai este acordeon */
.faq-question::after,
.faq-question.open::after {
    content: none; /* Elimină complet iconița */
}

.faq-answer {
    /* Răspunsul este vizibil implicit, fără tranziții */
    padding: 0 25px 25px; /* Padding: sus (0 - pentru a se lipi de întrebare), laterale (25px), jos (25px) */
    font-family: 'Open Sans', sans-serif; /* Asigură fontul corect */
    font-size: 1.1rem; /* Asigură mărimea corectă */
    color: var(--text-dark); /* Asigură culoarea corectă */
    line-height: 1.6; /* Asigură line-height corect */
    margin-bottom: 0; /* Asigură că paragrafele din răspuns nu au margini suplimentare la final */
    /* Toate proprietățile legate de ascundere/afișare (max-height, opacity, transition, overflow) au fost eliminate. */
}