/* The French Property Playbook — blog/article stylesheet (design-system tokens) */
:root{
  --navy:#1F3864; --navy-700:#172a4d; --gold:#C8A24B; --gold-soft:#f3e9cf;
  --ink:#1d2433; --muted:#5d6b82; --line:#e3e8f0; --bg:#ffffff; --soft:#f6f8fb;
  --maxw:1080px; --readw:720px; --radius:12px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.container.narrow{max-width:var(--readw)}
a{color:var(--navy);text-decoration:underline;text-underline-offset:2px;text-decoration-color:#c7d0df}
a:hover{color:var(--gold)}

/* Header / nav */
.site-header{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:20}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{font-weight:800;font-size:18px;color:var(--navy);text-decoration:none;letter-spacing:-.01em}
.brand span{color:var(--gold)}
.nav-links a{margin-left:18px;font-size:14px;font-weight:600;color:var(--ink);text-decoration:none}
.nav-links a:hover{color:var(--gold)}
@media(max-width:640px){.nav-links a{margin-left:12px;font-size:13px}.brand{font-size:16px}}

/* Article */
.article{padding:34px 0 10px}
article h1{font-size:34px;line-height:1.18;color:var(--navy);margin:.1em 0 .15em;letter-spacing:-.015em}
.byline{color:var(--muted);font-size:14px;margin:0 0 1.6em;padding-bottom:1.1em;border-bottom:1px solid var(--line)}
article h2{font-size:23px;color:var(--navy);margin:1.7em 0 .5em;line-height:1.3}
article h3{font-size:18.5px;color:var(--navy-700);margin:1.4em 0 .4em}
article p{margin:0 0 1.1em;font-size:17px}
article ul,article ol{margin:0 0 1.2em;padding-left:1.4em}
article li{margin:.4em 0;font-size:17px}
article strong{color:var(--navy-700)}
article code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.88em;
  background:var(--soft);border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:#42546f}
article hr{border:0;border-top:1px solid var(--line);margin:2.2em 0}
blockquote{margin:1.5em 0;padding:14px 18px;background:var(--gold-soft);border-left:4px solid var(--gold);
  border-radius:0 10px 10px 0;font-size:16px}
blockquote p{margin:.4em 0}

/* Tables */
.table-wrap{overflow-x:auto;margin:1.4em 0;border:1px solid var(--line);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:14.5px;min-width:520px}
th,td{text-align:left;padding:10px 13px;border-bottom:1px solid var(--line);vertical-align:top}
thead th{background:var(--navy);color:#fff;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;border-bottom:none}
tbody tr:nth-child(even){background:var(--soft)}
td strong{color:var(--navy)}

/* Footer */
.site-footer{margin-top:46px;border-top:1px solid var(--line);background:var(--soft);padding:26px 0}
.site-footer p{margin:.3em 0;font-size:14px;color:var(--ink)}
.site-footer .fine{font-size:12.5px;color:var(--muted)}
.site-footer a{color:var(--navy)}

/* Blog index */
.blog-hero{background:linear-gradient(160deg,var(--navy),var(--navy-700));color:#fff;padding:46px 0 40px}
.blog-hero .kicker{display:inline-block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:10px}
.blog-hero h1{font-size:34px;margin:0 0 .3em;line-height:1.15}
.blog-hero .lead{color:#cdd8ec;font-size:17px;margin:0 0 1.3em}
.btn-cta{display:inline-block;background:var(--gold);color:#1a1a1a;font-weight:700;text-decoration:none;
  padding:12px 20px;border-radius:9px;font-size:15px}
.btn-cta:hover{filter:brightness(1.05);color:#1a1a1a}
.blog-index{padding:34px 0 10px}
h2.cluster{font-size:15px;text-transform:uppercase;letter-spacing:.05em;color:var(--gold);margin:30px 0 14px}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.post-card{display:block;border:1px solid var(--line);border-radius:var(--radius);padding:20px;text-decoration:none;
  color:var(--ink);background:#fff;transition:.15s;box-shadow:0 1px 3px rgba(20,40,80,.05)}
.post-card:hover{border-color:var(--gold);box-shadow:0 6px 20px rgba(20,40,80,.09);transform:translateY(-2px)}
.post-card h3{color:var(--navy);margin:0 0 .5em;font-size:18px;line-height:1.3}
.post-card p{color:var(--muted);font-size:14px;margin:0 0 1em}
.post-card .read{color:var(--gold);font-weight:700;font-size:14px}
