/*
 * Le Bon Repos — legal pages (privacy-policy, mentions-legales) shared styles.
 */

.page-legal .site-content-inner.safar-container { max-width: none; padding: 0; }
.page-legal .safar-main-content-inner { margin: 0; }
.page-legal #primary { padding: 0; }
.page-legal .safar-single-page { margin: 0; }
.page-legal .post-thumbnail,
.page-legal .entry-title { display: none; }
.page-legal .entry-content { margin: 0; padding: 0; }

/* ---- Hero ---- */
.lbr-lg-hero {
  position: relative;
  padding: 80px 24px 60px;
  background: linear-gradient(135deg, #FAF5F1 0%, #F4EBDE 100%);
  text-align: center;
  border-bottom: 1px solid #EAEAEA;
}
.lbr-lg-hero__inner { max-width: 820px; margin: 0 auto; }
.lbr-lg-hero .lbr-eyebrow {
  letter-spacing: 4px; font-size: 12px; text-transform: uppercase;
  color: #C97A4F; font-weight: 600; display: inline-block; margin-bottom: 14px;
}
.lbr-lg-hero h1 {
  font-family: Marcellus, Georgia, serif;
  font-size: clamp(34px, 5vw, 52px);
  line-height: 1.1; margin: 0 0 14px;
  color: #362618; font-weight: 400;
}
.lbr-lg-hero p { font-size: 15px; color: #777; margin: 0; letter-spacing: .3px; }
.lbr-lg-hero p strong { color: #362618; }

/* ---- 2-col layout ---- */
.lbr-lg-main {
  max-width: 1180px; margin: 0 auto;
  padding: 60px 24px 100px;
  display: grid; grid-template-columns: 240px 1fr;
  gap: 60px; align-items: flex-start;
}
.lbr-lg-toc {
  position: sticky; top: 120px;
  background: #FAF5F1; border-radius: 12px;
  padding: 26px 24px;
}
.lbr-lg-toc h3 {
  font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase;
  color: #C97A4F; margin: 0 0 16px; font-weight: 700;
}
.lbr-lg-toc ol {
  list-style: none; padding: 0; margin: 0; counter-reset: toc;
}
.lbr-lg-toc li {
  counter-increment: toc;
  margin-bottom: 8px;
  font-size: 14px; line-height: 1.45;
}
.lbr-lg-toc li::before {
  content: counter(toc, decimal-leading-zero) ' ';
  font-family: Marcellus, Georgia, serif;
  color: #C97A4F; font-weight: 700;
  margin-right: 8px;
}
.lbr-lg-toc a {
  color: #555E63; text-decoration: none; transition: color .15s;
  border-bottom: 1px dotted transparent;
}
.lbr-lg-toc a:hover { color: #C97A4F; border-bottom-color: #C97A4F; }

/* ---- Article body ---- */
.lbr-lg-article { min-width: 0; }
.lbr-lg-section { padding: 14px 0 28px; border-bottom: 1px solid #EAEAEA; scroll-margin-top: 100px; }
.lbr-lg-section:last-child { border-bottom: none; padding-bottom: 0; }
.lbr-lg-section__head {
  display: flex; align-items: baseline; gap: 14px; margin-bottom: 16px;
}
.lbr-lg-section__num {
  font-family: Marcellus, Georgia, serif; font-size: 18px;
  color: #C97A4F; font-weight: 700; line-height: 1;
}
.lbr-lg-section h2 {
  font-family: Marcellus, Georgia, serif;
  font-size: clamp(22px, 3vw, 30px);
  color: #362618; margin: 0; line-height: 1.2; font-weight: 400;
}
.lbr-lg-section p,
.lbr-lg-section li {
  font-size: 16px; line-height: 1.7; color: #555E63; margin: 0 0 14px;
}
.lbr-lg-section p strong,
.lbr-lg-section li strong { color: #362618; font-weight: 700; }
.lbr-lg-section a { color: #C97A4F; font-weight: 600; text-decoration: none; border-bottom: 1px dotted #C97A4F; padding-bottom: 1px; }
.lbr-lg-section a:hover { color: #B16638; border-bottom-style: solid; }
.lbr-lg-section ul {
  margin: 8px 0 14px; padding: 0;
  list-style: none;
}
.lbr-lg-section ul li {
  position: relative; padding-left: 22px; margin-bottom: 8px;
}
.lbr-lg-section ul li::before {
  content: '✓'; position: absolute; left: 0; top: 0;
  color: #C97A4F; font-weight: 700;
}
.lbr-lg-section h3 {
  font-family: Marcellus, Georgia, serif;
  font-size: 19px;
  color: #362618; margin: 22px 0 10px; font-weight: 400;
}
.lbr-lg-section .lbr-lg-callout {
  background: #FAF5F1; border-left: 4px solid #C97A4F;
  padding: 18px 22px; border-radius: 6px; margin: 16px 0;
}
.lbr-lg-section .lbr-lg-callout p { margin: 0; font-size: 15px; }
.lbr-lg-section .lbr-lg-callout strong { color: #C97A4F; }

/* Definition list — clean rows */
.lbr-lg-section dl {
  display: grid; grid-template-columns: 180px 1fr;
  gap: 8px 24px; margin: 16px 0;
  padding: 18px 22px;
  background: #FAF5F1; border-radius: 8px;
  font-size: 15px;
}
.lbr-lg-section dt { color: #777; font-weight: 600; letter-spacing: .3px; }
.lbr-lg-section dd { margin: 0; color: #362618; font-weight: 600; }

/* ---- Footer note ---- */
.lbr-lg-foot {
  background: #362618; color: #f4ebde;
  padding: 60px 24px;
  text-align: center;
}
.lbr-lg-foot h2 {
  font-family: Marcellus, Georgia, serif; font-size: 28px;
  color: #fff; margin: 0 0 12px; font-weight: 400;
}
.lbr-lg-foot p { font-size: 16px; color: #f4ebde; margin: 0 0 22px; line-height: 1.6; }
.lbr-lg-foot a {
  display: inline-block; padding: 12px 28px;
  background: #C97A4F; color: #fff; text-decoration: none;
  border-radius: 6px; font-weight: 600; letter-spacing: 1.5px;
  font-size: 13px; text-transform: uppercase;
}
.lbr-lg-foot a:hover { background: #B16638; color: #fff; }

/* ---- Responsive ---- */
@media (max-width: 992px) {
  .lbr-lg-main { grid-template-columns: 1fr; gap: 30px; padding: 40px 22px 70px; }
  .lbr-lg-toc { position: static; top: auto; }
  .lbr-lg-section dl { grid-template-columns: 1fr; gap: 4px; }
  .lbr-lg-section dt { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; }
}
@media (max-width: 600px) {
  .lbr-lg-hero { padding: 60px 18px 40px; }
  .lbr-lg-hero h1 { font-size: 28px; }
  .lbr-lg-main { padding: 30px 18px 50px; }
  .lbr-lg-section h2 { font-size: 22px; }
  .lbr-lg-section p, .lbr-lg-section li { font-size: 15px; }
  .lbr-lg-foot { padding: 50px 18px; }
}
