/* article.css — shared stylesheet for standalone article pages
   Contains: design tokens, nav, body typography, article shell, footer.
   Each article page links this once and adds nothing inline.
   ------------------------------------------------------------------ */

:root{
  --kl-green:#9DB58E;--kl-green-soft:#B5C8A7;--kl-green-tint:#D9E3CF;--kl-green-pale:#EEF2E6;
  --kl-green-mid:#7A9269;--kl-green-dark:#4D6240;--kl-green-deep:#2E3D2A;
  --bg:#FCFCF9;--bg-alt:#FFFFFF;--bg-warm:#F6F5EE;
  --ink:#15181A;--ink-2:#3A4042;--mute:#6A7074;--faint:#9099A0;
  --rule:#E6E4DA;--rule-soft:#EFEDE3;
  --on-dark:#F5F2EA;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Century Gothic','Jost',ui-sans-serif,system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

.h-1{font-family:'Century Gothic','Jost',ui-sans-serif,system-ui,sans-serif;font-weight:600;font-size:clamp(40px,5.5vw,60px);letter-spacing:-0.02em;line-height:1.05}
.h-2{font-family:'Century Gothic','Jost',ui-sans-serif,system-ui,sans-serif;font-weight:600;font-size:clamp(24px,2.8vw,32px);letter-spacing:-0.015em;line-height:1.1}
.eyebrow{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--kl-green-dark);font-weight:500;display:inline-flex;align-items:center;gap:8px}
.crumb{font-size:13px;color:var(--mute)}
.crumb a{color:var(--mute)} .crumb a:hover{color:var(--ink)}
.crumb .sep{margin:0 8px;color:var(--faint)}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
@media (max-width:720px){.wrap{padding:0 22px}}

/* Nav (kept minimal — full site nav lives in index.html) */
nav.top{background:var(--bg-alt);border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:50}
.nav-inner{max-width:1280px;margin:0 auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand-link{display:flex;align-items:center;cursor:pointer;text-decoration:none}
.logo-mark{display:inline-flex;align-items:center;color:var(--kl-green);height:30px;line-height:0}
.logo-mark svg{height:100%;width:auto;display:block}
.logo-wordmark{font-weight:400;font-size:13px;color:var(--kl-green-dark);letter-spacing:0.16em;margin-left:14px;border-left:1px solid var(--rule);padding-left:14px;text-transform:uppercase}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-back{font-size:13px;color:var(--kl-green-dark);font-weight:500;letter-spacing:.04em}
.nav-back:hover{text-decoration:underline}
.nav-cta{background:var(--kl-green-deep);color:var(--bg);padding:10px 16px;font-size:13px;font-weight:500;letter-spacing:.005em}
.nav-cta:hover{background:var(--kl-green-dark)}
@media (max-width:680px){.nav-back{display:none}}

/* Article hero */
.article-hero{padding:64px 0 56px;background:var(--bg-warm);border-bottom:1px solid var(--rule)}
.article-hero .wrap{max-width:840px}
.article-back{display:inline-block;font-size:11px;color:var(--kl-green-dark);text-decoration:none;margin-bottom:28px;cursor:pointer;letter-spacing:.12em;text-transform:uppercase;font-weight:500}
.article-back:hover{text-decoration:underline}
.article-tag{display:inline-block;background:var(--kl-green-deep);color:#fff;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;padding:7px 14px;font-weight:600;margin-bottom:24px}
.article-hero h1{font-weight:600;font-size:clamp(34px,5vw,54px);letter-spacing:-0.025em;line-height:1.05;color:var(--ink);margin-bottom:24px}
.article-dek{font-size:clamp(19px,2vw,23px);line-height:1.45;color:var(--ink-2);font-weight:400;letter-spacing:-0.008em;margin-bottom:36px;max-width:720px}
.article-byline{display:flex;align-items:center;gap:14px;padding-top:24px;border-top:1px solid var(--rule);font-size:13px;color:var(--mute);flex-wrap:wrap}
.article-byline .author{color:var(--ink);font-weight:600;letter-spacing:.005em}
.article-byline .sep{color:var(--rule)}

.article-hero-image{width:100%;background:#ddd;border-bottom:1px solid var(--rule);overflow:hidden;line-height:0}
.article-hero-image img{width:100%;height:auto;display:block;max-height:520px;object-fit:cover}
@media (max-width:680px){.article-hero-image img{max-height:280px}}

.article-body{padding:64px 0 72px;background:var(--bg)}
.article-body .wrap{max-width:760px;margin:0 auto}
.article-prose p{font-size:18px;line-height:1.78;color:var(--ink-2);margin-bottom:24px}
.article-prose p strong{color:var(--ink);font-weight:600}
.article-prose p em{font-style:italic}
.article-prose > p:first-of-type::first-letter{font-weight:600;font-size:5.4em;line-height:.9;float:left;margin:6px 14px -2px 0;color:var(--kl-green-dark);letter-spacing:-.02em}
.article-prose h3{font-weight:600;font-size:26px;letter-spacing:-0.018em;line-height:1.2;margin:64px 0 18px;color:var(--ink);position:relative;padding-top:32px}
.article-prose h3::before{content:'';position:absolute;top:0;left:0;width:48px;height:2px;background:var(--kl-green-mid)}
.article-prose ul{list-style:none;margin:18px 0 28px;padding:0;display:flex;flex-direction:column;gap:12px}
.article-prose ul li{padding-left:22px;position:relative;font-size:17px;line-height:1.6;color:var(--ink-2)}
.article-prose ul li::before{content:'';position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--kl-green);display:inline-block}
.article-prose ul li strong{color:var(--ink);font-weight:600}
.article-prose blockquote{margin:48px 0;padding:36px 40px 36px 56px;background:var(--kl-green-pale);border-left:4px solid var(--kl-green-dark);font-size:23px;line-height:1.4;color:var(--ink);font-weight:500;letter-spacing:-0.012em;position:relative}
.article-prose blockquote::before{content:'\201C';position:absolute;top:-8px;left:20px;font-size:90px;color:var(--kl-green-mid);font-family:Georgia,serif;line-height:1;font-weight:700;opacity:.6}
.article-prose .note{font-size:13px;color:var(--mute);font-style:italic;border-left:2px solid var(--kl-green);padding:14px 18px;margin:56px 0 0;background:var(--bg-warm)}

/* Continue reading rail */
.article-cont{padding:64px 0 80px;background:var(--bg-warm);border-top:1px solid var(--rule)}
.article-cont .wrap{max-width:1100px}
.article-cont .head{margin-bottom:32px;display:flex;justify-content:space-between;align-items:baseline;gap:18px;flex-wrap:wrap}
.article-cont .head .eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--kl-green-dark);font-weight:500}
.article-cont .head h3{font-weight:600;font-size:24px;letter-spacing:-0.015em;color:var(--ink);margin-top:6px}
.article-cont .head .all-link{font-size:13px;color:var(--kl-green-dark);text-decoration:underline;font-weight:500;cursor:pointer}
.article-cont .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.article-cont .card{background:var(--bg-alt);border:1px solid var(--rule);cursor:pointer;transition:border-color .15s,background .15s;overflow:hidden;display:flex;flex-direction:column;text-decoration:none}
.article-cont .card:hover{border-color:var(--kl-green-mid);background:var(--bg)}
.article-cont .card .card-art{aspect-ratio:1.6/1;background:linear-gradient(135deg,var(--kl-green-tint) 0%,var(--kl-green-pale) 100%);background-size:cover;background-position:center}
.article-cont .card .card-body{padding:20px}
.article-cont .card .meta{font-size:11px;color:var(--mute);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.article-cont .card h4{font-weight:600;font-size:18px;letter-spacing:-0.015em;line-height:1.25;color:var(--ink);margin-bottom:8px}
.article-cont .card p{font-size:13px;color:var(--ink-2);line-height:1.55;margin:0}
@media (max-width:820px){.article-cont .grid{grid-template-columns:1fr}}
@media (max-width:680px){.article-prose blockquote{padding:28px 22px 28px 36px;font-size:20px;margin:36px -8px}.article-prose > p:first-of-type::first-letter{font-size:4.4em}}

/* Footer (simplified — main site footer linked back via Home) */
footer{background:var(--ink);color:rgba(245,242,234,0.55);padding:48px 0 28px;font-size:13px;margin-top:0}
footer .wrap{max-width:1180px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;align-items:center}
footer .foot-brand{display:flex;align-items:center;gap:14px;color:var(--kl-green-soft)}
footer .foot-brand svg{height:24px;width:auto}
footer .foot-name{font-weight:400;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--on-dark);border-left:1px solid rgba(245,242,234,0.2);padding-left:14px}
footer .foot-links{display:flex;gap:24px;flex-wrap:wrap;font-size:13px}
footer .foot-links a{color:rgba(245,242,234,0.65)}
footer .foot-links a:hover{color:var(--on-dark)}
footer .foot-tiny{width:100%;border-top:1px solid rgba(245,242,234,0.1);padding-top:18px;margin-top:14px;color:rgba(245,242,234,0.4);font-size:11px}
