/* =========================================================
   Gleam & Sip — blog / article styles
   Built on colors_and_type.css tokens. Spectral + Hanken.
   ========================================================= */

/* ---- Nav ---- */
.blog-nav {
  position: sticky; top: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 40px;
  background: rgba(246,241,230,0.88);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
}
.blog-nav-brand { display: flex; align-items: center; gap: 13px; text-decoration: none; }
.blog-nav-brand img { width: 40px; height: 40px; object-fit: contain; }
.blog-nav-wm { font-family: var(--font-display); font-weight: 400; font-size: 20px; letter-spacing: 0.03em; color: var(--ink-0); }
.blog-nav-wm em { font-family: var(--font-italic); font-style: italic; color: var(--matcha-1); }
.blog-nav-cta { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--matcha-0); text-decoration: none; }
.blog-nav-cta:hover { color: var(--ink-0); }

/* ---- Hero ---- */
.blog-hero { position: relative; height: 54vh; min-height: 340px; max-height: 520px; overflow: hidden; }
.blog-hero img { width: 100%; height: 100%; object-fit: cover; }
.blog-hero-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end;
  padding: 56px 0; background: linear-gradient(180deg, rgba(20,18,14,0.1) 0%, rgba(20,18,14,0.18) 45%, rgba(20,18,14,0.72) 100%); }
.blog-hero-inner { max-width: 760px; margin: 0 auto; padding-inline: 24px; width: 100%; }
.blog-hero-eyebrow { font-family: var(--font-accent); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--matcha-3); margin: 0 0 14px; }
.blog-hero h1 { font-family: var(--font-display); font-weight: 300; font-size: clamp(30px, 5vw, 52px); line-height: 1.08; letter-spacing: -0.015em; color: var(--paper-0); margin: 0; max-width: 18ch; text-shadow: 0 1px 28px rgba(20,18,14,0.4); }

/* ---- Article ---- */
.post { max-width: 720px; margin: 0 auto; padding: 64px 24px 96px; }
.post-lead { font-family: var(--font-italic); font-style: italic; font-size: clamp(19px, 2.4vw, 23px); line-height: 1.6; color: var(--ink-1); margin: 0 0 28px; }
.post p { font-family: var(--font-body); font-weight: 300; font-size: 17px; line-height: 1.78; color: var(--ink-2); margin: 0 0 20px; }
.post h2 { font-family: var(--font-display); font-weight: 300; font-size: clamp(26px, 3.4vw, 36px); line-height: 1.14; letter-spacing: -0.01em; color: var(--ink-0); margin: 52px 0 18px; }
.post h3 { font-family: var(--font-display); font-weight: 400; font-size: 22px; color: var(--matcha-0); margin: 34px 0 12px; }
.post ul, .post ol { margin: 0 0 22px; padding-left: 0; list-style: none; }
.post li { font-family: var(--font-body); font-weight: 300; font-size: 17px; line-height: 1.7; color: var(--ink-2); padding: 9px 0 9px 28px; position: relative; border-bottom: 1px solid var(--rule); }
.post li::before { content: "—"; position: absolute; left: 0; color: var(--matcha-1); }
.post strong { font-weight: 500; color: var(--ink-1); }
.post em { font-style: italic; }
.post a { color: var(--matcha-0); text-decoration: underline; text-decoration-color: rgba(107,128,64,0.4); text-underline-offset: 3px; }
.post a:hover { text-decoration-color: var(--matcha-1); }
.post figure { margin: 36px 0; }
.post img, .post video { width: 100%; border-radius: var(--radius-2); display: block; }
.post figcaption { font-family: var(--font-italic); font-style: italic; font-size: 14px; color: var(--ink-3); margin-top: 10px; text-align: center; }

/* ---- Pull quote ---- */
.post-quote { border-left: 2px solid var(--matcha-1); padding: 6px 0 6px 28px; margin: 34px 0; }
.post-quote p { font-family: var(--font-display); font-weight: 300; font-style: normal; font-size: 24px; line-height: 1.4; color: var(--ink-0); margin: 0; }

/* ---- Comparison table ---- */
.cmp-table { width: 100%; border-collapse: collapse; margin: 30px 0; font-family: var(--font-body); }
.cmp-table th { background: var(--ink-0); color: var(--paper-0); padding: 13px 14px; text-align: left; font-weight: 500; font-size: 13px; letter-spacing: 0.04em; }
.cmp-table td { padding: 13px 14px; border-bottom: 1px solid var(--rule); vertical-align: top; font-weight: 300; font-size: 14.5px; color: var(--ink-2); }
.cmp-table tr:nth-child(even) td { background: var(--paper-1); }
.cmp-table strong { color: var(--ink-0); }

/* ---- CTA ---- */
.post-cta { background: var(--ink-0); border-radius: var(--radius-2); padding: 48px 40px; text-align: center; margin: 52px 0; }
.post-cta h3 { font-family: var(--font-display); font-weight: 300; font-size: 28px; color: var(--paper-0); margin: 0 0 12px; }
.post-cta p { color: var(--paper-2); margin: 0 auto 26px; max-width: 46ch; }
.post-cta-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.post-cta .small { font-size: 13px; color: var(--paper-3); margin-top: 18px; }

/* ---- Index / listing ---- */
.blog-index-head { max-width: 760px; margin: 0 auto; padding: 80px 24px 40px; }
.blog-index-eyebrow { font-family: var(--font-accent); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--matcha-0); margin: 0 0 16px; }
.blog-index-head h1 { font-family: var(--font-display); font-weight: 300; font-size: clamp(34px, 5vw, 54px); line-height: 1.06; letter-spacing: -0.015em; color: var(--ink-0); margin: 0 0 18px; }
.blog-index-head p { font-family: var(--font-italic); font-style: italic; font-size: clamp(18px, 2.3vw, 21px); line-height: 1.6; color: var(--ink-2); margin: 0; max-width: 46ch; }
.blog-index-head .rule { height: 1px; background: var(--rule); margin-top: 40px; }

.blog-list { max-width: 760px; margin: 0 auto; padding: 8px 24px 96px; display: grid; gap: 0; }
.blog-card { display: grid; grid-template-columns: 220px 1fr; gap: 32px; align-items: center; padding: 40px 0; border-bottom: 1px solid var(--rule); text-decoration: none; transition: opacity var(--dur) var(--ease); }
.blog-card:hover { opacity: 0.78; }
.blog-card-media { aspect-ratio: 4 / 3; overflow: hidden; border-radius: var(--radius-2); }
.blog-card-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 700ms var(--ease); }
.blog-card:hover .blog-card-media img { transform: scale(1.03); }
.blog-card-meta { font-family: var(--font-accent); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--matcha-0); margin: 0 0 12px; }
.blog-card h2 { font-family: var(--font-display); font-weight: 300; font-size: clamp(23px, 3vw, 30px); line-height: 1.14; letter-spacing: -0.01em; color: var(--ink-0); margin: 0 0 12px; }
.blog-card p { font-family: var(--font-body); font-weight: 300; font-size: 16px; line-height: 1.65; color: var(--ink-2); margin: 0 0 14px; }
.blog-card-more { font-family: var(--font-accent); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--matcha-1); }

@media (max-width: 560px) {
  .blog-card { grid-template-columns: 1fr; gap: 18px; }
  .blog-card-media { aspect-ratio: 16 / 9; }
}

/* ---- Footer ---- */
.blog-foot { background: var(--paper-2); border-top: 1px solid var(--rule); text-align: center; padding: 40px 24px; font-family: var(--font-body); font-size: 13px; color: var(--ink-3); }
.blog-foot a { color: var(--matcha-0); text-decoration: none; }
.blog-foot a:hover { color: var(--ink-0); }

@media (max-width: 600px) {
  .blog-nav { padding-inline: 20px; }
  .post { padding-top: 44px; }
  .cmp-table { font-size: 12px; }
  .cmp-table th, .cmp-table td { padding: 8px; }
  .post-cta { padding: 32px 22px; }
}
