/*
Theme Name: Despacho Jurídico Theme
Theme URI: https://consultoriajuridicapatrimonialdelsur.com/
Description: Tema hijo de Hello Elementor para Consultoría Jurídica Patrimonial del Sur. Landing page de divulgación jurídica para Pasto, Nariño, Colombia.
Author: Consultoría Jurídica Patrimonial del Sur
Author URI: https://consultoriajuridicapatrimonialdelsur.com/
Template: hello-elementor
Version: 1.0.0
Text Domain: despacho-juridico-theme
*/

/* ── TOKENS ── */
:root {
  --forest:   #1E3A2F;
  --forest-lt:#2A5040;
  --siena:    #A0522D;
  --siena-lt: #C4703F;
  --sand:     #F2EDE3;
  --sand-dk:  #E8E0D0;
  --moss:     #4A6741;
  --white:    #FAFAF7;
  --text:     #1C2B22;
  --muted:    #5E6E5C;
  --serif:    'Playfair Display', Georgia, serif;
  --sans:     'IBM Plex Sans', sans-serif;
  --max:      1180px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--sans); color: var(--text); background: var(--white); line-height: 1.7; }

/* ── NAV ── */
nav.site-nav {
  position: fixed; top: 0; width: 100%; z-index: 100;
  background: var(--forest); border-bottom: 1px solid rgba(160,82,45,.25);
  padding: 0 2rem;
}
.nav-inner {
  max-width: var(--max); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
}
.nav-logo { font-family: var(--serif); font-size: 1.1rem; color: var(--sand); font-weight: 700; text-decoration: none; }
.nav-logo span { display: block; font-size: .62rem; color: rgba(242,237,227,.45); font-family: var(--sans); font-weight: 300; letter-spacing: .14em; text-transform: uppercase; }
.nav-links { display: flex; gap: 2rem; list-style: none; }
.nav-links a { color: rgba(242,237,227,.7); text-decoration: none; font-size: .85rem; font-weight: 400; letter-spacing: .03em; transition: color .2s; }
.nav-links a:hover { color: var(--siena-lt); }
.nav-cta {
  background: var(--siena); color: var(--white); padding: .45rem 1.3rem;
  font-size: .8rem; letter-spacing: .06em; text-transform: uppercase;
  font-family: var(--sans); cursor: pointer; transition: all .2s; text-decoration: none; font-weight: 500;
}
.nav-cta:hover { background: var(--siena-lt); }

/* ── HERO ── */
#hero {
  min-height: 100vh; background: var(--forest);
  display: grid; align-items: center;
  padding: 120px 2rem 80px;
  position: relative; overflow: hidden;
}
#hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(74,103,65,.3) 0%, transparent 70%),
              radial-gradient(ellipse 50% 80% at 20% 80%, rgba(160,82,45,.12) 0%, transparent 60%);
}
.hero-line {
  position: absolute; left: 0; top: 0; bottom: 0; width: 5px;
  background: var(--siena);
}
.hero-content { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; position: relative; z-index: 1; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .7rem;
  color: var(--siena-lt); font-family: var(--sans); font-size: .72rem;
  letter-spacing: .2em; text-transform: uppercase; font-weight: 500; margin-bottom: 1.8rem;
}
.hero-eyebrow::before { content: ''; display: block; width: 30px; height: 1px; background: var(--siena-lt); }
.hero-title {
  font-family: var(--serif); font-size: clamp(2.5rem, 5vw, 4.2rem);
  color: var(--sand); line-height: 1.15; font-weight: 700; margin-bottom: 1.5rem;
}
.hero-title em { color: var(--siena-lt); font-style: italic; }
.hero-sub {
  color: rgba(242,237,227,.6); font-size: 1rem; font-weight: 300;
  max-width: 480px; margin-bottom: 2.5rem; line-height: 1.85;
}
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.btn-primary {
  background: var(--siena); color: var(--white); padding: .9rem 2.2rem;
  font-family: var(--sans); font-size: .85rem; font-weight: 500; letter-spacing: .05em;
  text-transform: uppercase; text-decoration: none; transition: all .2s;
}
.btn-primary:hover { background: var(--siena-lt); }
.btn-ghost {
  background: transparent; color: rgba(242,237,227,.7); padding: .9rem 2.2rem;
  border: 1px solid rgba(242,237,227,.2); font-family: var(--sans); font-size: .85rem;
  letter-spacing: .05em; text-transform: uppercase; text-decoration: none; transition: all .2s;
}
.btn-ghost:hover { border-color: var(--siena-lt); color: var(--siena-lt); }
.hero-right {
  border: 1px solid rgba(160,82,45,.2); padding: 2.5rem;
  background: rgba(255,255,255,.04);
}
.hero-stat { padding: 1.2rem 0; border-bottom: 1px solid rgba(255,255,255,.07); }
.hero-stat:last-child { border-bottom: none; }
.hero-stat-label { font-size: .72rem; letter-spacing: .15em; text-transform: uppercase; color: rgba(242,237,227,.35); margin-bottom: .3rem; }
.hero-stat-val { font-family: var(--serif); font-size: 1.05rem; color: rgba(242,237,227,.8); }
.hero-disclaimer {
  position: absolute; bottom: 1.5rem; left: 0; right: 0;
  text-align: center; color: rgba(255,255,255,.22); font-size: .7rem; letter-spacing: .05em;
  padding: 0 2rem;
}

/* ── SECTIONS ── */
section { padding: 100px 2rem; }
.container { max-width: var(--max); margin: 0 auto; }
.section-label {
  font-family: var(--sans); font-size: .7rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--siena); font-weight: 500; margin-bottom: .8rem;
}
.section-title {
  font-family: var(--serif); font-size: clamp(1.9rem, 4vw, 2.9rem);
  color: var(--forest); line-height: 1.2; font-weight: 700; margin-bottom: 1.2rem;
}
.section-body { color: var(--muted); font-size: 1rem; max-width: 600px; line-height: 1.85; }
.ornament-bar { width: 50px; height: 3px; background: var(--siena); margin: 1.2rem 0 2rem; }

/* ── ACERCA ── */
#acerca { background: var(--sand); }
.acerca-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.acerca-visual {
  background: var(--forest); height: 480px; position: relative;
  display: flex; align-items: flex-end;
}
.acerca-visual::after {
  content: ''; position: absolute; top: 20px; left: 20px; right: -20px; bottom: -20px;
  border: 2px solid var(--siena); opacity: .3; z-index: 0;
}
.acerca-visual-inner {
  padding: 2.5rem; position: relative; z-index: 1; width: 100%;
  background: linear-gradient(to top, rgba(30,58,47,.95), transparent);
}
.acerca-visual-inner p { font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: rgba(242,237,227,.75); line-height: 1.6; }
.acerca-visual-inner cite { display: block; font-size: .75rem; color: var(--siena-lt); margin-top: .6rem; font-style: normal; letter-spacing: .1em; text-transform: uppercase; }
.pillar { margin-bottom: 2rem; padding-left: 1.2rem; border-left: 2px solid var(--siena); }
.pillar h4 { font-family: var(--serif); font-size: 1.15rem; color: var(--forest); margin-bottom: .4rem; }
.pillar p { color: var(--muted); font-size: .9rem; line-height: 1.8; }

/* ── TEMAS ── */
#temas { background: var(--white); }
.temas-header { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; margin-bottom: 4rem; align-items: end; }
.temas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.tema-card {
  border: 1px solid var(--sand-dk); padding: 2.2rem 1.8rem;
  transition: all .3s; position: relative; overflow: hidden;
}
.tema-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--siena); transform: scaleX(0); transform-origin: left; transition: transform .3s;
}
.tema-card:hover { border-color: transparent; box-shadow: 0 8px 40px rgba(30,58,47,.1); transform: translateY(-3px); }
.tema-card:hover::before { transform: scaleX(1); }
.tema-ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; margin-bottom: 1.1rem;
  color: var(--siena);
}
.tema-ico svg { width: 100%; height: 100%; display: block; }
.tema-card:hover .tema-ico { color: var(--forest); }
.tema-card h3 { font-family: var(--serif); font-size: 1.2rem; color: var(--forest); margin-bottom: .5rem; }
.tema-card p { font-size: .87rem; color: var(--muted); line-height: 1.75; }
.tema-link { display: inline-block; margin-top: .9rem; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--siena); text-decoration: none; font-weight: 500; }

/* ── PROCESO ── */
#proceso { background: var(--forest); }
#proceso .section-title { color: var(--sand); }
#proceso .section-body { color: rgba(242,237,227,.5); }
.proceso-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px;
  margin-top: 4rem; background: rgba(255,255,255,.06);
}
.paso {
  background: rgba(30,58,47,.8); padding: 2.5rem 2rem;
  border-top: 3px solid transparent; transition: border-color .3s;
}
.paso:hover { border-color: var(--siena); }
.paso-num {
  font-family: var(--serif); font-size: 3rem; color: rgba(160,82,45,.25);
  line-height: 1; margin-bottom: 1rem;
}
.paso h4 { font-family: var(--serif); font-size: 1.1rem; color: var(--sand); margin-bottom: .5rem; }
.paso p { font-size: .85rem; color: rgba(242,237,227,.45); line-height: 1.7; }

/* ── BLOG ── */
#blog { background: var(--sand); }
.blog-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 3.5rem; }
.blog-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1.5rem; }
.blog-featured { grid-row: span 2; }
.blog-card { background: var(--white); overflow: hidden; transition: box-shadow .25s; }
.blog-card:hover { box-shadow: 0 8px 30px rgba(30,58,47,.12); }
.blog-featured .blog-thumb { height: 320px; }
.blog-thumb {
  height: 180px; position: relative; overflow: hidden;
  background: var(--forest);
  display: grid; place-items: center;
}
.blog-thumb img { width: 100%; height: 100%; object-fit: cover; }
.blog-tag {
  position: absolute; top: 1rem; left: 1rem;
  background: var(--siena); color: var(--white);
  font-size: .65rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
  padding: .3rem .7rem; z-index: 2;
}
.blog-num {
  font-family: var(--serif); font-size: 5rem; font-weight: 700;
  color: rgba(242,237,227,.22); line-height: 1; letter-spacing: .02em;
}
.blog-featured .blog-num { font-size: 7rem; }
.blog-body { padding: 1.6rem; }
.blog-date { font-size: .73rem; color: var(--muted); letter-spacing: .06em; margin-bottom: .5rem; }
.blog-card h3 { font-family: var(--serif); color: var(--forest); margin-bottom: .6rem; line-height: 1.3; }
.blog-featured h3 { font-size: 1.4rem; }
.blog-card p { font-size: .87rem; color: var(--muted); line-height: 1.7; margin-bottom: 1rem; }
.read-more { font-size: .78rem; color: var(--siena); text-decoration: none; letter-spacing: .1em; text-transform: uppercase; font-weight: 500; }
.read-more::after { content: ' →'; }
.btn-outline {
  border: 1px solid var(--forest); color: var(--forest); padding: .75rem 2rem;
  font-family: var(--sans); font-size: .82rem; letter-spacing: .08em; text-transform: uppercase;
  text-decoration: none; transition: all .2s; display: inline-block;
}
.btn-outline:hover { background: var(--forest); color: var(--white); }
.blog-empty {
  background: var(--white); padding: 3rem 2rem; text-align: center;
  color: var(--muted); font-style: italic; font-size: .95rem;
}

/* ── RADIO ── */
#radio { background: var(--siena); padding: 70px 2rem; }
.radio-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: auto 1fr; gap: 3rem; align-items: center; }
.radio-ico-wrap {
  width: 80px; height: 80px; border-radius: 50%;
  background: rgba(255,255,255,.18); display: grid; place-items: center;
  color: var(--forest);
}
.radio-ico-wrap svg { width: 40px; height: 40px; display: block; }
.radio-inner h3 { font-family: var(--serif); font-size: 1.7rem; color: var(--white); margin-bottom: .4rem; }
.radio-inner p { color: rgba(255,255,255,.75); font-size: .95rem; }

/* ── ORIENTACION ── */
#orientacion { background: var(--white); }
.orientacion-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.wa-card {
  background: var(--forest); padding: 3rem; color: var(--sand);
}
.wa-card h3 { font-family: var(--serif); font-size: 1.6rem; color: var(--sand); margin-bottom: .8rem; }
.wa-card p { color: rgba(242,237,227,.65); font-size: .93rem; line-height: 1.8; margin-bottom: 2rem; }
.wa-card .email-line { font-size: .85rem; color: rgba(242,237,227,.5); margin-top: 1.2rem; }
.wa-card .email-line a { color: var(--siena-lt); text-decoration: none; }
.wa-card .email-line a:hover { color: var(--sand); }
.wa-btn {
  display: inline-flex; align-items: center; gap: .6rem;
  background: #25D366; color: #fff; padding: .9rem 2rem;
  font-family: var(--sans); font-size: .85rem; font-weight: 500;
  text-decoration: none; transition: opacity .2s;
}
.wa-btn:hover { opacity: .88; }
.disclaimer-box {
  margin-top: 2rem; padding: 1.5rem; background: var(--sand);
  border-left: 3px solid var(--siena); font-size: .82rem; color: var(--muted);
  line-height: 1.7; font-style: italic;
}

/* ── FOOTER ── */
footer.site-footer { background: var(--forest); color: rgba(242,237,227,.5); padding: 70px 2rem 30px; }
.footer-inner {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 4rem;
  padding-bottom: 3rem; border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer-logo { font-family: var(--serif); font-size: 1.25rem; color: var(--sand); margin-bottom: .6rem; font-weight: 700; }
.footer-tagline { font-size: .83rem; color: rgba(242,237,227,.35); line-height: 1.7; max-width: 300px; }
.footer-contact { margin-top: 1rem; font-size: .83rem; color: rgba(242,237,227,.4); }
.footer-contact a { color: var(--siena-lt); text-decoration: none; }
.footer-contact a:hover { color: var(--sand); }
footer.site-footer h4 { font-family: var(--sans); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--siena-lt); margin-bottom: 1.2rem; }
footer.site-footer ul { list-style: none; }
footer.site-footer ul li { margin-bottom: .6rem; }
footer.site-footer ul li a { color: rgba(242,237,227,.4); font-size: .87rem; text-decoration: none; transition: color .2s; }
footer.site-footer ul li a:hover { color: var(--siena-lt); }
.footer-bottom {
  max-width: var(--max); margin: 0 auto; padding-top: 1.5rem;
  display: flex; justify-content: space-between; align-items: center; font-size: .75rem;
  gap: 2rem; flex-wrap: wrap;
}
.legal-note { font-size: .72rem; color: rgba(242,237,227,.25); max-width: 600px; line-height: 1.6; }

/* ── WA FLOAT ── */
.wa-float {
  position: fixed; bottom: 2rem; right: 2rem; z-index: 999;
  background: #25D366; width: 58px; height: 58px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(0,0,0,.25); text-decoration: none; transition: transform .2s;
}
.wa-float:hover { transform: scale(1.08); }
.wa-float svg { width: 28px; height: 28px; fill: white; }

/* ── SINGLE POST ── */
.single-post-main {
  padding: 130px 2rem 80px;
  max-width: 800px;
  margin: 0 auto;
  min-height: 60vh;
}
.single-post-header {
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--sand-dk);
}
.single-post-meta {
  font-family: var(--sans);
  font-size: .75rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--siena);
  margin-bottom: 1rem;
  font-weight: 500;
}
.single-post-meta .sep { color: var(--muted); margin: 0 .5rem; opacity: .6; }
.single-post-title {
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: var(--forest);
  line-height: 1.2;
  font-weight: 700;
}
.single-post-thumb {
  margin: 0 0 2.5rem;
}
.single-post-thumb img {
  width: 100%;
  height: auto;
  display: block;
}
.single-post-content {
  font-family: var(--sans);
  font-size: 1.05rem;
  color: var(--text);
  line-height: 1.85;
}
.single-post-content > * { margin-bottom: 1.5rem; }
.single-post-content > *:last-child { margin-bottom: 0; }
.single-post-content h2 {
  font-family: var(--serif);
  font-size: 1.8rem;
  color: var(--forest);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  line-height: 1.3;
  font-weight: 700;
}
.single-post-content h3 {
  font-family: var(--serif);
  font-size: 1.4rem;
  color: var(--forest);
  margin-top: 2rem;
  margin-bottom: .8rem;
  line-height: 1.3;
  font-weight: 700;
}
.single-post-content h4,
.single-post-content h5,
.single-post-content h6 {
  font-family: var(--serif);
  color: var(--forest);
  margin-top: 1.8rem;
  margin-bottom: .6rem;
  line-height: 1.3;
}
.single-post-content ul,
.single-post-content ol {
  margin: 0 0 1.5rem 1.5rem;
  padding-left: .5rem;
}
.single-post-content li { margin-bottom: .5rem; }
.single-post-content img {
  max-width: 100%;
  height: auto;
  margin: 2rem 0;
  display: block;
}
.single-post-content blockquote {
  border-left: 3px solid var(--siena);
  padding: 1rem 1.5rem;
  margin: 2rem 0;
  font-style: italic;
  color: var(--muted);
  background: var(--sand);
}
.single-post-content a {
  color: var(--siena);
  text-decoration: underline;
}
.single-post-content a:hover { color: var(--siena-lt); }
.single-post-content strong { color: var(--forest); }
.single-post-disclaimer {
  margin-top: 3rem;
  padding: 1.5rem 1.8rem;
  background: var(--sand);
  border-left: 3px solid var(--siena);
  font-size: .88rem;
  color: var(--muted);
  line-height: 1.7;
  font-style: italic;
}
.single-post-back {
  display: inline-block;
  margin-top: 2.5rem;
  font-size: .8rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--siena);
  text-decoration: none;
  font-weight: 500;
}
.single-post-back::before { content: '← '; }
.single-post-back:hover { color: var(--siena-lt); }

/* ── ARCHIVE ── */
.archive-section {
  background: var(--sand);
  padding: 130px 2rem 100px;
  min-height: 80vh;
}
.archive-header {
  text-align: center;
  margin-bottom: 4rem;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}
.archive-header .ornament-bar {
  margin: 1.2rem auto 1.5rem;
}
.archive-header .section-body {
  margin: 0 auto;
}
.archive-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: var(--max);
  margin: 0 auto;
}
.archive-empty {
  text-align: center;
  padding: 3rem 2rem;
  color: var(--muted);
  font-style: italic;
  background: var(--white);
  max-width: var(--max);
  margin: 0 auto;
}
.archive-pagination {
  max-width: var(--max);
  margin: 3rem auto 0;
  text-align: center;
  font-family: var(--sans);
}
.archive-pagination .page-numbers {
  display: inline-block;
  padding: .5rem .9rem;
  margin: 0 .15rem;
  color: var(--forest);
  text-decoration: none;
  border: 1px solid var(--sand-dk);
  background: var(--white);
  font-size: .85rem;
  transition: all .2s;
}
.archive-pagination .page-numbers.current,
.archive-pagination .page-numbers:hover {
  background: var(--siena);
  color: var(--white);
  border-color: var(--siena);
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .hero-content, .acerca-grid, .orientacion-inner, .temas-header { grid-template-columns: 1fr; }
  .hero-right { display: none; }
  .proceso-grid { grid-template-columns: 1fr 1fr; }
  .temas-grid { grid-template-columns: 1fr 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .blog-header { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .radio-inner { grid-template-columns: 1fr; text-align: center; }
  .nav-links { display: none; }
  .acerca-visual { display: none; }
  .archive-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .archive-grid { grid-template-columns: 1fr; }
  .single-post-main { padding: 110px 1.2rem 60px; }
}
