/* =========================================================
   LE PARC PLACE — Tin tức & Bài viết (self-contained)
   Đồng bộ design tokens với trang chủ
========================================================= */
:root{
  --ink:#1B1A17; --ink-soft:#3A3631;
  --paper:#F6F1E8; --paper-2:#EDE6D7; --bone:#E2D8C2;
  --burgundy:#5E1E22; --burgundy-2:#7A2A2E;
  --sage:#6E7A5E; --brass:#B89255; --brass-2:#D9B074;
  --line:rgba(27,26,23,.14); --line-2:rgba(27,26,23,.08);
  --shadow-1:0 1px 2px rgba(27,26,23,.06), 0 10px 30px -12px rgba(27,26,23,.16);
  --ff-display:"Fraunces","Times New Roman",serif;
  --ff-sans:"Be Vietnam Pro",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --maxw:1200px;
  --read:760px;
  --gutter:clamp(20px,4vw,56px);
  --radius:2px;
}
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:90px; }
html,body{ width:100%; max-width:100%; overflow-x:hidden; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--ff-sans); font-size:16px; line-height:1.7;
  font-weight:400; -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--burgundy); text-decoration:none; }
::selection{ background:var(--burgundy); color:var(--paper); }

/* ---------- Header ---------- */
.nh{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:14px var(--gutter);
  background:rgba(246,241,232,.92);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-2);
}
.nh__brand{ line-height:1; display:flex; flex-direction:column; gap:2px; }
.nh__brand .le{ font-family:var(--ff-display); font-style:italic; font-size:11px; letter-spacing:.32em; color:var(--brass); }
.nh__brand .name{ font-family:var(--ff-display); font-size:21px; letter-spacing:.02em; color:var(--burgundy); }
.nh__links{ display:flex; align-items:center; gap:26px; }
.nh__links a{ font-size:14px; font-weight:500; letter-spacing:.02em; color:var(--ink-soft); transition:color .3s; }
.nh__links a:hover, .nh__links a[aria-current]{ color:var(--burgundy); }
.nh__cta{
  padding:9px 18px; border:1px solid var(--burgundy); border-radius:999px;
  color:var(--burgundy) !important; font-weight:600; font-size:13px; letter-spacing:.03em;
  transition:all .3s;
}
.nh__cta:hover{ background:var(--burgundy); color:var(--paper) !important; }
@media (max-width:760px){
  .nh__links a:not(.nh__cta){ display:none; }
  .nh__brand .name{ font-size:18px; }
}

/* ---------- Breadcrumb ---------- */
.crumb{ max-width:var(--maxw); margin:0 auto; padding:22px var(--gutter) 0; }
.crumb ol{ list-style:none; display:flex; flex-wrap:wrap; gap:8px; margin:0; padding:0; font-size:12.5px; color:var(--ink-soft); }
.crumb li::after{ content:"›"; margin-left:8px; opacity:.5; }
.crumb li:last-child::after{ content:""; }
.crumb a{ color:var(--ink-soft); }
.crumb a:hover{ color:var(--burgundy); }
.crumb li[aria-current]{ color:var(--burgundy); }

/* ---------- Article hero ---------- */
.ah{ max-width:var(--read); margin:0 auto; padding:34px var(--gutter) 0; }
.ah__eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:600; letter-spacing:.26em; text-transform:uppercase; color:var(--brass);
  margin:0 0 18px;
}
.ah__eyebrow::before{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }
.ah h1{
  font-family:var(--ff-display); font-weight:400;
  font-size:clamp(30px,5vw,46px); line-height:1.12; letter-spacing:-.01em;
  color:var(--ink); margin:0 0 18px;
}
.ah__meta{
  display:flex; flex-wrap:wrap; gap:8px 18px; align-items:center;
  font-size:13px; color:var(--ink-soft); padding-bottom:26px;
  border-bottom:1px solid var(--line);
}
.ah__meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--brass); }

/* ---------- Cover ---------- */
.cover{ max-width:var(--maxw); margin:30px auto; padding:0 var(--gutter); }
.cover figure{ margin:0; }
.cover img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow-1); }
.cover figcaption{ margin-top:10px; text-align:center; font-size:12px; letter-spacing:.06em; color:var(--ink-soft); }

/* ---------- Prose ---------- */
.prose{ max-width:var(--read); margin:0 auto; padding:8px var(--gutter) 0; }
.prose > p{ font-size:17px; line-height:1.8; color:var(--ink-soft); margin:0 0 22px; }
.prose h2{
  font-family:var(--ff-display); font-weight:400;
  font-size:clamp(24px,3.4vw,32px); line-height:1.2; color:var(--burgundy);
  margin:52px 0 16px; scroll-margin-top:90px;
  padding-top:18px; border-top:1px solid var(--line-2);
}
.prose h3{
  font-family:var(--ff-display); font-weight:500; font-size:21px;
  color:var(--ink); margin:32px 0 12px;
}
.prose strong{ color:var(--ink); font-weight:600; }
.prose a{ color:var(--burgundy); text-decoration:underline; text-decoration-color:rgba(94,30,34,.3); text-underline-offset:3px; transition:text-decoration-color .3s; }
.prose a:hover{ text-decoration-color:var(--burgundy); }
.prose ul{ margin:0 0 22px; padding-left:0; list-style:none; }
.prose ul li{ position:relative; padding-left:24px; margin-bottom:10px; font-size:16.5px; color:var(--ink-soft); line-height:1.7; }
.prose ul li::before{ content:""; position:absolute; left:2px; top:11px; width:7px; height:7px; border:1px solid var(--brass); transform:rotate(45deg); }
.prose ul li strong{ color:var(--ink); }

/* Ảnh chèn giữa bài */
.prose figure{ margin:30px 0; }
.prose figure img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow-1); }
.prose figure figcaption{ margin-top:10px; text-align:center; font-size:12.5px; color:var(--ink-soft); }

/* Tables */
.prose .tw{ overflow-x:auto; margin:0 0 26px; -webkit-overflow-scrolling:touch; }
.prose table{ width:100%; border-collapse:collapse; font-size:15px; min-width:480px; }
.prose th{
  text-align:left; font-family:var(--ff-sans); font-weight:600;
  font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--brass);
  padding:0 14px 12px; border-bottom:1px solid var(--line);
}
.prose td{ padding:14px; border-bottom:1px solid var(--line-2); color:var(--ink-soft); vertical-align:top; }
.prose td:first-child{ font-family:var(--ff-display); color:var(--burgundy); font-size:18px; }
.prose tbody tr:hover{ background:rgba(94,30,34,.03); }

/* Callout / blockquote */
.prose blockquote, .callout{
  margin:0 0 24px; padding:18px 22px;
  background:var(--paper-2); border-left:3px solid var(--brass);
  border-radius:0 var(--radius) var(--radius) 0;
  font-size:15.5px; color:var(--ink-soft); line-height:1.7;
}
.prose blockquote strong{ color:var(--burgundy); }
.note{ font-size:13.5px; color:var(--ink-soft); font-style:italic; opacity:.9; margin:0 0 22px; }

/* TOC */
.toc{
  max-width:var(--read); margin:30px auto; padding:22px 26px;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
}
.toc h2{ font-family:var(--ff-sans); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--brass); margin:0 0 14px; border:0; padding:0; }
.toc ol{ margin:0; padding-left:20px; columns:2; column-gap:32px; font-size:14.5px; }
.toc li{ margin-bottom:8px; break-inside:avoid; }
.toc a{ color:var(--ink-soft); }
.toc a:hover{ color:var(--burgundy); }
@media (max-width:600px){ .toc ol{ columns:1; } }

/* FAQ */
.faq{ max-width:var(--read); margin:0 auto; padding:0 var(--gutter); }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{
  list-style:none; cursor:pointer; padding:18px 36px 18px 0; position:relative;
  font-family:var(--ff-display); font-size:18px; color:var(--ink); font-weight:500;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+"; position:absolute; right:4px; top:16px; font-size:22px;
  color:var(--brass); transition:transform .3s; font-family:var(--ff-sans);
}
.faq details[open] summary::after{ content:"−"; }
.faq details p{ margin:0 0 18px; color:var(--ink-soft); font-size:16px; line-height:1.75; }

/* CTA box */
.cta{
  max-width:var(--read); margin:48px auto; padding:38px clamp(24px,4vw,48px);
  background:var(--burgundy); color:var(--paper); border-radius:var(--radius);
  text-align:center;
}
.cta h2{ font-family:var(--ff-display); font-weight:400; font-size:26px; margin:0 0 10px; color:var(--paper); border:0; padding:0; }
.cta p{ color:rgba(246,241,232,.82); font-size:15.5px; margin:0 0 22px; }
.cta__row{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.btn{
  display:inline-flex; align-items:center; gap:8px; padding:14px 28px;
  font-size:14px; font-weight:600; letter-spacing:.04em; border-radius:999px;
  transition:all .3s; border:1px solid transparent; cursor:pointer;
}
.btn--gold{ background:var(--brass-2); color:var(--ink) !important; }
.btn--gold:hover{ background:#e6c489; }
.btn--ghost{ border-color:rgba(246,241,232,.5); color:var(--paper) !important; }
.btn--ghost:hover{ background:rgba(246,241,232,.12); }

/* Related / back to news */
.related{ max-width:var(--read); margin:0 auto; padding:0 var(--gutter) 10px; }
.related h2{ font-family:var(--ff-sans); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--brass); margin:0 0 16px; }
.related a{ display:flex; align-items:center; gap:10px; padding:14px 0; border-bottom:1px solid var(--line-2); color:var(--ink); font-family:var(--ff-display); font-size:18px; }
.related a:hover{ color:var(--burgundy); }
.related a .arr{ color:var(--brass); margin-left:auto; }

/* ---------- News listing ---------- */
.nlhero{ max-width:var(--maxw); margin:0 auto; padding:48px var(--gutter) 10px; text-align:center; }
.nlhero .ah__eyebrow{ justify-content:center; }
.nlhero h1{ font-family:var(--ff-display); font-weight:400; font-size:clamp(32px,5vw,52px); line-height:1.1; color:var(--ink); margin:0 auto 16px; max-width:14ch; }
.nlhero p{ max-width:60ch; margin:0 auto; color:var(--ink-soft); font-size:17px; }
.nlgrid{ max-width:var(--maxw); margin:0 auto; padding:40px var(--gutter) 20px; display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:28px; }
.ncard{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; transition:transform .3s, box-shadow .3s; }
.ncard:hover{ transform:translateY(-4px); box-shadow:var(--shadow-1); }
.ncard__media{ aspect-ratio:16/10; overflow:hidden; background:var(--paper-2); }
.ncard__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s; }
.ncard:hover .ncard__media img{ transform:scale(1.05); }
.ncard__body{ padding:22px 24px 26px; display:flex; flex-direction:column; flex:1; }
.ncard__tag{ font-size:10.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--brass); margin-bottom:12px; }
.ncard__title{ font-family:var(--ff-display); font-size:21px; line-height:1.25; color:var(--ink); margin:0 0 10px; }
.ncard__excerpt{ font-size:14.5px; color:var(--ink-soft); line-height:1.6; margin:0 0 18px; flex:1; }
.ncard__foot{ display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:var(--ink-soft); }
.ncard__foot .more{ color:var(--burgundy); font-weight:600; }
.ncard--soon{ opacity:.85; }
.ncard--soon .ncard__media{ display:flex; align-items:center; justify-content:center; color:var(--brass); font-family:var(--ff-display); font-style:italic; font-size:20px; }
.ncard--soon .ncard__tag{ color:var(--ink-soft); }

/* Featured (first) */
.nfeat{ max-width:var(--maxw); margin:0 auto; padding:36px var(--gutter) 0; }
.nfeat a{ display:grid; grid-template-columns:1.15fr 1fr; background:#fff; border:1px solid var(--line-2); border-radius:var(--radius); overflow:hidden; }
.nfeat .m{ overflow:hidden; background:var(--paper-2); min-height:280px; }
.nfeat .m img{ width:100%; height:100%; object-fit:cover; transition:transform 1s; }
.nfeat a:hover .m img{ transform:scale(1.04); }
.nfeat .c{ padding:clamp(28px,4vw,52px); display:flex; flex-direction:column; justify-content:center; }
.nfeat .tag{ font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--brass); margin-bottom:14px; }
.nfeat h2{ font-family:var(--ff-display); font-weight:400; font-size:clamp(24px,3vw,34px); line-height:1.2; color:var(--ink); margin:0 0 14px; border:0; padding:0; }
.nfeat p{ color:var(--ink-soft); font-size:16px; margin:0 0 20px; }
.nfeat .more{ color:var(--burgundy); font-weight:600; font-size:14px; }
@media (max-width:760px){ .nfeat a{ grid-template-columns:1fr; } .nfeat .m{ aspect-ratio:16/10; min-height:0; } }

/* ---------- Footer ---------- */
.nf{ background:var(--ink); color:rgba(246,241,232,.72); margin-top:64px; padding:56px var(--gutter) 36px; }
.nf__in{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; }
.nf__brand .name{ font-family:var(--ff-display); font-size:24px; color:var(--paper); }
.nf__brand .le{ font-family:var(--ff-display); font-style:italic; font-size:11px; letter-spacing:.32em; color:var(--brass); display:block; }
.nf p{ font-size:13.5px; line-height:1.7; margin:8px 0; }
.nf h4{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--brass); margin:0 0 14px; font-weight:600; }
.nf a{ color:rgba(246,241,232,.78); }
.nf a:hover{ color:var(--brass-2); }
.nf__links{ display:flex; flex-direction:column; gap:9px; font-size:13.5px; }
.nf__bottom{ max-width:var(--maxw); margin:36px auto 0; padding-top:24px; border-top:1px solid rgba(246,241,232,.12); font-size:11.5px; line-height:1.7; color:rgba(246,241,232,.5); }
@media (max-width:760px){ .nf__in{ grid-template-columns:1fr; gap:28px; } }

/* Lưới 2 ảnh cạnh nhau (Sky Villa) — mobile tự xuống 1 cột */
.prose .grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:1.4rem 0;}
.prose .grid2 figure{margin:0;}
@media (max-width:640px){.prose .grid2{grid-template-columns:1fr;}}
