
/**
 * main-deferred.css – non-critical CSS (loaded async)
 * Split from main.css for performance; loaded with media="print" onload="this.media='all'"
 */
/* Stiluri comune articole */
.article-card {
    background-color: var(--color-surface-raised);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.35s var(--transition-base);
}

.article-content {
    padding: var(--space-lg);
}

.article-category {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    font-weight: var(--font-weight-medium);
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    display: block;
    margin-bottom: var(--space-sm);
}

.article-title {
    font-size: var(--font-size-h4);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
    line-height: var(--line-height-tight);
}

.article-excerpt {
    font-size: var(--font-size-base);
    color: var(--color-text-muted);
    line-height: var(--line-height-base);
    margin-bottom: var(--space-md);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.article-actions {
    display: flex;
    gap: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border-light);
}

.article-action {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    transition: color 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2xs);
}

.article-action:hover {
    color: var(--color-primary);
}

.article-action i {
    font-size: 0.85em;
    opacity: 0.8;
}

/* Butoane îmbunătățite pentru rândul 1 */
.articles-row--style-a .article-actions {
    gap: var(--space-sm);
    flex-wrap: wrap;
}

.articles-row--style-a .article-action {
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-md);
    background: var(--color-surface-alt);
    color: var(--color-text-muted);
    font-weight: var(--font-weight-medium);
    transition: all 0.25s var(--transition-base);
}

.articles-row--style-a .article-action:hover {
    background: var(--color-primary);
    color: var(--color-white);
}

.articles-row--style-a .article-action i {
    opacity: 0.9;
}

/* --- Rând 1: Carduri cu imagine și icon în colț (design editorial) --- */
.articles-row--style-a {
    align-items: stretch;
}

.article-card--style-a {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--color-border);
}

.article-card--style-a:hover {
    box-shadow: 0 2px 12px rgba(58, 42, 69, 0.06);
}

.article-card--style-a .article-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.article-card--style-a .article-actions {
    margin-top: auto;
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border-light);
}

.article-card__image-wrap {
    position: relative;
    overflow: hidden;
}

.article-card--style-a .article-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    transition: transform 0.4s var(--transition-base);
}

.article-card--style-a:hover .article-image {
    transform: scale(1.03);
}

.article-card__icon {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(58, 42, 69, 0.92);
    color: var(--color-accent);
    border-radius: var(--radius-md);
    font-size: 1.125rem;
    transition: all 0.3s var(--transition-base);
}

.article-card--style-a:hover .article-card__icon {
    background: var(--color-accent);
    color: var(--color-primary);
}

/* --- Rând 2: Carduri cu imagine sus, design curat (stil nou) --- */
.articles-row--style-b {
    align-items: stretch;
}

.article-card--style-b {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-surface-raised);
    box-shadow: 0 1px 4px rgba(58, 42, 69, 0.04);
    border: none;
}

.article-card--style-b:hover {
    box-shadow: 0 8px 24px rgba(58, 42, 69, 0.08);
}

.article-card--style-b .article-card__image-wrap {
    position: relative;
    overflow: hidden;
}

.article-card--style-b .article-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    transition: transform 0.5s var(--transition-base);
}

.article-card--style-b:hover .article-image {
    transform: scale(1.02);
}

.article-card--style-b .article-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: var(--space-lg);
}

.article-card--style-b .article-category {
    display: inline-block;
    padding: var(--space-2xs) var(--space-sm);
    background: rgba(201, 166, 107, 0.15);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-sm);
    width: fit-content;
}

.article-card--style-b .article-actions {
    margin-top: auto;
}

.article-card--style-b .article-action {
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-md);
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    font-weight: var(--font-weight-medium);
    transition: all 0.25s var(--transition-base);
}

.article-card--style-b .article-action:hover {
    border-color: var(--color-accent);
    color: var(--color-accent-dark);
}

/* --- Rând 3: Carduri cu imagine sus, gradient la hover --- */
.articles-row--style-c {
    align-items: stretch;
}

.article-card--style-c {
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, var(--color-surface-raised) 0%, var(--color-surface-alt) 100%);
    border-radius: var(--radius-md);
    overflow: hidden;
    text-align: center;
    position: relative;
    transition: box-shadow 0.35s var(--transition-base);
}

.article-card--style-c::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(201, 166, 107, 0.12) 0%, rgba(201, 166, 107, 0.04) 40%, transparent 70%);
    opacity: 0;
    transition: opacity 0.4s var(--transition-base);
    pointer-events: none;
}

.article-card--style-c:hover {
    box-shadow: 0 4px 16px rgba(58, 42, 69, 0.06);
}

.article-card--style-c:hover::before {
    opacity: 1;
}

.article-card--style-c .article-card__image-wrap {
    position: relative;
    overflow: hidden;
}

.article-card--style-c .article-card__image-link {
    display: block;
}

.article-card--style-c .article-title a {
    color: inherit;
    text-decoration: none;
}

.article-card--style-c .article-title a:hover {
    color: var(--color-accent-dark);
}

.article-card--style-c .article-card__badges {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    display: flex;
    gap: var(--space-2xs);
    z-index: 2;
}

.article-card--style-c .article-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.article-card--style-c:hover .article-image {
    transform: scale(1.02);
}

.article-card--style-c .article-card__image-wrap .article-category {
    position: absolute;
    right: var(--space-md);
    top: var(--space-md);
    padding: var(--space-2xs) var(--space-sm);
    background: rgba(38, 26, 48, 0.85);
    color: var(--color-accent-light);
    font-size: var(--font-size-label);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    border-radius: var(--radius-sm);
    z-index: 2;
}

.article-card--style-c .article-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding-top: var(--space-lg);
    text-align: left;
}

.article-card--style-c .article-title,
.article-card--style-c .article-excerpt {
    text-align: left;
}

.article-card--style-c .article-actions {
    margin-top: auto;
    justify-content: flex-start;
}

.article-card--style-c .article-actions--about {
    justify-content: space-between;
    align-items: center;
}

.article-card--style-c .article-read-time {
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    color: var(--color-text-muted);
}

.article-card--style-c .article-read-time .icon {
    margin-right: 4px;
    opacity: 0.8;
}

/* Butoane noi pentru rândul 3 – stil link cu underline */
.article-card--style-c .article-action {
    position: relative;
    padding: var(--space-xs) var(--space-sm);
    background: none;
    color: var(--color-accent-dark);
    font-weight: var(--font-weight-medium);
}

.article-card--style-c .article-action::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--color-accent);
    transition: width 0.3s var(--transition-base);
}

.article-card--style-c .article-action:hover {
    color: var(--color-primary);
}

.article-card--style-c .article-action:hover::after {
    width: 100%;
    background: var(--color-primary);
}

/* ===========================
   SECTION 5 - DESPRE MINE
   =========================== */
.section-despre {
    background-color: var(--color-surface);
}

.despre-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--space-2xl);
    align-items: start;
}

.despre-image {
    position: sticky;
    top: calc(var(--space-3xl) + 80px);
}

.doctor-photo {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.despre-content h2 {
    margin-bottom: var(--space-lg);
}

.despre-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin: var(--space-xl) 0;
}

.despre-tag {
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    padding: var(--space-xs) var(--space-md);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    transition: all 0.3s var(--transition-base);
    text-decoration: none;
    cursor: pointer;
}

.despre-tag:hover {
    border-color: var(--color-accent);
    color: var(--color-accent-dark);
}

.despre-cta {
    margin-top: var(--space-xl);
}

/* ===========================
   SECTION 6 - CONSULTAȚII (CTA)
   =========================== */
.section-consultatii {
    position: relative;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-muted) 100%);
    text-align: center;
    color: var(--color-white);
    overflow: hidden;
}

.section-consultatii::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url('/public/images/consultatii-map-bg.png');
    background-size: cover;
    background-position: center;
    opacity: 0.1;
    pointer-events: none;
}

.consultatii-title {
    color: var(--color-white);
    margin-bottom: var(--space-md);
}

.consultatii-text {
    font-size: var(--font-size-body);
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: var(--space-xl);
}

.consultatii-locations {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-xl);
    margin-bottom: var(--space-2xl);
}

.consultatii-location-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
    background: rgba(255, 255, 255, 0.05);
    padding: var(--space-md) var(--space-xl);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
}

.consultatii-location-item:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: var(--color-accent-light);
    transform: translateY(-5px);
}

.consultatii-location-item i {
    color: var(--color-accent-light);
    font-size: 1.5rem;
    margin-bottom: var(--space-xs);
}

.location-name {
    font-size: var(--font-size-h5);
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
}

.location-city {
    font-size: var(--font-size-sm);
    color: var(--color-accent-light);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.consultatii-cta {
    display: flex;
    justify-content: center;
}

.consultatii-cta .btn-primary {
    position: relative;
    overflow: hidden;
    padding-right: 2.5rem;
    background-color: var(--color-accent-light);
    color: var(--color-primary-dark);
}


.consultatii-cta .btn-primary:hover {
    background-color: var(--color-accent);
    color: var(--color-primary-dark);
    transform: none;
}


/* ===========================
   FOOTER
   =========================== */
.footer {
    position: relative;
    overflow: hidden;
    background-color: #25192e;
    color: rgba(255, 255, 255, 0.85);
    padding: var(--space-3xl) 0 var(--space-lg);
}

/* Layer 1: Solid background */
.footer-bg {
    position: absolute;
    inset: 0;
    background-color: #25192e;
    z-index: 0;
}

/* Layer 2: Hexagon network */
.footer-hex-layer {
    position: absolute;
    inset: 0;
    z-index: 1;
    animation: footer-hex-float 10s ease-in-out infinite;
}

@keyframes footer-hex-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(8px); }
}

.footer-hex-svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.footer-hex-svg .hex-connections line {
    stroke: #6b4d8a;
    stroke-width: 0.6;
    stroke-opacity: 0.35;
}

.footer-hex-svg .hex-fill {
    fill: #4a3360;
    stroke: none;
}

.footer-hex-svg .hex-stroke {
    fill: none;
    stroke: #7c5fa0;
    stroke-width: 0.8;
}

.footer-hex-svg .hex-dots circle {
    fill: #9b6bc4;
    opacity: 0.5;
}

/* Layer 3 & 4: Image overlays */
.footer-overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    pointer-events: none;
}

.footer-overlay img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    mix-blend-mode: soft-light;
}

.footer-overlay-left {
    left: 0;
    width: 37%;
    opacity: 0.02;
}

.footer-overlay-right {
    right: 0;
    width: 37%;
    opacity: 0.05;
}

/* Layer 5: Footer content */
.footer-inner {
    position: relative;
    z-index: 10;
}

.footer-content {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr 0.8fr;
    gap: var(--space-2xl);
    margin-bottom: var(--space-2xl);
}

.footer-brand {
    max-width: 320px;
}

.footer-logo-link {
    display: inline-block;
    margin-bottom: var(--space-md);
}

.footer-logo {
    display: block;
    height: 40px;
    width: auto;
    opacity: 0.95;
    transition: opacity 0.3s ease;
}

.footer-logo-link:hover .footer-logo {
    opacity: 1;
}

.footer-tagline {
    font-size: var(--font-size-small);
    line-height: var(--line-height-relaxed);
    color: rgba(255, 255, 255, 0.75);
    margin: 0;
}

.footer-section .footer-section-title,
.footer-section h4 {
    font-family: var(--font-body);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    color: var(--color-accent-light);
    margin-bottom: var(--space-md);
}

.footer-contact {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.footer-contact li {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.footer-contact .icon {
    width: 18px;
    height: 18px;
    color: var(--color-accent);
    flex-shrink: 0;
}

.footer-contact a {
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.8);
    transition: color 0.3s ease;
}

.footer-contact a:hover {
    color: var(--color-accent-light);
}

.footer-social {
    display: flex;
    gap: var(--space-sm);
    margin-top: var(--space-md);
}

.footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.9rem;
    transition: background 0.3s ease, color 0.3s ease, transform 0.2s ease;
}

.footer-social a:hover {
    background: var(--color-accent);
    color: var(--color-primary-dark);
    transform: translateY(-2px);
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.footer-links a {
    display: inline-block;
    position: relative;
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.75);
    transition: color 0.3s ease, padding-left 0.3s ease;
}

.footer-links a::before {
    content: '\f105';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    position: absolute;
    left: 0;
    opacity: 0;
    transform: translateX(-6px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.footer-links a:hover {
    color: var(--color-accent-light);
    padding-left: var(--space-xs);
}

.footer-links a:hover::before {
    opacity: 1;
    transform: translateX(0);
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-md);
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    padding-top: var(--space-lg);
}

.footer-copyright {
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.5);
    margin: 0;
}

.footer-bottom-links {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
}

.footer-bottom-links a {
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.5);
    transition: color 0.3s ease;
}

.footer-bottom-links a:hover {
    color: var(--color-accent-light);
}

.footer-bottom-links a[href*="trustdesign"] img {
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.footer-bottom-links a[href*="trustdesign"]:hover img {
    opacity: 1;
}

@media (max-width: 1024px) {
    .footer-content {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-xl);
    }

    .footer-brand {
        max-width: none;
        grid-column: 1 / -1;
    }
}

@media (max-width: 768px) {
    .footer {
        padding: var(--space-2xl) 0 var(--space-lg);
    }

    .footer-content {
        grid-template-columns: 1fr;
        gap: var(--space-xl);
        margin-bottom: var(--space-xl);
    }

    .footer-bottom {
        flex-direction: column;
        text-align: center;
    }

    .footer-bottom-links {
        flex-direction: column;
    }
}

/* ===========================
   SCROLL REVEAL ANIMATIONS
   =========================== */
.scroll-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s var(--transition-base), transform 0.8s var(--transition-base);
}

.scroll-reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ===========================
   RESPONSIVE DESIGN
   =========================== */
@media (max-width: 1024px) {
    .despre-grid {
        grid-template-columns: 1fr;
        gap: var(--space-xl);
    }

    .despre-image {
        position: relative;
        top: 0;
        max-width: 400px;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
    :root {
        --font-size-h1: 2.5rem;
        --font-size-h2: 2rem;
        --font-size-h3: 1.5rem;
        --font-size-body: 1rem;
    }

    .mobile-menu-toggle {
        display: flex;
    }

    .nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background-color: var(--color-surface-raised);
        padding: var(--space-lg);
        box-shadow: var(--shadow-lg);
        border-top: 1px solid var(--color-border);
    }

    .nav.active {
        display: block;
    }

    .nav-list {
        flex-direction: column;
        gap: var(--space-sm);
        align-items: stretch;
    }

    .nav-item a {
        display: block;
        text-align: center;
        padding: var(--space-md);
    }

    .section {
        padding: var(--space-2xl) var(--space-md);
    }

    .hero-section {
        min-height: calc(100vh - var(--header-height));
        height: calc(100vh - var(--header-height));
    }

    .hero-bg {
        background-position: 70% center;
    }

    .hero-buttons {
        flex-direction: column;
    }

    .hero-buttons .btn-primary,
    .hero-buttons .btn-hero-outline {
        width: 100%;
        text-align: center;
    }

    .domenii-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .articles-grid {
        grid-template-columns: 1fr;
    }

    .consultatii-cities {
        flex-direction: column;
        gap: var(--space-sm);
    }

    .city-separator {
        display: none;
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 var(--space-md);
    }

    :root {
        --font-size-h1: 2rem;
        --font-size-h2: 1.75rem;
    }

    .hero-content {
        padding: 0 var(--space-md);
    }
}

/* ===========================
   ACCESSIBILITY
   =========================== */
@media (prefers-reduced-motion: reduce) {

    *:not(.hero-label):not(.hero-title):not(.hero-subtitle):not(.hero-description):not(.hero-buttons):not(.scroll-chevron):not(.widget__menu-btn):not(.widget__menu):not(.skeleton-prompt__crosshair):not(.hotspot__dot),
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

/* ===========================
   HEADER ACTIONS (Search + Programare CTA)
   =========================== */
.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-md);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    flex-shrink: 0;
}

/* Header Search */
.header-search {
    display: flex;
    align-items: center;
    position: relative;
}

.header-search__toggle {
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-size: 1rem;
    cursor: pointer;
    padding: var(--space-xs);
    transition: color 0.2s ease;
    display: flex;
    align-items: center;
}

.header-search__toggle:hover {
    color: var(--color-primary);
}

.header-search__field {
    position: absolute;
    right: 2.5rem;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    overflow: hidden;
    transition: width 0.35s var(--transition-base);
}

.header-search--active .header-search__field {
    width: 280px;
    overflow: visible;
}

.header-search__input {
    width: 100%;
    padding: 0.5rem var(--space-md);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface-raised);
    font-family: var(--font-body);
    font-size: var(--font-size-small);
    color: var(--color-text);
    outline: none;
    transition: border-color 0.2s ease;
}

.header-search__input:focus {
    border-color: var(--color-accent);
}

.header-search__dropdown {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    z-index: 500;
    max-height: 320px;
    overflow-y: auto;
    display: none;
}

.header-search__dropdown.visible {
    display: block;
}

.search-dropdown__item {
    display: block;
    padding: var(--space-xs) var(--space-md);
    font-size: var(--font-size-small);
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border-light);
    cursor: pointer;
    text-decoration: none;
    transition: background-color 0.15s ease;
}

.search-dropdown__item:last-child {
    border-bottom: none;
}

.search-dropdown__item:hover {
    background-color: var(--color-surface-alt);
    color: var(--color-primary);
}

.search-dropdown__empty {
    padding: var(--space-md);
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    text-align: center;
}

/* Programare header button */
.btn-programare-header {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2xs);
    line-height: 1;
    background-color: var(--color-accent);
    color: var(--color-primary-dark);
    padding: 0.6rem 1.25rem;
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    letter-spacing: 0.02em;
    white-space: nowrap;
    transition: all 0.25s var(--transition-base);
}

.btn-programare-header span {
    line-height: 1;
    display: flex;
    align-items: center;
}

.btn-programare-header:hover {
    background-color: var(--color-accent-dark);
    box-shadow: var(--shadow-sm);
}

/* ===========================
   FLOATING CTA
   =========================== */
/* ===========================
   DOCTOR INTERACTIVE WIDGET
   =========================== */
.doctor-widget {
    position: fixed;
    bottom: 0;
    right: 5px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    z-index: 1000;
}

/* Base Main Button - No circle, larger size, transparent background */
.doctor-widget__main {
    width: 160px;
    height: auto;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
    position: relative;
    z-index: 10;
    display: flex;
    align-items: flex-end;
}

.doctor-widget__img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    filter: drop-shadow(0 8px 16px rgba(58, 42, 69, 0.15));
}

/* Imagine mărită: la hover, când popup-ul e vizibil sau meniul e deschis */
.doctor-widget__main:hover .doctor-widget__img,
.doctor-widget--popup-active .doctor-widget__img,
.doctor-widget--open .doctor-widget__img {
    transform: scale(1.08);
}

/* Popup Helper Bubble */
.doctor-widget__popup {
    position: absolute;
    bottom: 90%;
    right: 50px;
    /* Shifted slightly to the left relative to doctor */
    background: var(--color-accent-light);
    color: var(--color-primary-dark);
    padding: 0.8rem 1.2rem;
    padding-right: 2.5rem;
    border-radius: 20px;
    font-size: 0.95rem;
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12);
    pointer-events: none;
    /* User can see it but only click logic triggers hover */
}

.doctor-widget__popup p {
    margin-bottom: 0px;
}

.doctor-widget__popup.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(-10px);
    pointer-events: auto;
}

.doctor-widget__popup-close {
    position: absolute;
    top: 6px;
    right: 8px;
    width: 24px;
    height: 24px;
    padding: 0;
    border: none;
    background: rgba(0, 0, 0, 0.1);
    color: var(--color-primary-dark);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    transition: background 0.2s ease, transform 0.2s ease;
}

.doctor-widget__popup-close:hover {
    background: rgba(0, 0, 0, 0.2);
    transform: scale(1.1);
}

.doctor-widget__popup-arrow {
    position: absolute;
    top: 100%;
    right: 30px;
    width: 0;
    height: 0;
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-top: 8px solid var(--color-accent-light);
}

/* Contact Menu */
.doctor-widget__menu {
    position: absolute;
    bottom: 20px;
    right: 170px;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    z-index: 5;
}

.doctor-widget--open .doctor-widget__menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

/* widget__menu: enter - use TRANSITIONS (more reliable than keyframes) */
.widget__menu .widget__menu-btn:not(.doctor-widget__close) {
    position: relative;
    overflow: visible;
}

.widget__menu .widget__menu-btn {
    opacity: 0;
    transform: translateX(40px);
    transition: opacity 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.widget__menu.is-visible .widget__menu-btn:nth-child(1),
.widget__menu.is-visible .widget__menu-btn:nth-child(2) {
    opacity: 1;
    transform: translateX(0);
    transition-delay: 0s;
}

.widget__menu.is-visible .widget__menu-btn:nth-child(3) {
    opacity: 1;
    transform: translateX(0);
    transition-delay: 0.15s;
}

.widget__menu.is-visible .widget__menu-btn:nth-child(4) {
    opacity: 1;
    transform: translateX(0);
    transition-delay: 0.3s;
}

/* widget__menu: exit animation (menuPuffOut) - keep children visible during puff */
.widget__menu.is-hiding {
    animation: menuPuffOut 0.3s cubic-bezier(0.55, 0, 1, 0.45) forwards;
    transform-origin: right center;
}

.widget__menu.is-hiding .widget__menu-btn {
    animation: none;
    opacity: 1;
    visibility: visible;
}

@keyframes menuPuffOut {
    0% {
        opacity: 1;
        transform: scale(1);
        filter: blur(0);
    }
    100% {
        opacity: 0;
        transform: scale(1.4);
        filter: blur(4px);
    }
}

.doctor-widget__close {
    position: absolute;
    top: -15px;
    right: -10px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--color-primary-dark);
    color: var(--color-white);
    border: 2px solid var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    transition: all 0.2s ease;
    z-index: 10;
}

.doctor-widget__close:hover {
    background: var(--color-error, #ff4d4d);
    transform: scale(1.1);
}

.doctor-widget__menu-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: 0.85rem 1.5rem;
    background: var(--color-white);
    color: var(--color-primary-dark);
    text-decoration: none;
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-semibold);
    font-size: 0.95rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    transition: all 0.25s var(--transition-base);
    white-space: nowrap;
}

.doctor-widget__menu-item i {
    font-size: 1.2rem;
    width: 24px;
    text-align: center;
}

.doctor-widget__menu-item--whatsapp {
    background: #25D366;
    color: var(--color-white);
}

.doctor-widget__menu-item--phone {
    background: var(--color-primary);
    color: var(--color-white);
}

.doctor-widget__menu-item:hover {
    transform: translateX(-8px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
}

.doctor-widget__menu-item--cta {
    background: var(--color-accent);
    color: var(--color-primary-dark);
}

.doctor-widget__menu-item--cta:hover {
    background: var(--color-accent-dark);
    color: var(--color-primary-dark);
}

@keyframes doctor-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(201, 166, 107, 0.4);
    }

    70% {
        box-shadow: 0 0 0 15px rgba(201, 166, 107, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(201, 166, 107, 0);
    }
}

.doctor-widget:not(.doctor-widget--open) .doctor-widget__main {
    animation: doctor-pulse 3s infinite;
}

@keyframes pulse-cta {

    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(201, 166, 107, 0.4);
    }

    50% {
        box-shadow: 0 0 0 10px rgba(201, 166, 107, 0);
    }
}

/* ===========================
   HERO BACKGROUND - diagonal lines + gradient spots
   Shared by: about-hero, page-hero (blog, contact, legal), article-header
   =========================== */
.hero-bg-lines {
    position: relative;
    background-color: var(--color-primary);
    overflow: hidden;
}

.hero-bg-lines::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 24px,
        rgba(255, 255, 255, 0.04) 24px,
        rgba(255, 255, 255, 0.04) 25px
    );
    pointer-events: none;
}

.hero-bg-lines::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 60% at 20% 30%, rgba(201, 166, 107, 0.12) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 85% 70%, rgba(223, 193, 158, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse 60% 80% at 50% 90%, rgba(90, 58, 107, 0.15) 0%, transparent 45%),
        radial-gradient(ellipse 50% 50% at 75% 15%, rgba(201, 166, 107, 0.06) 0%, transparent 50%);
    pointer-events: none;
}

.hero-bg-lines .container,
.hero-bg-lines .about-hero__inner {
    position: relative;
    z-index: 1;
}

/* ===========================
   PAGE HERO (shared inner-page header)
   =========================== */
.page-hero {
    background-color: var(--color-primary);
    padding: var(--space-2xl) 0;
    text-align: center;
}

.page-hero .section-label {
    color: var(--color-accent-light);
}

.page-hero__title {
    font-size: clamp(2rem, 4vw, var(--font-size-h1));
    color: var(--color-white);
    margin-bottom: var(--space-md);
}

.page-hero__description {
    font-size: var(--font-size-base);
    color: rgba(255, 255, 255, 0.8);
    max-width: 720px;
    margin: 0 auto;
    line-height: var(--line-height-relaxed);
}

.page-hero__meta {
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    color: var(--color-accent-light);
    letter-spacing: var(--letter-spacing-wide);
}

/* Blog hero: allow search dropdown to overflow above articles grid */
.page-hero--blog.hero-bg-lines {
    overflow: visible;
    position: relative;
    z-index: 10;
}


/* ===========================
   BLOG FILTER BAR
   =========================== */
/* Blog search - centered, modern, interactive */
.blog-search-wrap {
    display: flex;
    justify-content: center;
    margin-top: var(--space-xl);
}

.blog-search {
    position: relative;
    width: 100%;
    max-width: 560px;
}

.blog-search__icon {
    position: absolute;
    left: var(--space-lg);
    top: 50%;
    transform: translateY(-50%);
    color: rgba(255, 255, 255, 0.6);
    font-size: 1.1rem;
    pointer-events: none;
    transition: color 0.2s ease;
}

.blog-search__input {
    width: 100%;
    padding: 1.125rem 2.75rem 1.125rem calc(3rem + 10px);
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    outline: none;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.blog-search__input::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.blog-search__input:focus {
    outline: none;
    border-color: var(--color-accent);
    background: rgba(255, 255, 255, 0.12);
}

.blog-search:focus-within .blog-search__icon {
    color: var(--color-accent-light);
}

.blog-search__clear {
    position: absolute;
    right: var(--space-md);
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.8);
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}

.blog-search__clear:hover {
    background: rgba(255, 255, 255, 0.25);
    color: white;
}

.blog-search__dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    z-index: 1000;
    display: none;
}

.blog-search__dropdown.visible {
    display: block;
}

.blog-search__result {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    text-decoration: none;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border-light);
    transition: background-color 0.15s ease;
    text-align: left;
}

.blog-search__result:last-child {
    border-bottom: none;
}

.blog-search__result:hover {
    background: var(--color-surface-alt);
}

.blog-search__result-img {
    width: 48px;
    height: 48px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.blog-search__result-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    min-width: 0;
}

.blog-search__result-cat {
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-accent-dark);
}

.blog-search__result-title {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    color: var(--color-primary);
    line-height: 1.3;
}

.blog-search__result:hover .blog-search__result-title {
    color: var(--color-primary-dark);
}

.blog-search__empty {
    padding: var(--space-lg);
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    text-align: left;
}

/* Blog category filter bar - buttons below search */
.blog-category-bar {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-2xs);
    margin-top: var(--space-lg);
}

.blog-category-btn {
    display: inline-block;
    padding: 0.5rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.35);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.9);
    font-family: var(--font-body);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    text-decoration: none;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.blog-category-btn:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.5);
    color: var(--color-white);
}

.blog-category-btn--active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: var(--color-primary-dark);
}

.blog-category-btn--active:hover {
    background: var(--color-accent-light);
    border-color: var(--color-accent-light);
    color: var(--color-primary-dark);
}

/* Legacy - keep for any remaining refs */
.blog-filter__select-wrap {
    position: relative;
    flex-shrink: 0;
}

.blog-filter__select {
    appearance: none;
    padding: 0.85rem 2.5rem 0.85rem var(--space-md);
    border: 1.5px solid rgba(255, 255, 255, 0.25);
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.12);
    color: var(--color-white);
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    cursor: pointer;
    outline: none;
    min-width: 200px;
}

.blog-filter__select option {
    background: var(--color-primary);
    color: var(--color-white);
}

.blog-filter__select-icon {
    position: absolute;
    right: var(--space-md);
    top: 50%;
    transform: translateY(-50%);
    color: rgba(255, 255, 255, 0.6);
    pointer-events: none;
    font-size: 0.75rem;
}

/* ===========================
   BLOG GRID & CARDS
   =========================== */
.blog-section {
    padding: var(--space-3xl) 0;
    padding-bottom: var(--space-lg);
    position: relative;
    z-index: 1;
}

.blog__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}

@media (max-width: 1024px) {
    .blog__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

.blog__card {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.3s var(--transition-base);
    display: flex;
    flex-direction: column;
}

.blog__card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-primary-muted);
}

.blog__card-image-link {
    display: block;
}

.blog__card-image-wrap {
    position: relative;
    aspect-ratio: 3/2;
    overflow: hidden;
}

.blog__card-image-category {
    position: absolute;
    right: var(--space-md);
    top: var(--space-md);
    padding: var(--space-2xs) var(--space-sm);
    background: rgba(38, 26, 48, 0.85);
    color: var(--color-accent-light);
    font-size: var(--font-size-label);
    font-weight: var(--font-weight-medium);
    font-family: var(--font-mono);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    border-radius: var(--radius-sm);
    z-index: 2;
}

.blog__card-image-read {
    position: absolute;
    right: var(--space-md);
    bottom: var(--space-md);
    padding: var(--space-2xs) var(--space-sm);
    background: rgba(0, 0, 0, 0.6);
    color: rgba(255, 255, 255, 0.9);
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    border-radius: var(--radius-sm);
    z-index: 2;
}

.blog__card-image-read i {
    margin-right: 4px;
    opacity: 0.8;
}

.blog__card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s var(--transition-base);
}

.blog__card:hover .blog__card-image {
    transform: scale(1.04);
}

.blog__card-badges {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    display: flex;
    gap: var(--space-2xs);
    z-index: 2;
}

.blog__badge {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    padding: 3px 8px;
    border-radius: 2px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 500;
}

.blog__badge--video {
    background: rgba(38, 26, 48, 0.85);
    color: var(--color-accent-light);
}

.blog__badge--audio {
    background: rgba(38, 26, 48, 0.85);
    color: #1DB954;
}

.blog__card-body {
    padding: var(--space-md);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.blog__card-category {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    color: var(--color-accent-dark);
    margin-bottom: var(--space-xs);
}

.blog__card-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-h5);
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-tight);
    margin-bottom: var(--space-xs);
}

.blog__card-title a {
    color: var(--color-primary);
    transition: color 0.2s;
}

.blog__card-title a:hover {
    color: var(--color-accent-dark);
}

.blog__card-excerpt {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    line-height: var(--line-height-base);
    margin-bottom: var(--space-md);
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog__card-meta {
    display: flex;
    gap: var(--space-sm);
    flex-wrap: wrap;
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    color: var(--color-text-light);
    margin-bottom: var(--space-md);
}

.blog__card-meta i {
    margin-right: 4px;
}

.blog__card-actions {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-xs);
    border-top: 1px solid var(--color-border-light);
    padding-top: var(--space-sm);
    margin-top: auto;
}

.blog__card-read-link {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    color: var(--color-accent-dark);
    display: flex;
    align-items: center;
    gap: 6px;
    transition: color 0.2s ease;
}

.blog__card-read-link:hover {
    color: var(--color-primary);
}

/* Home articole: category + badge aceeași înălțime */
.blog__card-badge-size {
    font-size: 0.65rem !important;
    padding: 3px 8px !important;
    letter-spacing: 0.08em;
}

/* Home articole: Citește articolul stânga, ceas + min dreapta */
.blog__card-actions--home {
    justify-content: space-between;
    align-items: center;
}

.blog__card-read-time {
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    color: var(--color-text-muted);
}

.blog__card-read-time .icon {
    margin-right: 4px;
    opacity: 0.8;
}

.articles-row--home {
    align-items: stretch;
}

#articles-grid {
    margin-top: 0;
}

@media (min-width: 769px) {
    #articles-grid {
        margin-bottom: var(--space-2xl);
    }
}

.articles-row--home .blog__card {
    display: flex;
    flex-direction: column;
    border: none;
}

.articles-row--home .blog__card:hover {
    transform: none;
    box-shadow: var(--shadow-md);
}

.articles-row--home .blog__card-image {
    transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.articles-row--home .blog__card:hover .blog__card-image {
    transform: scale(1.02);
}

.articles-row--home .blog__card-body,
.articles-row--home .blog__card-title {
    text-align: left;
}

.blog__card-programare {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 5px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    transition: all 0.2s ease;
    white-space: nowrap;
}

.blog__card-programare:hover {
    border-color: var(--color-accent);
    color: var(--color-accent-dark);
    background: rgba(201, 166, 107, 0.08);
}

/* Blog no results */
.blog__no-results {
    text-align: center;
    padding: var(--space-3xl) var(--space-lg);
    color: var(--color-text-muted);
}

.blog__no-results i {
    font-size: 2rem;
    opacity: 0.4;
    margin-bottom: var(--space-md);
    display: block;
}

/* Consultatii mini CTA bar - MAIN CTA (TOP) */
.section-consultatii-mini {
    background: var(--color-primary);
    padding: var(--space-2xl) 0;
}

.consultatii-mini {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-xl);
    flex-wrap: wrap;
}

.consultatii-mini__text h2 {
    color: var(--color-white);
    margin-bottom: var(--space-xs);
    font-size: var(--font-size-h3);
}

.consultatii-mini__text p {
    color: rgba(255, 255, 255, 0.75);
    margin: 0;
}

/* Buton maro - culoare primară pentru CTA programare consultație */
.consultatii-mini .btn-cta-maro,
.btn-cta-maro {
    background-color: var(--color-cta-maro);
    color: var(--color-white);
    border: none;
}

.consultatii-mini .btn-cta-maro:hover,
.btn-cta-maro:hover {
    background-color: var(--color-cta-maro-hover);
    color: var(--color-white);
    box-shadow: var(--shadow-md);
}

/* ===========================
   4 MODELE CTA FULL-WIDTH - DESIGNURI DIFERITE
   =========================== */

.cta-variants-wrapper {
    padding-bottom: var(--space-2xl);
}

.cta-full {
    width: 100%;
    padding: var(--space-2xl) 0;
}

.cta-full__label {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    color: var(--color-accent-light);
    display: block;
    margin-bottom: var(--space-sm);
}

/* Model 1: Bar mov - text stânga, buton dreapta, fundal mov principal */
.cta-full--split {
    background: var(--color-primary);
    padding: var(--space-2xl) 0;
}

.cta-full--split__bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-xl);
    flex-wrap: wrap;
}

.cta-full--split__text h2 {
    color: var(--color-white);
    font-size: var(--font-size-h3);
    margin: 0 0 var(--space-xs);
}

.cta-full--split__text p {
    color: rgba(255, 255, 255, 0.75);
    margin: 0;
}

/* Model 2: Diagonal - clip-path diagonal, gradient cu mov deschis */
.cta-full--diagonal {
    background: linear-gradient(165deg, var(--color-primary) 0%, var(--color-primary-dark) 50%, var(--color-primary-light) 100%);
    clip-path: polygon(0 0, 100% 8%, 100% 100%, 0 92%);
    padding: var(--space-3xl) var(--space-lg);
}

.cta-full--diagonal__inner {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}

.cta-full--diagonal h2 {
    color: var(--color-white);
    font-size: var(--font-size-h2);
    margin: 0 0 var(--space-md);
}

.cta-full--diagonal p {
    color: rgba(255, 255, 255, 0.85);
    font-size: var(--font-size-body);
    margin: 0 0 var(--space-xl);
}

/* Model 3: Editorial - în container (nu full width), buton dreapta, bordură stânga groasă */
.cta-full--editorial {
    background: var(--color-surface);
    border-left: 12px solid var(--color-cta-maro);
    padding: var(--space-2xl) var(--space-lg);
}

.cta-full--editorial__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-xl);
    flex-wrap: wrap;
}

.cta-full--editorial__content {
    flex: 1;
    min-width: 200px;
}

.cta-full--editorial h2 {
    color: var(--color-text);
    font-size: var(--font-size-h3);
    margin: 0 0 var(--space-sm);
}

.cta-full--editorial p {
    color: var(--color-text-muted);
    margin: 0;
}

/* Model 4: Centered minimal - mov deschis, tipografie mare */
.cta-full--centered {
    background: var(--color-primary-light);
}

/* Variantă: mov principal (ca consultatii-mini) */
.cta-full--centered-primary {
    background: var(--color-primary);
    text-align: center;
    padding: var(--space-3xl) var(--space-lg);
}

.cta-full--centered__inner {
    max-width: 560px;
    margin: 0 auto;
}

.cta-full--centered h2 {
    color: var(--color-white);
    font-size: var(--font-size-h2);
    margin: 0 0 var(--space-md);
    letter-spacing: var(--letter-spacing-tight);
}

.cta-full--centered p {
    color: rgba(255, 255, 255, 0.85);
    font-size: var(--font-size-body);
    margin: 0 0 var(--space-xl);
}

@media (max-width: 768px) {
    .cta-full--split__bar {
        flex-direction: column;
        align-items: flex-start;
    }

    .cta-full--editorial__row {
        flex-direction: column;
        align-items: flex-start;
    }

    .cta-full--diagonal {
        clip-path: polygon(0 0, 100% 4%, 100% 100%, 0 96%);
    }

    .cta-full--diagonal h2,
    .cta-full--centered h2 {
        font-size: var(--font-size-h3);
    }
}


/* ===========================
   ARTICLE SINGLE PAGE
   =========================== */
.article-page {
    background: var(--color-surface);
}

.article-header {
    padding: var(--space-2xl) 0 var(--space-xl);
}

.article-header__inner {
    max-width: 780px;
}

.article-header__meta-top {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.article-category-badge {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    background: rgba(201, 166, 107, 0.2);
    color: var(--color-accent-light);
    border: 1px solid rgba(201, 166, 107, 0.35);
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    text-decoration: none;
}

.article-category-badge--sm {
    font-size: 0.65rem;
    padding: 3px 8px;
}

.article-category-badge--related {
    background: rgba(58, 42, 69, 0.18);
    color: var(--color-primary);
    border-color: rgba(58, 42, 69, 0.25);
}

.article-header__read-time {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    color: rgba(255, 255, 255, 0.55);
}

.article-header__title {
    font-size: clamp(1.8rem, 3.5vw, var(--font-size-h2));
    color: var(--color-white);
    line-height: 1.15;
    margin-bottom: var(--space-md);
}

.article-header__meta {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    color: rgba(255, 255, 255, 0.55);
}

.article-header__meta i {
    margin-right: 4px;
}

/* Article Layout */
.article-layout {
    padding: var(--space-2xl) 0 var(--space-lg);
}

.article-layout__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
    align-items: start;
}

@media (min-width: 768px) {
    .article-layout__inner {
        grid-template-columns: 1fr 300px;
    }
}

.article-layout .article-content {
    min-width: 0;
    padding: 0;
}

.article-lead {
    font-size: var(--font-size-h6);
    font-style: italic;
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
    border-left: 3px solid var(--color-accent);
    padding-left: var(--space-md);
    margin-bottom: var(--space-xl);
}

.article-media {
    margin-bottom: var(--space-xl);
}

.article-media__video {
    position: relative;
    aspect-ratio: 16/9;
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.article-media__video iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.article-media__image img {
    width: 100%;
    border-radius: var(--radius-lg);
    aspect-ratio: 3/2;
    object-fit: cover;
}

/* Article Body Prose */
.article-body {
    max-width: 720px;
}

.article-body h2 {
    font-size: var(--font-size-h3);
    color: var(--color-primary);
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-xs);
    border-bottom: 2px solid var(--color-border);
}

.article-body h3 {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-sm);
}

.article-body p {
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.article-body ul,
.article-body ol {
    padding-left: var(--space-lg);
    margin-bottom: var(--space-md);
}

.article-body li {
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-xs);
    list-style: disc;
}

.article-body ol li {
    list-style: decimal;
}

.article-body blockquote {
    border-left: 3px solid var(--color-accent);
    padding: var(--space-md) var(--space-lg);
    margin: var(--space-xl) 0;
    background: var(--color-surface-alt);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-size: var(--font-size-h6);
    font-style: italic;
    color: var(--color-text-muted);
}

.article-body blockquote cite {
    display: block;
    font-size: var(--font-size-small);
    font-style: normal;
    font-family: var(--font-mono);
    color: var(--color-text-light);
    margin-top: var(--space-xs);
}

.article-blockquote {
    border-left: 3px solid var(--color-accent);
    padding: var(--space-md) var(--space-lg);
    margin: var(--space-xl) 0;
    background: var(--color-surface-alt);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-size: var(--font-size-h6);
    font-style: italic;
    color: var(--color-text-muted);
}

.article-blockquote cite {
    display: block;
    font-size: var(--font-size-small);
    font-style: normal;
    font-family: var(--font-mono);
    color: var(--color-text-light);
    margin-top: var(--space-xs);
}

.article-infobox {
    display: flex;
    gap: var(--space-md);
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    margin: var(--space-xl) 0;
}

.article-infobox__icon {
    font-size: 1.5rem;
    color: var(--color-accent);
    flex-shrink: 0;
    padding-top: 2px;
}

.article-infobox__content h4 {
    font-size: var(--font-size-h6);
    margin-bottom: var(--space-sm);
}

.article-infobox__content ul {
    margin: 0;
    padding-left: var(--space-md);
}

.article-infobox__content li {
    list-style: disc;
    margin-bottom: 4px;
    font-size: var(--font-size-small);
}

/* Audio / Podcast section */
.article-audio {
    background: linear-gradient(135deg, #1DB954 0%, #158c3e 100%);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin: var(--space-2xl) 0;
    position: relative;
    overflow: hidden;
}

.article-audio__decoration {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 160px;
    opacity: 0.15;
    display: flex;
    align-items: center;
}

.audio-wave {
    display: flex;
    align-items: center;
    gap: 3px;
    height: 100%;
    width: 100%;
}

.audio-wave__bar {
    flex: 1;
    background: white;
    border-radius: 2px;
    animation: wave-anim 1.2s ease-in-out infinite;
}

.audio-wave__bar:nth-child(odd) {
    animation-delay: 0.15s;
}

.audio-wave__bar:nth-child(3n) {
    animation-delay: 0.3s;
}

@keyframes wave-anim {

    0%,
    100% {
        height: 20%;
    }

    50% {
        height: 80%;
    }
}

.article-audio__content {
    position: relative;
    display: flex;
    align-items: center;
    gap: var(--space-md);
    flex-wrap: wrap;
}

.article-audio__icon {
    font-size: 2rem;
    color: white;
    flex-shrink: 0;
}

.article-audio__text {
    flex: 1;
}

.article-audio__text h4 {
    color: white;
    font-size: var(--font-size-h6);
    margin-bottom: 4px;
}

.article-audio__text p {
    color: rgba(255, 255, 255, 0.85);
    font-size: var(--font-size-small);
    margin: 0;
}

.article-audio__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2xs);
    background: rgba(255, 255, 255, 0.2);
    color: white;
    padding: 0.6rem 1.25rem;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    border: 1px solid rgba(255, 255, 255, 0.35);
    transition: background 0.2s ease;
    white-space: nowrap;
}

.article-audio__btn:hover {
    background: rgba(255, 255, 255, 0.32);
}

/* Spotify embed direct (link sau iframe) */
.article-audio-embed {
    margin: var(--space-2xl) 0;
}

.article-audio-embed__title {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
}

.article-audio-embed iframe {
    display: block;
    max-width: 100%;
}

/* Image Gallery */
.article-gallery {
    margin: var(--space-2xl) 0;
}

.article-gallery__title {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
}

.article-gallery__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
}

@media (max-width: 500px) {
    .article-gallery__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 400px) {
    .article-gallery__grid {
        grid-template-columns: 1fr;
    }
}

.article-gallery__item {
    margin: 0;
    overflow: hidden;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    cursor: pointer;
    position: relative;
}

.article-gallery__item img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
}

.article-gallery__item figcaption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-lg) var(--space-md) var(--space-md);
    font-size: var(--font-size-small);
    font-family: var(--font-body);
    color: var(--color-white);
    background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.4) 50%, transparent 100%);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.3s var(--transition-base), transform 0.3s var(--transition-base);
}

.article-gallery__item:hover figcaption {
    opacity: 1;
    transform: translateY(0);
}

/* Lightbox */
.lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.92);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.lightbox.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.lightbox__close {
    position: absolute;
    top: var(--space-lg);
    right: var(--space-lg);
    width: 48px;
    height: 48px;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-white);
    font-size: 1.5rem;
    cursor: pointer;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}

.lightbox__close:hover {
    background: rgba(255, 255, 255, 0.2);
}

.lightbox__prev,
.lightbox__next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-white);
    font-size: 1.25rem;
    cursor: pointer;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}

.lightbox__prev {
    left: var(--space-lg);
}

.lightbox__next {
    right: var(--space-lg);
}

.lightbox__prev:hover,
.lightbox__next:hover {
    background: rgba(255, 255, 255, 0.2);
}

.lightbox__content {
    max-width: 90vw;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-md);
}

.lightbox__img {
    max-width: 100%;
    max-height: 75vh;
    object-fit: contain;
}

.lightbox__caption {
    color: var(--color-white);
    font-size: var(--font-size-base);
    text-align: center;
    padding: 0 var(--space-lg);
    margin: 0;
}

/* Related Articles */
.article-related {
    margin: var(--space-2xl) 0;
}

.article-related__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: var(--space-sm);
}

.article-related__title {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin: 0;
}

.article-related__all-link {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    color: var(--color-accent-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}

.article-related__all-link:hover {
    color: var(--color-primary);
}

.article-related .carousel__footer .article-related__all-link.btn-primary {
    color: var(--color-white);
}

.article-related .carousel__footer .article-related__all-link.btn-primary:hover {
    color: var(--color-white);
}

.article-related__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
}

@media (max-width: 768px) {
    .article-related__grid {
        grid-template-columns: 1fr;
    }
}

.article-related__card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.25s var(--transition-base);
}

.article-related__card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}

.article-related__image-link img {
    width: 100%;
    aspect-ratio: 3/2;
    object-fit: cover;
}

.article-related__body {
    padding: var(--space-sm);
}

.article-related__body h4 {
    font-size: var(--font-size-base);
    line-height: var(--line-height-tight);
    margin: var(--space-xs) 0;
}

.article-related__body h4 a {
    color: var(--color-primary);
}

.article-related__body h4 a:hover {
    color: var(--color-accent-dark);
}

.article-related__meta {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    color: var(--color-text-light);
}

/* Article CTA Bottom */
.article-cta {
    background: var(--color-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    margin: var(--space-2xl) 0;
}

.article-cta__content {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    flex-wrap: wrap;
}

.article-cta__icon {
    font-size: 2rem;
    color: var(--color-accent);
    flex-shrink: 0;
}

.article-cta__text {
    flex: 1;
}

.article-cta__text h3 {
    color: var(--color-white);
    font-size: var(--font-size-h4);
    margin-bottom: var(--space-xs);
}

.article-cta__text p {
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
    font-size: var(--font-size-small);
}

.article-cta__btn {
    background: var(--color-accent) !important;
    color: var(--color-primary-dark) !important;
    white-space: nowrap;
    flex-shrink: 0;
}

.article-cta__btn:hover {
    background: var(--color-accent-dark) !important;
}

/* Article Comments */
.article-comments {
    margin: var(--space-2xl) 0;
    padding-top: var(--space-xl);
    border-top: 1px solid var(--color-border);
}

.article-comments__title {
    font-size: var(--font-size-h4);
    color: var(--color-primary);
    margin-bottom: var(--space-lg);
}

.article-comments__success {
    background: rgba(34, 197, 94, 0.1);
    color: var(--color-primary);
    padding: var(--space-md);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-lg);
    font-size: var(--font-size-small);
}

.article-comments__empty {
    color: var(--color-text-muted);
    font-size: var(--font-size-small);
    margin-bottom: var(--space-lg);
}

.article-comments__list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-xl);
}

.article-comment {
    padding: var(--space-md) 0;
    border-bottom: 1px solid var(--color-border);
}

.article-comment:last-child {
    border-bottom: none;
}

.article-comment__body,
.article-comment__reply {
    position: relative;
    padding: var(--space-sm);
    border-radius: var(--radius-md);
}

.article-comment__body {
    background: var(--color-surface-raised);
    border-left: 3px solid var(--color-cta-maro);
}

.article-comment__meta {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    margin-bottom: var(--space-xs);
}

.article-comment__icon {
    color: var(--color-cta-maro);
    font-size: 0.95em;
}

.article-comment__reply .article-comment__icon {
    color: var(--color-primary);
    font-size: 0.95em;
}

.article-comment__author,
.article-comment__reply-label {
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-small);
    color: var(--color-primary);
}

.article-comment__content,
.article-comment__reply-content {
    font-size: var(--font-size-small);
    line-height: var(--line-height-relaxed);
    color: var(--color-text);
    padding-right: 4.5rem;
    padding-bottom: 1.25rem;
}

.article-comment__date {
    position: absolute;
    bottom: var(--space-sm);
    right: var(--space-sm);
    font-size: var(--font-size-label);
    color: var(--color-text-muted);
}

.article-comment__reply {
    margin-top: var(--space-sm);
    margin-left: var(--space-lg);
    background: rgba(58, 42, 69, 0.08);
    border-left: 3px solid var(--color-primary);
}

.article-comments__replies {
    list-style: none;
    padding: 0;
    margin: var(--space-md) 0 0 var(--space-lg);
    border-left: 2px solid var(--color-border);
    padding-left: var(--space-md);
}

.article-comment--reply {
    padding: var(--space-sm) 0;
    border-bottom: 1px solid var(--color-border);
}

.article-comment--reply:last-child {
    border-bottom: none;
}

.article-comments__form-wrap {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
}

.article-comments__form-title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-md);
}

.article-comments__form .article-comments__form-row {
    margin-bottom: var(--space-md);
}

.article-comments__form-row--inline {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}

@media (max-width: 480px) {
    .article-comments__form-row--inline {
        grid-template-columns: 1fr;
    }
}

.article-comments__checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    font-weight: normal;
    cursor: pointer;
}

.article-comments__checkbox-label input[type="checkbox"] {
    margin-top: 0.25em;
    flex-shrink: 0;
}

.article-comments__checkbox-label a {
    color: var(--color-primary);
}

.article-comments__checkbox-label a:hover {
    text-decoration: underline;
}

.article-comments__form label {
    display: block;
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--space-xs);
}

.article-comments__form input[type="text"],
.article-comments__form input[type="email"],
.article-comments__form textarea {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-base);
}

.article-comments__form .required {
    color: var(--color-accent);
}

/* Article Sidebar - vizibil pe desktop, ascuns doar pe mobil */
.article-sidebar {
    display: none;
}

@media (min-width: 768px) {
    .article-sidebar {
        display: flex;
        flex-direction: column;
        gap: var(--space-lg);
    }
}

.sidebar-box {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-md);
}

.sidebar-box__title {
    font-size: var(--font-size-small);
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
}

.sidebar-box--author {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    align-items: stretch;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-muted) 100%);
    border: none;
    padding: var(--space-lg);
    border-radius: var(--radius-lg);
}

.sidebar-author__header {
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
}

.sidebar-author__avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    object-position: top;
    border: 3px solid rgba(201, 166, 107, 0.5);
    flex-shrink: 0;
}

.sidebar-author__meta {
    flex: 1;
    min-width: 0;
}

.sidebar-box--author .sidebar-author__label {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    display: block;
    margin-bottom: 2px;
}

.sidebar-box--author .sidebar-author__name {
    font-size: var(--font-size-h5);
    color: var(--color-white);
    margin: 0;
}

.sidebar-box--author .sidebar-author__bio {
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.85);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.sidebar-author__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    background: var(--color-accent);
    color: var(--color-primary-dark);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-sm);
    transition: background 0.2s ease, color 0.2s ease;
}

.sidebar-author__btn:hover {
    background: var(--color-accent-light);
    color: var(--color-primary);
}

.sidebar-toc__list {
    padding-left: var(--space-md);
}

.sidebar-toc__item {
    list-style: decimal;
    margin-bottom: var(--space-xs);
}

.sidebar-toc__item a {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    transition: color 0.2s;
}

.sidebar-toc__item a:hover {
    color: var(--color-primary);
}

.sidebar-box--cta {
    background: var(--color-primary);
    border-color: transparent;
    text-align: center;
}

.sidebar-cta__icon {
    font-size: 1.75rem;
    color: var(--color-accent);
    margin-bottom: var(--space-xs);
    display: block;
}

.sidebar-box--cta h4 {
    color: var(--color-white);
    margin-bottom: var(--space-xs);
}

.sidebar-box--cta p {
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: var(--space-md);
}

.sidebar-box--cta .btn-primary {
    background-color: var(--color-primary-light);
}

.sidebar-box--cta .btn-primary:hover {
    background-color: var(--color-primary-muted);
}

.sidebar-categories {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sidebar-categories li a {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    padding: 4px 0;
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: color 0.2s;
}

.sidebar-categories li a:hover {
    color: var(--color-primary);
}

.sidebar-categories li a::after {
    content: '›';
    font-size: 1.3rem;
    font-weight: 600;
    opacity: 0;
    transition: opacity 0.2s;
    color: var(--color-accent-dark);
}

.sidebar-categories li a:hover::after {
    opacity: 1;
}


/* ===========================
   PATOLOGII PAGE
   =========================== */
.patologii-section {
    padding: var(--space-2xl) 0 var(--space-3xl);
}

.region-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    margin-bottom: var(--space-2xl);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.region-tab {
    background: none;
    border: none;
    padding: var(--space-sm) var(--space-lg);
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-muted);
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    transition: color 0.2s ease;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}

.region-tab:hover {
    color: var(--color-primary);
}

.region-tab--active {
    color: var(--color-primary);
    font-weight: var(--font-weight-bold);
    border-bottom-color: var(--color-accent);
}

.region-panel {
    display: none;
}

.region-panel--active {
    display: block;
}

.pathology-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: var(--space-lg);
}

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

.pathology-card {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.3s var(--transition-base);
    display: flex;
    flex-direction: column;
}

.pathology-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary-muted);
    transform: translateY(-2px);
}

.pathology-card__header {
    padding: var(--space-lg);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-muted) 100%);
}

.pathology-card__name {
    font-size: var(--font-size-h5);
    color: var(--color-white);
    margin-bottom: var(--space-xs);
}

.pathology-card__description {
    font-size: var(--font-size-small);
    color: rgba(255, 255, 255, 0.8);
    line-height: var(--line-height-base);
    margin: 0;
}

.pathology-card__section {
    padding: var(--space-md) var(--space-lg);
    border-bottom: 1px solid var(--color-border-light);
}

.pathology-card__section:last-of-type {
    border-bottom: none;
}

.pathology-card__section-title {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.pathology-card__chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.chip {
    display: inline-block;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: 2px;
    padding: 4px 10px;
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    color: var(--color-text-muted);
}

.pathology-card__treatment-list {
    padding-left: var(--space-md);
}

.pathology-card__treatment-list li {
    list-style: disc;
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    margin-bottom: 4px;
    line-height: var(--line-height-base);
}

.pathology-card__article-links {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pathology-card__article-links li a {
    font-size: var(--font-size-small);
    color: var(--color-primary);
    display: flex;
    align-items: flex-start;
    gap: 6px;
    transition: color 0.2s;
    line-height: var(--line-height-base);
}

.pathology-card__article-links li a:hover {
    color: var(--color-accent-dark);
}

.pathology-card__article-links li a i {
    margin-top: 4px;
    flex-shrink: 0;
}

.pathology-card__footer {
    padding: var(--space-md) var(--space-lg);
    margin-top: auto;
}

.pathology-card__footer .btn-primary {
    width: 100%;
    justify-content: center;
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

/* ===========================
   CONTACT PAGE
   =========================== */

/* Contact info block (date contact stânga, rețele sociale dreapta) */
.contact-info-section {
    padding: var(--space-4xl) 0 var(--space-2xl);
    background: var(--color-surface-alt);
}

.contact-info-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
    align-items: start;
    margin-bottom: var(--space-2xl);
}

.contact-info-split--single {
    grid-template-columns: 1fr;
}

/* Titlurile din contact-info-split: același stil, aliniere la stânga */
.contact-info-split .contact-section-title {
    text-align: left;
    margin-bottom: var(--space-md);
}

.contact-social-links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
}

.contact-info-split .contact-social-links {
    justify-content: flex-start;
}

.contact-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    transition: all 0.2s ease;
}

.contact-social-link:hover {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
}

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

/* Contact page – mobile: spații reduse */
@media (max-width: 768px) {
    .page-hero.page-hero--contact {
        padding: var(--space-lg) 0;
    }

    .page-hero.page-hero--contact .page-hero__title {
        margin-bottom: var(--space-xs);
    }

    .page-hero.page-hero--contact .page-hero__description {
        font-size: var(--font-size-small);
    }

    /* Pagina programare – hero + form */
    body.page-programare .page-hero {
        padding-bottom: var(--space-lg);
    }

    .contact-form-section--programare {
        padding-bottom: var(--space-md);
    }

    .contact-info-section {
        padding: var(--space-lg) 0 var(--space-md);
    }

    .contact-info-split {
        gap: var(--space-md);
        margin-bottom: var(--space-md);
    }

    .contact-info-split .contact-section-title {
        margin-bottom: var(--space-sm);
        font-size: var(--font-size-h4);
    }

    .contact-social-links {
        gap: var(--space-xs);
    }

    .contact-social-link {
        width: 38px;
        height: 38px;
    }

    .contact-info-list {
        gap: var(--space-2xs);
    }

    .contact-info-item {
        font-size: var(--font-size-small);
        gap: var(--space-xs);
    }

    .contact-locations {
        padding: var(--space-md) 0;
    }

    .contact-locations .contact-section-title {
        margin-bottom: var(--space-md);
        font-size: var(--font-size-h4);
    }

    .location-grid {
        gap: var(--space-md);
    }

    .location-card__header {
        padding: var(--space-sm) var(--space-md);
    }

    .location-card__city {
        font-size: 0.65rem;
    }

    .location-card__clinic {
        font-size: var(--font-size-small);
    }

    .location-card__details {
        padding: var(--space-sm) var(--space-md);
    }

    .location-card__detail {
        font-size: 0.8125rem;
        margin-bottom: var(--space-2xs);
    }

    .location-card__nav {
        padding: 0 var(--space-md) var(--space-xs);
        gap: var(--space-2xs);
    }

    .location-card__nav-btn {
        padding: 0.4rem;
        font-size: 0.7rem;
    }

    .location-card__programare {
        padding: var(--space-xs) var(--space-md);
        font-size: 0.8125rem;
    }
}

.contact-locations {
    padding: var(--space-2xl) 0;
}

.contact-section-title {
    font-size: var(--font-size-h3);
    color: var(--color-primary);
    margin-bottom: var(--space-xl);
    text-align: center;
}

.location-grid {
    display: grid;
    gap: var(--space-lg);
}

/* 1 locație: casetă 50% centrată */
.location-grid--1 {
    grid-template-columns: 50%;
    justify-content: center;
}

/* 2 locații: 50% cu 50% */
.location-grid--2 {
    grid-template-columns: repeat(2, 1fr);
}

/* 3 locații: 2 pe linie 50/50, a 3-a pe linia 2 la stânga */
.location-grid--3 {
    grid-template-columns: repeat(2, 1fr);
}

/* 4+ locații: grid 2 coloane */
.location-grid--4,
.location-grid--5,
.location-grid--6 {
    grid-template-columns: repeat(2, 1fr);
}

@media (max-width: 768px) {
    .location-grid {
        grid-template-columns: 1fr;
        max-width: none;
    }
}

.location-card {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.3s var(--transition-base);
    display: flex;
    flex-direction: column;
}

.location-card:hover {
    box-shadow: var(--shadow-md);
}

.location-card__header {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-muted) 100%);
    padding: var(--space-md) var(--space-lg);
}

.location-card__city {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    color: var(--color-accent-light);
    margin-bottom: 4px;
}

.location-card__clinic {
    font-size: var(--font-size-h6);
    color: white;
    margin: 0;
}

.location-card__details {
    padding: var(--space-md) var(--space-lg);
    flex: 1;
}

.location-card__detail {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xs);
}

.location-card__detail i {
    color: var(--color-accent-dark);
    flex-shrink: 0;
    margin-top: 3px;
}

.location-card__detail a {
    color: var(--color-text-muted);
    transition: color 0.2s;
}

.location-card__detail a:hover {
    color: var(--color-primary);
}

.location-card__nav {
    display: flex;
    gap: var(--space-xs);
    padding: 0 var(--space-lg) var(--space-sm);
}

.location-card__nav-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 0.5rem;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-label);
    font-weight: var(--font-weight-medium);
    transition: all 0.2s ease;
    text-align: center;
}

.location-card__nav-btn--maps {
    background: #E8F0FE;
    color: #1a73e8;
    border: 1px solid #c5d9fb;
}

.location-card__nav-btn--maps:hover {
    background: #1a73e8;
    color: white;
}

.location-card__nav-btn--waze {
    background: #E8F5FF;
    color: #33CCFF;
    border: 1px solid #b3eaff;
}

.location-card__nav-btn--waze:hover {
    background: #33CCFF;
    color: white;
}

.location-card__programare {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    width: 100%;
    padding: var(--space-sm) var(--space-lg);
    background: var(--color-accent);
    color: var(--color-primary-dark);
    font-family: var(--font-body);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    border: none;
    cursor: pointer;
    transition: background 0.2s ease;
    margin-top: auto;
}

.location-card__programare:hover {
    background: var(--color-accent-dark);
}

/* Link variant (Contact page → Programare) */
.location-card__programare--link {
    text-decoration: none;
    color: var(--color-primary-dark);
    text-align: center;
}

/* Map placeholder */
.contact-map-section {
    padding: 0 0 var(--space-2xl);
}

.map-container {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
}

.map-placeholder {
    position: relative;
    height: 380px;
    background: linear-gradient(135deg, var(--color-surface-alt) 0%, var(--color-surface) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.map-placeholder__bg {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 30% 50%, rgba(58, 42, 69, 0.04) 0%, transparent 60%),
        radial-gradient(circle at 70% 30%, rgba(201, 166, 107, 0.06) 0%, transparent 50%);
}

.map-pin {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    z-index: 2;
}

.map-pin i {
    font-size: 1.75rem;
    color: var(--color-accent-dark);
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

.map-pin__label {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    color: var(--color-primary);
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    padding: 2px 6px;
    border-radius: 2px;
    white-space: nowrap;
    margin-top: 2px;
    box-shadow: var(--shadow-sm);
}

.map-placeholder__note {
    position: absolute;
    bottom: var(--space-md);
    left: 50%;
    transform: translateX(-50%);
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    color: var(--color-text-light);
    white-space: nowrap;
    margin: 0;
}

/* Contact Form */
.contact-form-section {
    background: var(--color-surface-alt);
    padding: var(--space-2xl) 0 var(--space-3xl);
}

.contact-form-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--space-2xl);
    align-items: start;
}

@media (max-width: 900px) {
    .contact-form-layout {
        grid-template-columns: 1fr;
    }
}

/* Centered layout for Programare page (form only) */
.contact-form-layout--centered {
    max-width: 100%;
    margin: 0 auto;
    grid-template-columns: 1fr;
}

/* Container mai mare pentru pagina Programare */
.container--programare {
    max-width: 900px;
}

.contact-form-info {}

.contact-form-info h2 {
    font-size: var(--font-size-h3);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
}

.contact-form-info p {
    color: var(--color-text-muted);
    font-size: var(--font-size-base);
    margin-bottom: var(--space-xl);
}

.contact-info-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.contact-info-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--font-size-base);
    color: var(--color-text-muted);
    transition: color 0.2s;
    text-decoration: none;
}

.contact-info-item i {
    font-size: 1.1rem;
    color: var(--color-accent-dark);
    width: 20px;
}

.contact-info-item:hover {
    color: var(--color-primary);
}

.contact-form {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}

/* Form row cu 3 coloane - după .form-row pentru a suprascrie */
.form-row.form-row--3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 768px) {
    .form-row.form-row--3 {
        grid-template-columns: 1fr;
    }
}

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

.form-group {
    margin-bottom: var(--space-md);
}

.form-label {
    display: block;
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    margin-bottom: var(--space-xs);
}

.form-required {
    color: var(--color-text-muted);
}
.form-submitted .form-group:has(.form-input:invalid) .form-required,
.form-submitted .form-group:has(.form-select:invalid) .form-required,
.form-submitted .form-group:has(.form-checkbox:invalid) .form-required {
    color: var(--color-error);
}

.form-input {
    display: block;
    width: 100%;
    padding: 0.75rem var(--space-md);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    color: var(--color-text);
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    appearance: none;
}

.form-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(58, 42, 69, 0.08);
}

/* Roșu doar după submit attempt */
.form-submitted .form-input:invalid,
.form-submitted .form-select:invalid {
    border-color: var(--color-error);
}

.form-input:valid:not(:placeholder-shown) {
    border-color: var(--color-success);
}

.form-textarea {
    resize: vertical;
    min-height: 120px;
}

.form-select-wrap {
    position: relative;
}

.form-select {
    cursor: pointer;
}

.form-select-icon {
    position: absolute;
    right: var(--space-md);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    pointer-events: none;
    font-size: 0.75rem;
}

.form-group--checkbox {}

.form-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    cursor: pointer;
}

.form-checkbox {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.form-checkbox-custom {
    width: 18px;
    height: 18px;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    flex-shrink: 0;
    margin-top: 2px;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.form-checkbox:checked+.form-checkbox-custom {
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.form-submitted .form-checkbox:invalid+.form-checkbox-custom {
    border-color: var(--color-error);
}

.form-checkbox:checked+.form-checkbox-custom::after {
    content: '✓';
    color: white;
    font-size: 0.75rem;
    line-height: 1;
}

.form-checkbox-text {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    line-height: var(--line-height-base);
}

.form-checkbox-text a {
    color: var(--color-primary);
    text-decoration: underline;
}

.form-submit {
    margin-top: var(--space-lg);
}

.contact-form__submit {
    width: 100%;
    justify-content: center;
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.form-note {
    font-size: var(--font-size-label);
    font-family: var(--font-mono);
    color: var(--color-text-light);
    text-align: center;
    margin-top: var(--space-sm);
    margin-bottom: 0;
}

.form-alert {
    padding: var(--space-md);
    border-radius: var(--radius-sm);
    margin-top: var(--space-md);
    font-size: var(--font-size-small);
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.form-alert--success {
    background: rgba(74, 124, 89, 0.1);
    border: 1px solid var(--color-success);
    color: var(--color-success);
}

/* ===========================
   MESSAGE MODAL (validare formular)
   =========================== */
.message-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-lg);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s var(--transition-base), visibility 0.3s var(--transition-base);
}

.message-modal.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.message-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(26, 22, 20, 0.6);
    backdrop-filter: blur(4px);
}

.message-modal__box {
    position: relative;
    width: 100%;
    max-width: 420px;
    background: var(--color-surface-raised);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg), 0 24px 48px rgba(58, 42, 69, 0.2);
    padding: var(--space-xl);
    padding-top: var(--space-2xl);
    text-align: center;
    transform: scale(0.95) translateY(10px);
    transition: transform 0.35s var(--transition-base);
}

.message-modal__close {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 50%;
    background: var(--color-border-light);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}

.message-modal__close:hover {
    background: var(--color-border);
    color: var(--color-primary);
}

.message-modal.is-visible .message-modal__box {
    transform: scale(1) translateY(0);
}

.message-modal__icon-wrap {
    width: 56px;
    height: 56px;
    margin: 0 auto var(--space-md);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(168, 76, 76, 0.12);
}

.message-modal__icon {
    font-size: 1.75rem;
    color: var(--color-error);
}

.message-modal--success .message-modal__icon-wrap {
    background: rgba(74, 124, 89, 0.12);
}

.message-modal--success .message-modal__icon {
    color: var(--color-success);
}

.message-modal__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-h3);
    color: var(--color-primary);
    margin: 0 0 var(--space-sm);
}

.message-modal__text {
    font-size: var(--font-size-body);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--space-lg);
}

.message-modal__btn {
    min-width: 160px;
}

/* ===========================
   LEGAL PAGES
   =========================== */
.page-hero--legal {
    padding: var(--space-xl) 0;
}

.page-hero--legal .page-hero__title {
    font-size: clamp(1.75rem, 3vw, var(--font-size-h2));
}

.legal-section {
    padding: var(--space-2xl) 0 var(--space-3xl);
}

.legal-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--space-2xl);
    align-items: start;
}

@media (max-width: 900px) {
    .legal-layout {
        grid-template-columns: 1fr;
    }
}

.legal-content {
    min-width: 0;
}

.legal-intro {
    font-size: var(--font-size-body);
    color: var(--color-text-muted);
    padding: var(--space-md) var(--space-lg);
    background: var(--color-surface-alt);
    border-left: 3px solid var(--color-accent);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    margin-bottom: var(--space-xl);
}

.legal-intro p {
    margin: 0;
}

.legal-content h2 {
    font-size: var(--font-size-h4);
    color: var(--color-primary);
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-xs);
    border-bottom: 1px solid var(--color-border);
}

.legal-content h3 {
    font-size: var(--font-size-h5);
    color: var(--color-primary-muted);
    margin: var(--space-lg) 0 var(--space-sm);
}

.legal-content p {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text);
    margin-bottom: var(--space-md);
}

.legal-content ul {
    padding-left: var(--space-lg);
    margin-bottom: var(--space-md);
}

.legal-content li {
    list-style: disc;
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text);
    margin-bottom: var(--space-xs);
}

.legal-content a {
    color: var(--color-primary);
    text-decoration: underline;
}

.legal-notice {
    display: flex;
    gap: var(--space-md);
    background: rgba(184, 135, 90, 0.08);
    border: 1px solid rgba(184, 135, 90, 0.3);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    margin: var(--space-lg) 0;
}

.legal-notice i {
    color: var(--color-warning);
    flex-shrink: 0;
    margin-top: 3px;
    font-size: 1.1rem;
}

.legal-notice p {
    margin: 0;
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
}

/* Cookie table */
.cookie-table-wrap {
    overflow-x: auto;
    margin: var(--space-md) 0 var(--space-lg);
}

.cookie-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-small);
}

.cookie-table th,
.cookie-table td {
    text-align: left;
    padding: var(--space-xs) var(--space-sm);
    border-bottom: 1px solid var(--color-border-light);
}

.cookie-table th {
    background: var(--color-surface-alt);
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-text-muted);
}

.cookie-table td code {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    background: var(--color-surface-alt);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
}

/* Legal Sidebar */
.legal-sidebar {
    position: sticky;
    top: calc(var(--header-height) + var(--space-md));
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

@media (max-width: 900px) {
    .legal-sidebar {
        position: static;
    }
}

.sidebar-legal-links {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sidebar-legal-links li a {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    padding: var(--space-xs) 0;
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    transition: color 0.2s;
}

.sidebar-legal-links li a:hover,
.sidebar-legal-links li a.active {
    color: var(--color-primary);
    font-weight: var(--font-weight-medium);
}

/* Mobile nav */
@media (max-width: 768px) {
    .mobile-menu-toggle {
        display: flex;
    }

    .mobile-menu-header {
        display: none;
    }

    .nav {
        display: none;
        position: fixed;
        inset: 0;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        height: 100%;
        min-height: 100dvh;
        background: var(--color-white);
        z-index: 1001;
        flex-direction: column;
        justify-content: flex-start;
        align-items: stretch;
        padding: 0;
        overflow-y: auto;
    }

    .nav.active {
        display: flex;
    }

    .nav.active .mobile-menu-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-lg) var(--space-lg) var(--space-md);
        flex-shrink: 0;
        background: var(--color-primary);
    }

    .mobile-menu-logo {
        display: block;
    }

    .mobile-menu-logo-img {
        height: 36px;
        width: auto;
        display: block;
    }

    .mobile-menu-close {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        padding: 0;
        background: transparent;
        border: none;
        color: var(--color-white);
        font-size: 1.5rem;
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
    }

    .mobile-menu-close:hover,
    .mobile-menu-close:focus {
        opacity: 0.85;
    }

    .nav-list {
        flex: 1;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 0;
        padding: var(--space-md) var(--space-lg) var(--space-xl);
    }

    .nav-item a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        font-size: var(--font-size-base);
        font-weight: var(--font-weight-medium);
        color: var(--color-text);
        padding: var(--space-sm) 0;
        border-bottom: 1px solid var(--color-border-light);
    }

    .nav-item a::after {
        content: "\f054";
        font-family: "Font Awesome 6 Free";
        font-weight: 900;
        font-size: 0.75rem;
        color: var(--color-text-muted);
        /* Reset inherited underline pseudo-element */
        position: static;
        bottom: auto;
        left: auto;
        transform: none;
        width: auto;
        height: auto;
        background: none;
        line-height: 1;
        flex-shrink: 0;
    }

    .nav-item a:hover {
        color: var(--color-primary);
    }

    .nav-item a:hover::after {
        color: var(--color-primary);
    }

    .nav-item.active a {
        color: var(--color-primary);
        font-weight: var(--font-weight-semibold);
    }

    .nav-item.active a::after {
        color: var(--color-primary);
    }

    .nav-item--cta {
        display: list-item;
        margin-top: var(--space-md);
        border-bottom: none;
    }

    .nav-item--cta a {
        border-bottom: none;
    }

    .nav-item--cta a::after {
        display: none;
    }

    .btn-programare-mobile {
        display: flex !important;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-sm);
        width: 100%;
        padding: var(--space-md) var(--space-lg) !important;
        background-color: var(--color-accent);
        color: var(--color-primary-dark);
        font-weight: var(--font-weight-semibold);
        border-radius: var(--radius-md);
        text-align: left;
    }

    .btn-programare-mobile:hover {
        background-color: var(--color-accent-dark);
        color: var(--color-primary-dark);
    }

    .btn-programare-mobile i:first-child {
        font-size: 1rem;
    }

    .btn-programare-mobile i:last-child {
        font-size: 0.75rem;
        color: inherit;
    }

    .header-actions {
        gap: var(--space-xs);
    }

    .btn-programare-header span {
        display: none;
    }

    .doctor-widget {
        bottom: 0;
        right: var(--space-sm);
    }

    .doctor-widget__main {
        width: 100px;
    }

    .doctor-widget__menu {
        bottom: 10px;
        right: 110px;
        /* Adjusted for 100px mobile doctor */
    }

    .doctor-widget__menu-item {
        padding: 0.65rem 1rem;
        font-size: 0.85rem;
    }

    .doctor-widget__popup {
        display: none;
        /* Hide popup on mobile for better UX */
    }
}


/* ===========================
   DESPRE MINE (ABOUT) PAGE
   =========================== */

/* Utility spacing classes for about page */
.section-spacing {
    padding: var(--space-3xl) 0;
}

@media (max-width: 900px) {
    .section-spacing {
        padding: var(--space-2xl) 0;
    }
}

.mt-4 {
    margin-top: var(--space-lg);
}

/* About Hero */
.about-hero {
    position: relative;
    padding: var(--space-3xl) 0 var(--space-2xl);
}

.about-hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--space-3xl);
    align-items: center;
}

@media (max-width: 900px) {
    .about-hero__inner {
        grid-template-columns: 1fr;
        gap: var(--space-2xl);
    }
}

.about-hero__content {
    color: var(--color-white);
}

.about-hero__content .section-label {
    color: var(--color-accent-light);
}

.about-hero__title {
    font-size: clamp(2.5rem, 5vw, var(--font-size-h1));
    margin-bottom: var(--space-xs);
    line-height: 1.1;
    color: var(--color-white);
}

.about-hero__subtitle {
    font-family: var(--font-heading);
    font-size: var(--font-size-h4);
    color: var(--color-accent-light);
    margin-bottom: var(--space-md);
    font-weight: var(--font-weight-regular);
}

.about-hero__description {
    font-size: var(--font-size-h6);
    color: rgba(255, 255, 255, 0.85);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-xl);
    max-width: 560px;
}

.about-hero__actions {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
}

.about-hero__image-wrap {
    position: relative;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    overflow: hidden;
    aspect-ratio: 3/5;
    border: 10px solid rgba(255, 255, 255, 0.05);
}

.about-hero__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about-hero__badge {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(38, 26, 48, 0.9), transparent);
    color: var(--color-white);
    padding: var(--space-xl) var(--space-lg) var(--space-lg);
    display: flex;
    align-items: flex-end;
    gap: var(--space-sm);
}

.about-hero__badge-number {
    font-family: var(--font-body);
    font-size: 2.25rem;
    font-weight: var(--font-weight-bold);
    line-height: 1;
}

.about-hero__badge-text {
    font-size: var(--font-size-small);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    font-weight: var(--font-weight-medium);
    line-height: 1.4;
    opacity: 0.9;
}

/* Medical Philosophy */
.philosophy-layout {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: var(--space-3xl);
    align-items: center;
}

@media (max-width: 900px) {
    .philosophy-layout {
        grid-template-columns: 1fr;
    }
}

.philosophy-collage {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.philosophy-collage__main {
    position: relative;
}

.philosophy-collage__main .philosophy-img {
    aspect-ratio: 3 / 4;
    object-fit: cover;
    border: 1px solid var(--color-accent-light);
}

.philosophy-collage__bottom {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}

.philosophy-collage__img-wrap {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-accent-light);
}

.philosophy-collage__img-wrap:first-child {
    transform: translateY(8px);
}

.philosophy-collage__img-wrap:last-child {
    transform: translateY(-8px);
}

.philosophy-collage__img-wrap img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
}

.philosophy-image-wrapper {
    position: relative;
}

.philosophy-img {
    width: 100%;
    border-radius: var(--radius-lg);
    position: relative;
    z-index: 2;
    box-shadow: var(--shadow-xl);
}

.philosophy-bg-accent {
    position: absolute;
    inset: -20px -20px 20px 20px;
    background: var(--color-accent);
    border-radius: var(--radius-lg);
    z-index: 1;
}

.philosophy-content-col h2 {
    font-size: var(--font-size-h2);
    color: var(--color-primary);
    margin-bottom: var(--space-lg);
}

.philosophy-text p {
    margin-bottom: var(--space-md);
    font-size: var(--font-size-base);
    color: var(--color-text);
    line-height: var(--line-height-relaxed);
}

.philosophy-quote {
    margin-top: var(--space-xl);
    padding: var(--space-lg);
    background: var(--color-surface-alt);
    border-left: 3px solid var(--color-accent);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    position: relative;
}

.philosophy-quote i {
    color: var(--color-accent);
    font-size: 2rem;
    margin-bottom: var(--space-sm);
    display: block;
    opacity: 0.5;
}

.philosophy-quote blockquote {
    margin: 0;
    font-family: var(--font-heading);
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    line-height: var(--line-height-relaxed);
    font-style: italic;
}

/* Timeline CV */
.about-cv {
    background: var(--color-surface-alt);
}

.cv-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3xl);
}

@media (max-width: 900px) {
    .cv-layout {
        grid-template-columns: 1fr;
    }
}

.cv-column-title {
    font-size: var(--font-size-h4);
    color: var(--color-primary);
    margin-bottom: var(--space-xl);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.cv-column-title i {
    color: var(--color-accent-dark);
}

.timeline {
    position: relative;
    padding-left: 1.5rem;
}

.timeline::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--color-border);
}

.timeline-item {
    position: relative;
    margin-bottom: var(--space-xl);
}

.timeline-item:last-child {
    margin-bottom: 0;
}

.timeline-dot {
    position: absolute;
    left: -1.5rem;
    top: 0.25rem;
    width: 14px;
    height: 14px;
    background: var(--color-accent);
    border-radius: 50%;
    transform: translateX(-50%);
    box-shadow: 0 0 0 4px var(--color-surface-alt);
}

.timeline-date {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-accent-dark);
    margin-bottom: var(--space-xs);
    font-weight: var(--font-weight-bold);
}

.timeline-title {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin-bottom: 4px;
}

.timeline-org {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
    font-weight: var(--font-weight-medium);
}

.timeline-desc {
    font-size: var(--font-size-small);
    color: var(--color-text);
    line-height: var(--line-height-relaxed);
}

/* Informații Suplimentare */
.about-additional {
    background: var(--color-surface);
}

.additional-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--space-lg);
    margin-bottom: var(--space-2xl);
}

.additional-info-grid--2 {
    grid-template-columns: 1fr 1fr;
}

@media (max-width: 640px) {
    .additional-info-grid--2 {
        grid-template-columns: 1fr;
    }
}

.additional-card {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: var(--shadow-sm);
}

.additional-card--horizontal {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.additional-card--horizontal .additional-card__top {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.additional-card--horizontal .additional-card__icon {
    flex-shrink: 0;
    margin-bottom: 0;
}

.additional-card--horizontal .additional-card__title {
    flex: 1;
    margin-bottom: 0;
}

.additional-card--horizontal .additional-card__tags {
    width: 100%;
}

.additional-card__icon {
    width: 48px;
    height: 48px;
    background: var(--color-primary);
    color: var(--color-accent-light);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-md);
    font-size: 1.25rem;
}

.additional-card__title {
    font-size: var(--font-size-h6);
    color: var(--color-primary);
    margin-bottom: var(--space-sm);
}

.additional-card__list {
    font-size: var(--font-size-small);
    color: var(--color-text);
    line-height: var(--line-height-relaxed);
}

.additional-card__list li {
    margin-bottom: var(--space-2xs);
}

.additional-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2xs);
}

.additional-tag {
    display: inline-block;
    padding: var(--space-2xs) var(--space-sm);
    background: var(--color-surface-alt);
    color: var(--color-primary);
    font-size: var(--font-size-small);
    border-radius: var(--radius-sm);
    font-weight: var(--font-weight-medium);
}

.additional-card__text {
    font-size: var(--font-size-base);
    color: var(--color-text);
}

.additional-section {
    margin-top: var(--space-2xl);
    padding-top: var(--space-2xl);
    border-top: 1px solid var(--color-border);
}

.about-additional .section-heading + .additional-section {
    margin-top: var(--space-xl);
    padding-top: 0;
    border-top: none;
}

.additional-section__title {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin-bottom: var(--space-lg);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.additional-section__title i {
    color: var(--color-accent-dark);
}

.publications-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.publication-item {
    padding: var(--space-md);
    background: var(--color-surface-raised);
    border-left: 3px solid var(--color-accent);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.publication-item__title {
    font-size: var(--font-size-base);
    color: var(--color-primary);
    margin-bottom: var(--space-2xs);
}

.publication-item__venue,
.publication-item__journal {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    margin: 0;
}

.congress-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
}

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

.congress-col h4 {
    font-size: var(--font-size-h6);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
}

.congress-list {
    font-size: var(--font-size-small);
    color: var(--color-text);
    line-height: var(--line-height-relaxed);
}

.congress-list li {
    margin-bottom: var(--space-sm);
}

.congress-year {
    display: inline-block;
    min-width: 3rem;
    font-family: var(--font-mono);
    font-weight: var(--font-weight-bold);
    color: var(--color-accent-dark);
}

/* Locations Section */
.about-locations-box {
    background: var(--color-primary);
    border-radius: var(--radius-xl);
    overflow: hidden;
    display: grid;
    grid-template-columns: 60% 40%;
}

@media (max-width: 900px) {
    .about-locations-box {
        grid-template-columns: 1fr;
    }
}

.locations-box-content {
    padding: var(--space-2xl);
    color: var(--color-white);
}

.locations-box-icon {
    margin-bottom: var(--space-md);
}

.locations-box-icon i {
    font-size: 3rem;
    color: rgba(201, 166, 107, 0.4);
}

.locations-box-content h2 {
    color: var(--color-white);
    font-size: var(--font-size-h3);
    margin-bottom: var(--space-sm);
}

.locations-box-content p {
    color: rgba(255, 255, 255, 0.8);
    font-size: var(--font-size-base);
    margin-bottom: 0;
    max-width: 100%;
}

.locations-box-right {
    background: var(--color-primary-muted);
    padding: var(--space-2xl);
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 900px) {
    .locations-box-right {
        padding: var(--space-2xl);
    }
}

.locations-tag-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    width: 100%;
}

.location-tag {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-sm);
    padding: var(--space-md) var(--space-lg);
    width: 100%;
    min-width: 0;
}

.location-tag--link {
    text-decoration: none;
    color: inherit;
    transition: background-color 0.2s var(--transition-base), border-color 0.2s var(--transition-base);
}

.location-tag--link:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.3);
}

.location-tag__arrow {
    margin-left: auto;
    opacity: 0;
    transform: translateX(-4px);
    transition: opacity 0.2s var(--transition-base), transform 0.2s var(--transition-base);
    color: var(--color-accent-light);
}

.location-tag--link:hover .location-tag__arrow {
    opacity: 1;
    transform: translateX(0);
}

.location-tag i:first-child {
    color: var(--color-accent-light);
    font-size: 1.2rem;
}

.location-tag-info {
    flex: 1;
    min-width: 0;
}

.location-tag-info strong {
    display: block;
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
}

.location-tag-info span {
    display: block;
    font-size: var(--font-size-label);
    color: rgba(255, 255, 255, 0.7);
}

/* Blog Teaser */
.section-heading-split {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: var(--space-xl);
    gap: var(--space-md);
    flex-wrap: wrap;
}

.heading-split-left h2 {
    font-size: var(--font-size-h2);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.heading-split-left p {
    color: var(--color-text-muted);
    font-size: var(--font-size-base);
    margin: 0;
}

.about-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}

@media (max-width: 900px) {
    .about-blog-grid {
        grid-template-columns: 1fr;
    }
}

/* ===========================
   HOMEPAGE VARIANTS (DOMENII)
   =========================== */

/* VARIANTA 1: Minimalist Modern Grid */
.section-v1 {
    background: var(--color-surface);
    padding: var(--space-3xl) 0;
}

.v1-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
}

@media(max-width:900px) {
    .v1-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

.v1-card {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    display: flex;
    flex-direction: column;
    transition: all 0.3s var(--transition-base);
}

.v1-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-accent);
}

.v1-icon {
    font-size: 2.5rem;
    color: var(--color-primary);
    margin-bottom: var(--space-md);
}

.v1-card h3 {
    font-size: var(--font-size-h4);
    color: var(--color-primary);
    margin-bottom: var(--space-sm);
}

.v1-card p {
    font-size: var(--font-size-base);
    color: var(--color-text-muted);
    flex: 1;
    margin-bottom: var(--space-lg);
    line-height: var(--line-height-relaxed);
}

.v1-link {
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    text-transform: uppercase;
    color: var(--color-accent-dark);
    letter-spacing: var(--letter-spacing-wide);
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 600;
}

.v1-card:hover .v1-link {
    color: var(--color-primary);
}


/* ===========================
   HOMEPAGE PATHOLOGIES (VARIANTA 4: Focus & Expertiză)
   =========================== */

.section-v4 {
    padding-top: var(--space-4xl);
    padding-bottom: var(--space-2xl);
    background: var(--color-surface-alt);
}

.v4-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg);
    margin-top: var(--space-2xl);
}

@media (max-width: 768px) {
    .v4-cards {
        grid-template-columns: 1fr;
    }

    .v4-card__img {
        object-position: left center !important;
    }
}

.v4-card {
    display: block;
    background: linear-gradient(180deg, var(--color-surface-raised) 0%, var(--color-surface-alt) 100%);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 0;
    box-shadow: var(--shadow-sm);
    transition: box-shadow 0.3s ease;
    text-decoration: none;
    color: var(--color-text);
    overflow: hidden;
}

.v4-card:hover {
    box-shadow: 0 4px 16px rgba(58, 42, 69, 0.06);
}

.v4-card:hover .v4-card__img,
.v4-card:hover .v4-card__img-placeholder {
    transform: scale(1.05);
}

.v4-card__inner {
    display: grid;
    grid-template-columns: 60% 1fr;
    gap: 0;
    min-height: 140px;
    padding: var(--space-lg) 0 var(--space-lg) var(--space-lg);
}

.v4-card__left {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.v4-card__title {
    font-size: var(--font-size-h3);
    font-family: var(--font-heading);
    color: var(--color-primary-dark);
    margin-bottom: var(--space-sm);
}

.v4-card__tags {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.v4-card__tag {
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    padding: var(--space-xs) var(--space-md);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    transition: all 0.3s var(--transition-base);
}

.v4-card:hover .v4-card__tag {
    border-color: var(--color-accent);
    color: var(--color-accent-dark);
}

.v4-card__right {
    margin: calc(-1 * var(--space-lg)) 0 calc(-1 * var(--space-lg)) 0;
    display: flex;
    align-items: stretch;
    justify-content: stretch;
}

.v4-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right center;
    display: block;
    transition: transform 0.3s ease;
}

.v4-card__img-placeholder {
    min-height: 120px;
    width: 100%;
    background: var(--color-surface-alt);
    border-radius: var(--radius-sm);
    transition: transform 0.3s ease;
}

/* --- v4-box: Explorează domeniile - regiuni anatomice, patologie frecventă --- */
.explore-domains__title {
    text-align: center;
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-lg);
    font-family: var(--font-heading);
    font-size: var(--font-size-h2);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary-dark);
    letter-spacing: var(--letter-spacing-tight);
}

.explore-domains__cta {
    text-align: center;
    margin-top: var(--space-xl);
}

.btn-primary--medical {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    font-weight: var(--font-weight-medium);
}

.v4-cards--box {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
    margin-top: var(--space-lg);
}

@media (max-width: 1024px) {
    .v4-cards--box {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .v4-cards--box {
        grid-template-columns: 1fr;
    }
    /* Homepage #domenii păstrează 2 pe linie ca pe patologii */
    #domenii .v4-cards--box {
        grid-template-columns: repeat(2, 1fr);
    }
}

.v4-box {
    display: flex;
    flex-direction: column;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    color: var(--color-text);
    transition: box-shadow 0.35s var(--transition-base), border-color 0.35s var(--transition-base), transform 0.35s var(--transition-base);
}

.v4-box:hover {
    box-shadow: 0 12px 32px rgba(58, 42, 69, 0.1), 0 4px 12px rgba(58, 42, 69, 0.06);
    border-color: var(--color-accent);
    transform: translateY(-3px);
}

/* Imagine pătrată - clickable */
.v4-box__media {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-surface-alt);
    display: block;
    text-decoration: none;
    color: inherit;
}

.v4-box__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.5s var(--transition-base);
}

.v4-box:hover .v4-box__img {
    transform: scale(1.05);
}

.v4-box__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(166, 136, 90, 0.5) 0%, transparent 45%);
    opacity: 0;
    transition: opacity 0.35s var(--transition-base);
}

.v4-box:hover .v4-box__overlay {
    opacity: 1;
}

.v4-box__body {
    padding: var(--space-md) var(--space-md) var(--space-sm);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-2xs);
}

.v4-box__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-h4);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary-dark);
    margin: 0;
    transition: color 0.3s var(--transition-base);
}

.v4-box__title-link {
    color: inherit;
    text-decoration: none;
    transition: color 0.3s var(--transition-base);
}

.v4-box__title-link:hover {
    color: var(--color-primary);
}

.v4-box:hover .v4-box__title,
.v4-box:hover .v4-box__title-link {
    color: var(--color-primary);
}

/* Cea mai frecventă patologie: pe primul rând, numele pe rândul următor (link) */
.v4-box__pathology {
    display: flex;
    flex-direction: column;
}

.v4-box__pathology-label {
    font-size: var(--font-size-label);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-muted);
    letter-spacing: var(--letter-spacing-wide);
}

.v4-box__pathology-name {
    display: block;
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    color: var(--color-accent-dark);
    text-decoration: none;
    transition: color 0.3s var(--transition-base);
}

.v4-box__pathology-name:hover {
    color: var(--color-accent);
}

.v4-box__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-accent-dark);
    padding: var(--space-sm) var(--space-md);
    margin-top: var(--space-sm);
    border: 1.5px solid var(--color-accent);
    border-radius: var(--radius-sm);
    background: transparent;
    text-decoration: none;
    transition: color 0.3s var(--transition-base), background 0.3s var(--transition-base),
                border-color 0.3s var(--transition-base);
}

.v4-box__btn:hover {
    color: var(--color-white);
    background: var(--color-accent);
    border-color: var(--color-accent);
}


/* ===========================
   HOMEPAGE - DECIZIA DE A OPERA (CTA)
   =========================== */

.section-decision-cta {
    background: var(--color-primary);
    padding: var(--space-3xl) var(--space-lg);
    text-align: center;
}

.decision-cta__inner {
    max-width: 900px;
    margin: 0 auto;
}

.decision-cta__label {
    display: block;
    font-family: var(--font-mono);
    font-size: var(--font-size-label);
    font-weight: var(--font-weight-medium);
    color: var(--color-accent-light);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wider);
    margin-bottom: var(--space-md);
}

.decision-cta__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-h2);
    font-weight: var(--font-weight-semibold);
    color: var(--color-white);
    margin: 0 0 var(--space-2xl);
    line-height: var(--line-height-tight);
}

.decision-cta__pillars {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
    margin-bottom: var(--space-lg);
}

.decision-cta__pillar {
    padding: var(--space-lg);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    transition: all 0.3s var(--transition-base);
}

.decision-cta__pillar:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(201, 166, 107, 0.4);
}

.decision-cta__pillar-title {
    display: block;
    font-family: var(--font-heading);
    font-size: var(--font-size-h6);
    font-weight: var(--font-weight-semibold);
    color: var(--color-white);
}

.decision-cta__text {
    font-size: var(--font-size-body);
    color: rgba(255, 255, 255, 0.85);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--space-xl);
}

.decision-cta__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
}

@media (max-width: 768px) {
    .decision-cta__pillars {
        grid-template-columns: 1fr;
        gap: var(--space-md);
    }

    .decision-cta__title {
        font-size: var(--font-size-h3);
    }
}

/* Homepage mobile: spații reduse */
@media (max-width: 768px) {
    .section-motto {
        padding-top: var(--space-2xl);
        padding-bottom: var(--space-2xl);
    }

    .section-motto .motto-header {
        margin-bottom: var(--space-lg);
    }

    .section-motto .motto-body p {
        margin-bottom: var(--space-md);
    }

    .section-central-idea {
        padding-top: var(--space-xl);
        padding-bottom: var(--space-xl);
    }

    .section-central-idea h2 {
        margin-bottom: var(--space-md);
    }

    .section-v4 {
        padding-top: var(--space-2xl);
        padding-bottom: var(--space-xl);
    }

    .section-v4 h2 {
        margin-bottom: var(--space-lg);
    }

    .v4-cards {
        margin-top: var(--space-lg);
    }

    /* Homepage Focus & Expertiză - același stil ca pe pagina patologii (2 pe linie, font mic, fără patologie frecventă) */
    #domenii .v4-cards--box {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-sm);
    }
    #domenii .v4-box__body {
        padding: var(--space-sm);
    }
    #domenii .v4-box__pathology {
        display: none;
    }
    #domenii .v4-box__title {
        font-size: var(--font-size-h6);
    }
    #domenii .v4-box__btn {
        padding: 6px 0;
        font-size: var(--font-size-small);
        letter-spacing: 0;
    }

    .section-decision-cta {
        padding: var(--space-2xl) var(--space-md);
    }

    .decision-cta__title {
        margin-bottom: var(--space-lg);
    }

    .decision-cta__pillars {
        margin-bottom: var(--space-md);
    }

    .decision-cta__text {
        margin-bottom: var(--space-lg);
    }

    .section-articole {
        padding-top: var(--space-xl);
        padding-bottom: var(--space-md);
    }

    .blog-section {
        padding-top: var(--space-xl);
        padding-bottom: var(--space-md);
    }

    .section-despre .despre-grid {
        gap: var(--space-lg);
    }

    .cta-full--centered-primary {
        padding: var(--space-2xl) var(--space-md);
    }

    .cta-full--centered h2 {
        margin-bottom: var(--space-sm);
    }

    .cta-full--centered p {
        margin-bottom: var(--space-lg);
    }
}


/* VARIANTA 3: Asymmetric Focus */
.section-v3 {
    padding: var(--space-3xl) 0;
}

.v3-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3xl);
    align-items: center;
}

@media(max-width:900px) {
    .v3-layout {
        grid-template-columns: 1fr;
        gap: var(--space-xl);
    }
}

.v3-featured-img {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
}

.v3-featured-img img {
    width: 100%;
    height: auto;
    display: block;
}

.v3-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.v3-item {
    display: flex;
    gap: var(--space-lg);
    align-items: flex-start;
    padding: var(--space-lg);
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all 0.3s ease;
}

.v3-item:hover {
    background: var(--color-surface-alt);
    border-color: var(--color-accent);
    transform: translateX(8px);
    box-shadow: var(--shadow-sm);
}

.v3-icon {
    font-family: var(--font-mono);
    font-size: 2.5rem;
    color: var(--color-accent);
    font-weight: bold;
    line-height: 1;
    opacity: 0.8;
}

.v3-text h3 {
    font-size: var(--font-size-h5);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.v3-text p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
}

/* ===========================
   INLINE EDIT (Admin - genTxt, genImg)
   =========================== */
body.inline-edit-enabled .genTxt,
body.inline-edit-enabled .genImg {
    position: relative;
    border: 1px dotted #c00;
    padding: 2px;
    min-height: 1.2em;
}

body.inline-edit-enabled .genTxt {
    display: block;
}

/* genTxt în titluri (h1, h2, h3, h4): chenarul să cuprindă doar textul, nu întreaga linie */
body.inline-edit-enabled h1 .genTxt,
body.inline-edit-enabled h2 .genTxt,
body.inline-edit-enabled h3 .genTxt,
body.inline-edit-enabled h4 .genTxt,
body.inline-edit-enabled .contact-section-title .genTxt,
body.inline-edit-enabled .section-label .genTxt {
    display: inline-block;
}

/* Permite badge-ului (::before) și butonului să fie vizibile – părinții nu taie conținutul */
body.inline-edit-enabled .contact-info-section,
body.inline-edit-enabled .contact-info-split,
body.inline-edit-enabled .contact-locations {
    overflow: visible;
}

/* Wizard steps: genTxt compact, buton inline lângă text (nu overlay) */
body.inline-edit-enabled .wizard-step .genTxt {
    display: inline-block;
    border-color: rgba(201, 166, 107, 0.6);
}

body.inline-edit-enabled .wizard-step:hover .genTxt {
    border-color: var(--color-accent);
}

body.inline-edit-enabled .wizard-step .genTxt::before {
    top: -22px;
    left: 50%;
    transform: translateX(-50%);
}

body.inline-edit-enabled .wizard-step .genTxt .inline-edit-btn {
    position: relative;
    top: auto;
    right: auto;
    margin-left: 4px;
    vertical-align: middle;
    width: 20px;
    height: 20px;
    font-size: 10px;
}

body.inline-edit-enabled .wizard-steps {
    overflow: visible;
}

body.inline-edit-enabled .genTxt::before,
body.inline-edit-enabled .genImg::before {
    content: attr(data-identifier);
    position: absolute;
    top: -20px;
    left: 0;
    font-size: 10px;
    background: #c00;
    color: #fff;
    padding: 2px 6px;
    z-index: 1;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
}

body.inline-edit-enabled .genTxt:hover::before,
body.inline-edit-enabled .genImg:hover::before {
    opacity: 0.9;
}

body.inline-edit-enabled .genTxt .inline-edit-btn,
body.inline-edit-enabled .genImg .inline-edit-btn {
    position: absolute;
    top: 0;
    right: 0;
    width: 24px;
    height: 24px;
    padding: 0;
    border: none;
    background: #c00;
    color: #fff;
    cursor: pointer;
    font-size: 12px;
    display: flex;
    align-items: center;
    opacity: 0;
    transition: opacity 0.15s ease;
}

body.inline-edit-enabled .genTxt:hover .inline-edit-btn,
body.inline-edit-enabled .genImg:hover .inline-edit-btn {
    opacity: 1;
    justify-content: center;
    z-index: 2;
    border-radius: 2px;
}

body.inline-edit-enabled .genTxt .inline-edit-btn:hover,
body.inline-edit-enabled .genImg .inline-edit-btn:hover {
    background: #a00;
}

/* CTA patologii + form submit: buton edit inline lângă text, nu overlay */
body.inline-edit-enabled .pathology-article__cta .genTxt,
body.inline-edit-enabled .form-submit .genTxt {
    display: inline-block;
}

body.inline-edit-enabled .pathology-article__cta .genTxt .inline-edit-btn,
body.inline-edit-enabled .form-submit .genTxt .inline-edit-btn {
    position: relative;
    top: auto;
    right: auto;
    margin-left: 6px;
    vertical-align: middle;
}

body.inline-edit-enabled .pathology-article__cta,
body.inline-edit-enabled .form-submit {
    overflow: visible;
}

/* Inline edit modal popup */
.inline-edit-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    align-items: center;
    justify-content: center;
}

.inline-edit-modal[aria-hidden="false"] {
    display: flex;
}

.inline-edit-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
}

.inline-edit-modal__box {
    position: relative;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    width:95%;
    max-width: 600px;
}

.inline-edit-modal--editor .inline-edit-modal__box {
    max-width: 800px;
}

.inline-edit-modal__close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 20px;
    color: var(--color-text-muted);
}

.inline-edit-modal__close:hover {
    color: var(--color-text);
}

.inline-edit-modal__title {
    margin: 0;
    padding: 20px 20px 12px;
    font-size: var(--font-size-h5);
    color: var(--color-primary);
}

.inline-edit-modal__body {
    padding: 0 20px;
    overflow-y: auto;
    flex: 1;
}

.inline-edit-modal__body textarea,
.inline-edit-modal__body input[type="text"],
.inline-edit-modal__body input[type="file"] {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: var(--font-size-base);
    font-family: inherit;
}

.inline-edit-modal__body textarea {
    min-height: 150px;
    resize: vertical;
}

/* Editor tip: ascundem textarea-ul original, doar Summernote e vizibil */
.inline-edit-modal--editor #inline-edit-value {
    display: none !important;
}

.inline-edit-modal__body .form-group {
    margin-bottom: 16px;
}

.inline-edit-modal__body label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
}

.inline-edit-modal__actions {
    padding: 16px 20px;
    border-top: 1px solid var(--color-border);
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}