/* ===========================================================
   components.css · piezas reutilizables del sitio
   =========================================================== */

/* ---------- HERO (Inicio) ---------- */
.hero { padding-block: clamp(28px,4vw,52px) clamp(34px,5vw,64px); }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px,6vw,76px); align-items: center; }
.hero h1 { font-size: clamp(40px,6.4vw,74px); line-height: 1.02; color: var(--wine); }
.hero h1 em { font-style: italic; color: var(--gold-ink); }
.hero .lead { margin-top: 24px; max-width: 32ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-note { margin-top: 22px; font-size: 14px; color: var(--tx-soft); display: flex; align-items: center; gap: 9px; }
.hero-note svg { width: 17px; height: 17px; color: var(--gold-ink); flex: none; }

.portrait-wrap { position: relative; }
.portrait { aspect-ratio: 4/5; border-radius: 50% 50% 8px 8px / 30% 30% 8px 8px; border: 1px solid rgba(110,43,58,.14); box-shadow: var(--shadow-md); overflow: hidden; }
.portrait img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 22%; border-radius: inherit; }
.portrait::before { content:""; position:absolute; inset:-12px; border:1px solid var(--gold); border-radius: 50% 50% 18px 18px / 30% 30% 18px 18px; pointer-events:none; z-index: 1; }
.portrait span { max-width: 17ch; }
.badge-card { position: absolute; left: -16px; bottom: 22px; background: var(--card); border: 1px solid rgba(110,43,58,.1);
  border-top: 2px solid var(--gold); border-radius: var(--r-md); padding: 14px 18px; box-shadow: var(--shadow-sm);
  display: flex; align-items: center; gap: 12px; max-width: 236px; }
.badge-card .dot { width: 40px; height: 40px; border-radius: 50%; border: 1.5px solid var(--gold); display: grid; place-items: center; color: var(--wine); flex: none; }
.badge-card .dot svg { width: 20px; height: 20px; }
.badge-card p { font-size: 12.5px; line-height: 1.35; color: var(--tx-soft); }
.badge-card b { color: var(--wine); font-weight: 600; }

/* ---------- trust strip ---------- */
.trust { border-block: 1px solid rgba(110,43,58,.12); background: var(--card); }
.trust .wrap { padding-block: 28px; }

/* ---------- value grid ---------- */
.value-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; margin-top: 10px; }
.value-card .vnum { font-family: var(--serif); font-size: 15px; color: var(--gold-ink); letter-spacing: .08em; }
.value-card h3 { font-size: 24px; color: var(--wine); margin: 12px 0 10px; }
.value-card p { color: var(--tx-soft); font-size: 16px; }

/* ---------- areas ---------- */
.areas-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 40px; }
.areas-head h2 { font-size: clamp(30px,4.4vw,46px); color: var(--wine); max-width: 16ch; }
.areas-head h2 em { font-style: italic; color: var(--gold-ink); }
.area-list { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.area-card { background: var(--card); border: 1px solid rgba(110,43,58,.1); border-radius: var(--r-md);
  padding: 30px 30px 26px; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  display: flex; flex-direction: column; gap: 12px; position: relative; overflow: hidden; }
.area-card::before { content:""; position:absolute; top:0; left:0; right:0; height:3px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .25s ease; }
.area-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.area-card:hover::before { transform: scaleX(1); }
.area-card .anum { font-family: var(--serif); font-size: 14px; color: var(--gold-ink); }
.area-card h3 { font-size: 25px; color: var(--wine); }
.area-card p { font-size: 15.5px; color: var(--tx-soft); flex: 1; }
.area-card .link-gold { font-size: 15px; margin-top: 4px; }

/* ---------- sobre block ---------- */
.sobre { background: var(--ivory-200); }
.sobre-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(32px,6vw,70px); align-items: center; }
.sobre-portrait { aspect-ratio: 1/1; border-radius: var(--r-lg); border: 1px solid rgba(110,43,58,.14); position: relative; overflow: hidden; }
.sobre-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%; border-radius: inherit; }
.sobre-portrait::before { content:""; position:absolute; inset:14px; border:1px solid var(--gold); border-radius: calc(var(--r-lg) - 6px); pointer-events:none; z-index: 1; }
.sobre blockquote { margin: 0; }
.sobre blockquote p { font-family: var(--serif); font-size: clamp(24px,3.2vw,34px); line-height: 1.32; color: var(--wine); }
.sobre blockquote p em { font-style: italic; color: var(--gold-ink); }
.sobre cite { display: block; margin-top: 22px; font-style: normal; font-size: 15px; color: var(--tx-soft); }
.sobre cite b { color: var(--wine); font-family: var(--serif); font-size: 18px; font-weight: 500; display: block; }

/* ---------- testimonios ---------- */
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.testi-card { background: var(--card); border: 1px solid rgba(110,43,58,.1); border-radius: var(--r-md); padding: 28px; display: flex; flex-direction: column; }
.stars { display: flex; gap: 3px; color: var(--gold); margin-bottom: 14px; font-size: 16px; letter-spacing: 2px; }
.testi-card p { font-size: 16px; color: var(--tx); line-height: 1.6; flex: 1; }
.testi-card .who { margin-top: 20px; display: flex; align-items: center; gap: 12px; }
.testi-card .who .av { width: 42px; height: 42px; border-radius: 50%; background: var(--blush); display: grid; place-items: center; font-family: var(--serif); color: var(--wine); flex: none; font-size: 17px; }
.testi-card .who b { font-size: 15px; color: var(--wine); font-weight: 600; }
.testi-card .who small { display: block; font-size: 13px; color: var(--tx-soft); }

/* ---------- proceso ---------- */
.proceso-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; margin-top: 12px; }
.step .snum { font-family: var(--serif); font-size: 40px; color: var(--gold); line-height: 1; }
.step h3 { font-size: 21px; color: var(--wine); margin: 14px 0 8px; }
.step p { color: var(--tx-soft); font-size: 15.5px; }

/* ---------- CTA band ---------- */
.cta-band { background: var(--wine); color: var(--ivory); border-radius: var(--r-lg); padding: clamp(40px,6vw,70px); text-align: center; position: relative; overflow: hidden; }
.cta-band::after { content:""; position:absolute; inset:0; background: radial-gradient(100% 120% at 50% -20%, rgba(193,154,91,.22), transparent 60%); pointer-events:none; }
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { font-size: clamp(28px,4vw,44px); color: var(--ivory); max-width: 20ch; margin-inline: auto; }
.cta-band h2 em { font-style: italic; color: var(--gold-soft); }
.cta-band p { color: var(--onwine-soft); margin: 18px auto 30px; max-width: 46ch; }
.cta-band .hero-cta { justify-content: center; }

/* ---------- generic split (interior) ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,6vw,70px); align-items: center; }
.split.narrow-left { grid-template-columns: .85fr 1.15fr; }
.split .ph { aspect-ratio: 4/5; border-radius: var(--r-lg); }

/* ---------- area page: services list ---------- */
.svc-list { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.svc { background: var(--card); border: 1px solid rgba(110,43,58,.1); border-radius: var(--r-md); padding: 24px; display: flex; gap: 16px; }
.svc .mk { width: 38px; height: 38px; flex: none; border-radius: 50%; border: 1.5px solid var(--gold); color: var(--wine); display: grid; place-items: center; font-family: var(--serif); font-size: 15px; }
.svc h3 { font-size: 19px; color: var(--wine); margin-bottom: 5px; }
.svc p { font-size: 14.5px; color: var(--tx-soft); }

/* numbered process (interior) */
.steps-num { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; counter-reset: st; }
.steps-num .sc { counter-increment: st; }
.steps-num .sc::before { content: counter(st,decimal-leading-zero); font-family: var(--serif); font-size: 30px; color: var(--gold); display: block; margin-bottom: 10px; }
.steps-num h3 { font-size: 18px; color: var(--wine); margin-bottom: 6px; }
.steps-num p { font-size: 14.5px; color: var(--tx-soft); }

/* ---------- FAQ accordion ---------- */
.faq-list { max-width: 820px; margin-inline: auto; }
.faq-item { border-bottom: 1px solid rgba(110,43,58,.14); }
.faq-q { width: 100%; background: none; border: 0; cursor: pointer; text-align: left; font-family: var(--serif);
  font-size: clamp(19px,2.2vw,23px); color: var(--wine); padding: 24px 44px 24px 0; position: relative; display: block; }
.faq-q::after { content:"+"; position: absolute; right: 6px; top: 50%; transform: translateY(-50%); font-family: var(--sans); font-size: 26px; color: var(--gold); transition: transform .25s ease; line-height: 1; }
.faq-item.open .faq-q::after { content:"–"; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-a p { padding: 0 40px 26px 0; color: var(--tx-soft); font-size: 16.5px; line-height: 1.7; }
.faq-item.open .faq-a { max-height: 420px; }

/* ---------- blog ---------- */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 26px; }
.post-card { background: var(--card); border: 1px solid rgba(110,43,58,.1); border-radius: var(--r-md); overflow: hidden;
  display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease; }
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.post-card .thumb { aspect-ratio: 16/10; }
.post-card .body { padding: 24px; display: flex; flex-direction: column; flex: 1; }
.post-card .cat { font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--gold-ink); margin-bottom: 10px; }
.post-card h3 { font-size: 21px; color: var(--wine); line-height: 1.2; }
.post-card p { font-size: 15px; color: var(--tx-soft); margin-top: 10px; flex: 1; }
.post-card .pmeta { margin-top: 18px; font-size: 13px; color: var(--tx-soft); display: flex; gap: 8px; }
.post-card.feature { grid-column: 1 / -1; flex-direction: row; }
.post-card.feature .thumb { aspect-ratio: auto; flex: 1.1; min-height: 280px; }
.post-card.feature .body { flex: 1; justify-content: center; padding: clamp(28px,4vw,48px); }
.post-card.feature h3 { font-size: clamp(26px,3.4vw,38px); }
@media (max-width: 820px){ .post-card.feature { flex-direction: column; } .post-card.feature .thumb { min-height: 200px; } }

/* ---------- article ---------- */
.article { max-width: 760px; margin-inline: auto; }
.article-meta { display: flex; flex-wrap: wrap; gap: 8px 18px; font-size: 14px; color: var(--tx-soft); margin-bottom: 30px; }
.article-meta .cat { color: var(--gold-ink); font-weight: 600; }
.article .hero-img { aspect-ratio: 16/8; border-radius: var(--r-lg); margin-bottom: 40px; }
.author-card { display: flex; gap: 18px; align-items: center; background: var(--card); border: 1px solid rgba(110,43,58,.1); border-left: 3px solid var(--gold); border-radius: var(--r-md); padding: 24px; margin-top: 48px; }
.author-card .av { width: 60px; height: 60px; border-radius: 50%; background: var(--blush); display: grid; place-items: center; font-family: var(--serif); font-size: 24px; color: var(--wine); flex: none; }
.author-card b { font-family: var(--serif); font-size: 19px; color: var(--wine); font-weight: 500; }
.author-card p { font-size: 14px; color: var(--tx-soft); margin-top: 3px; }

/* ---------- contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr .9fr; gap: clamp(32px,5vw,60px); align-items: start; }
.contact-info .info-item { display: flex; gap: 14px; padding: 18px 0; border-bottom: 1px solid rgba(110,43,58,.12); }
.contact-info .info-item:last-child { border-bottom: 0; }
.contact-info .mk { width: 42px; height: 42px; flex: none; border-radius: 50%; border: 1.5px solid var(--gold); color: var(--wine); display: grid; place-items: center; }
.contact-info .mk svg { width: 20px; height: 20px; }
.contact-info h4 { font-family: var(--sans); font-size: 13px; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-ink); margin-bottom: 4px; }
.contact-info p { color: var(--tx); font-size: 16px; }
.contact-info a { color: var(--wine); font-weight: 500; }
.form-card { background: var(--card); border: 1px solid rgba(110,43,58,.12); border-top: 3px solid var(--gold); border-radius: var(--r-lg); padding: clamp(26px,4vw,40px); box-shadow: var(--shadow-sm); }
.form-card h3 { font-size: 26px; color: var(--wine); margin-bottom: 6px; }
.form-card .sub { color: var(--tx-soft); font-size: 15px; margin-bottom: 24px; }
.form-card .btn { width: 100%; justify-content: center; margin-top: 6px; }
.form-card .priv { font-size: 12.5px; color: var(--tx-soft); text-align: center; margin-top: 14px; }

/* responsive */
@media (max-width: 900px){
  .hero-grid, .sobre-grid, .split, .split.narrow-left, .contact-grid { grid-template-columns: 1fr; }
  .portrait-wrap { max-width: 420px; margin-inline: auto; order: -1; }
  .value-grid, .testi-grid, .proceso-grid { grid-template-columns: 1fr; }
  .area-list, .svc-list, .blog-grid { grid-template-columns: 1fr; }
  .steps-num { grid-template-columns: 1fr 1fr; }
  .areas-head { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 560px){ .steps-num { grid-template-columns: 1fr; } }

/* ===========================================================
   Refuerzo de contraste y ritmo (ajuste solicitado)
   =========================================================== */
/* Tarjetas más despegadas del fondo */
.area-card, .testi-card, .post-card, .svc, .value-card-boxed {
  border-color: rgba(99,31,45,.16);
  box-shadow: 0 1px 2px rgba(47,16,25,.05), 0 10px 26px rgba(47,16,25,.06);
}
.form-card { border-color: rgba(99,31,45,.16); }
.svc { box-shadow: 0 1px 2px rgba(47,16,25,.05), 0 8px 20px rgba(47,16,25,.05); }

/* Texto cuerpo con más presencia */
.value-card p, .area-card p, .step p, .svc p, .steps-num p { color: #443A39; }
.lead, .muted { color: #4D4140; }
.prose, .prose p { color: #312827; }

/* Franja de confianza más marcada */
.trust { background: var(--ivory-200); }
.chip { color: #463B3A; }

/* Headings con peso ligeramente mayor para reforzar jerarquía */
.hero h1, .page-hero h1 { font-weight: 500; }

/* Apretar márgenes internos grandes */
.areas-head { margin-bottom: 30px; }
.proceso-grid, .value-grid { gap: 24px; }

@media (max-width: 700px){
  .hero-cta { gap: 10px; }
  .hero .lead { margin-top: 18px; }
  .hero-grid, .sobre-grid, .split, .split.narrow-left { gap: 26px; }
  .center[style] { margin-bottom: 26px !important; }
  .cta-band { padding: 34px 22px; }
  .portrait-wrap { max-width: 340px; }
  .badge-card { left: 0; }
}
