/*
 * Pattern-uri partajate pentru paginile interioare (despre, servicii, contact, landing).
 * Stil editorial din mockup v6 (Fraunces + accente aurii + paletă verde/crem).
 * Clase cu prefix .pg-* / .ed-* / .cards / .feat — distincte de homepage (fără conflict).
 * Încărcat global pe paginile non-home (vezi inc/setup/enqueue.php). Anti-duplicare:
 * aceste componente se refolosesc, nu se rescriu per pagină.
 */

/* ===== PAGE HERO (antet pagină) ===== */
.pg-hero { position: relative; background: var(--green); color: var(--ivory); overflow: hidden; }
.pg-hero .container { position: relative; z-index: 2; padding-top: 96px; padding-bottom: 88px; }
.pg-hero.has-img::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(33,54,49,.92), rgba(33,54,49,.7)); }
.pg-hero .pg-hero-bg { position: absolute; inset: 0; z-index: 0; }
.pg-hero .pg-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.pg-hero .eyebrow { color: #e0d3ba; }
.pg-hero h1 { font-size: clamp(2.8rem, 6vw, 5rem); font-weight: 300; color: var(--white); line-height: 1.05; margin: 14px 0 0; letter-spacing: -.01em; }
.pg-hero h1 em { font-style: italic; color: #ecdcbd; }
.pg-hero .pg-sub { font-family: 'Fraunces'; font-style: italic; font-size: clamp(1.3rem, 2.6vw, 2rem); color: #ece4d6; font-weight: 300; margin-top: 16px; max-width: 760px; }
.pg-hero .pg-lead { color: #ddd6c9; max-width: 660px; margin-top: 20px; font-size: 1.05rem; }
.pg-hero .pg-actions { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 34px; }

/* ===== EDITORIAL (text ↔ media, alternant) ===== */
.ed { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.ed--rev .ed-media { order: 2; }
.ed-media { position: relative; }
.ed-media img { width: 100%; height: 100%; max-height: 620px; object-fit: cover; }
.ed-media .frame { position: absolute; top: -22px; left: -22px; right: 22px; bottom: 22px; border: 1px solid var(--gold); z-index: -1; }
.ed h2 { font-size: clamp(2.2rem, 4vw, 3.4rem); font-weight: 300; margin-bottom: 18px; }
.ed h2 em { font-style: italic; color: var(--gold-deep); }
.ed p { color: var(--green-soft); margin-bottom: 18px; }
.ed p strong, .ed p b { color: var(--green); font-weight: 500; }

/* ===== CARDS (grilă editorială fără iconuri) ===== */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.card { background: var(--white); border-top: 3px solid var(--gold); padding: 40px 36px; transition: transform .35s, box-shadow .35s; }
.card:hover { transform: translateY(-6px); box-shadow: 0 28px 52px rgba(33,54,49,.12); }
.card .card-idx { font-family: 'Fraunces'; font-style: italic; font-size: 1.2rem; color: var(--gold); margin-bottom: 12px; }
.card h3 { font-family: 'Fraunces'; font-size: 1.55rem; font-weight: 400; color: var(--green); margin-bottom: 12px; line-height: 1.2; }
.card p { font-size: .95rem; color: var(--green-soft); }
.card p strong, .card p b { color: var(--green); font-weight: 500; }

/* Variante grilă carduri */
.cards.cards-4 { grid-template-columns: repeat(4, 1fr); gap: 24px; }
.cards.cards-2 { grid-template-columns: repeat(2, 1fr); max-width: 940px; margin: 0 auto; }
.card-feat { list-style: none; margin: 16px 0 18px; }
.card-feat li { font-size: .88rem; color: var(--green-soft); padding: 4px 0; display: flex; gap: 8px; }
.card-feat li.hl { color: var(--green); font-weight: 500; }
.card-price { font-family: 'Fraunces'; font-style: italic; font-size: 1.2rem; color: var(--gold-deep); margin: auto 0 14px; padding-top: 6px; }
.card-link { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--green); display: inline-flex; gap: 8px; border-bottom: 1px solid var(--gold); padding-bottom: 4px; align-self: flex-start; transition: gap .3s; }
.card-link:hover { gap: 14px; }
.card.card-flex { display: flex; flex-direction: column; }

/* ===== FEATURE LIST (h4 + p, accent auriu) ===== */
.feat-list { display: grid; grid-template-columns: 1fr 1fr; gap: 30px 44px; }
.feat { padding-left: 20px; border-left: 2px solid var(--gold); }
.feat h4 { font-family: 'Fraunces'; font-size: 1.3rem; font-weight: 500; color: var(--green); margin-bottom: 6px; }
.feat h4 span, .feat h4 em { color: var(--gold-deep); font-style: italic; }
.feat p { font-size: .9rem; color: var(--green-soft); margin: 0; }

/* ===== QUOTE BOX ===== */
.quote-box { background: var(--green); color: var(--ivory); padding: 54px 48px; position: relative; }
.quote-box .q-mark { font-family: 'Fraunces'; font-size: 4rem; line-height: .6; color: var(--gold); }
.quote-box blockquote { font-family: 'Fraunces'; font-style: italic; font-size: 1.8rem; font-weight: 300; color: var(--white); margin: 16px 0; line-height: 1.3; }
.quote-box .q-desc { font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; color: #bdb6a7; }

/* ===== INNER CTA ===== */
.pg-cta { position: relative; text-align: center; padding: 110px 0; color: var(--white); background: var(--green); overflow: hidden; }
.pg-cta.has-img::after { content: ""; position: absolute; inset: 0; z-index: -1; background: rgba(33,54,49,.85); }
.pg-cta .pg-cta-bg { position: absolute; inset: 0; z-index: -2; }
.pg-cta .pg-cta-bg img { width: 100%; height: 100%; object-fit: cover; }
.pg-cta .eyebrow { color: #e0d3ba; }
.pg-cta h2 { font-size: clamp(2.4rem, 5vw, 4.2rem); font-weight: 300; color: var(--white); margin: 14px 0 16px; }
.pg-cta h2 em { font-style: italic; color: #ecdcbd; }
.pg-cta p { color: #ddd6c9; max-width: 560px; margin: 0 auto 36px; font-size: 1.08rem; }
.pg-cta .pg-actions { display: flex; gap: 18px; justify-content: center; flex-wrap: wrap; }

/* ===== two-column stacked blocks (ex. echipă + mentorat) ===== */
.col2 { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; }
.col2 h3 { font-family: 'Fraunces'; font-size: 1.8rem; font-weight: 400; color: var(--green); margin-bottom: 16px; }
.col2 p { color: var(--green-soft); margin-bottom: 16px; }
.col2 p strong, .col2 p b { color: var(--green); font-weight: 500; }

/* ===== RESPONSIVE ===== */
@media (max-width: 920px) {
    .ed, .col2 { grid-template-columns: 1fr; gap: 48px; }
    .ed--rev .ed-media { order: 0; }
    .ed-media .frame { display: none; }
    .cards { grid-template-columns: 1fr 1fr; }
    .pg-hero .container { padding-top: 64px; padding-bottom: 60px; }
}
@media (max-width: 920px) {
    .cards.cards-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
    .cards, .cards.cards-4, .cards.cards-2, .feat-list { grid-template-columns: 1fr; }
}
