/* =============================================================
   Coastal Coffee — Blog (listing + post styles).
   Extends styles.css; reuses the same tokens.
   ============================================================= */

/* ---------- BLOG LISTING ----------------------------------- */
.blog-page { padding-block-start: var(--header-h); }

.blog-hero {
  padding-block: clamp(4rem, 3rem + 4vw, 7rem) clamp(2rem, 2vw, 3rem);
}
.blog-hero__title {
  font-family: var(--f-display);
  font-size: var(--t-3xl);
  font-weight: 360;
  letter-spacing: -0.035em;
  line-height: 0.92;
  margin-block: 1rem 1.25rem;
  text-wrap: balance;
}
.blog-hero__title em {
  font-style: italic;
  color: var(--c-ocean);
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.blog-hero__lede {
  max-inline-size: 50ch;
  color: var(--fg-soft);
  font-size: var(--t-md);
}

.blog-list { padding-block: clamp(1rem, 2vw, 2rem) clamp(5rem, 4vw, 8rem); }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.25rem, 1rem + 1vw, 2rem);
}
@media (max-width: 720px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* Plain-anchor cards. Entire card IS the link — no nesting, no JS. */
.blog-card {
  display: grid;
  grid-template-rows: auto 1fr;
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: color-mix(in oklab, var(--bg) 92%, var(--c-sand-200));
  border: 1px solid var(--rule-soft);
  transition: transform 480ms var(--ease-out), border-color 360ms;
  cursor: pointer;
  color: inherit;
  text-decoration: none;
}
.blog-card:hover { transform: translateY(-4px); border-color: var(--rule); }

.blog-card--featured { grid-column: 1 / -1; grid-template-columns: 1.2fr 1fr; grid-template-rows: auto; }
.blog-card--featured .blog-card__media {
  aspect-ratio: 5/4;
  block-size: 100%;
}
.blog-card--featured .blog-card__title { font-size: var(--t-xl); }
@media (max-width: 720px) {
  .blog-card--featured { grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
}
.blog-card__media {
  aspect-ratio: 16/10;
  margin: 0;
  overflow: hidden;
  background: var(--bg-warm);
}
.blog-card__media img {
  inline-size: 100%; block-size: 100%;
  object-fit: cover;
  transition: transform 800ms var(--ease-out), filter 400ms;
  filter: saturate(0.95);
}
.blog-card:hover .blog-card__media img {
  transform: scale(1.05);
  filter: saturate(1.05);
}

.blog-card__body {
  padding: clamp(1.25rem, 1rem + 1vw, 1.75rem);
  display: grid;
  align-content: start;
  gap: 0.75rem;
}
.blog-card__meta {
  display: flex;
  gap: 0.6rem 1.1rem;
  flex-wrap: wrap;
  font-family: var(--f-mono);
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-soft);
}
.blog-card__cat {
  color: var(--c-ocean);
  border-block-end: 1px solid currentColor;
}
.blog-card__title {
  font-family: var(--f-display);
  font-size: var(--t-lg);
  font-weight: 380;
  letter-spacing: -0.015em;
  line-height: 1.05;
  text-wrap: balance;
}
.blog-card__title em {
  font-style: italic;
  color: var(--c-ocean);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.blog-card__excerpt {
  color: var(--fg-soft);
  font-size: var(--t-sm);
  max-inline-size: 50ch;
}
.blog-card__cta {
  margin-block-start: 0.4rem;
  font-family: var(--f-mono);
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--fg);
  border-block-end: 1px solid currentColor;
  align-self: start;
  padding-block-end: 2px;
  transition: color 200ms;
}
.blog-card:hover .blog-card__cta { color: var(--c-ocean); }


/* ---------- BLOG POST -------------------------------------- */
.post {
  padding-block: var(--header-h) 0;
}
.post__hero {
  position: relative;
  inline-size: 100%;
  block-size: clamp(280px, 38vw, 460px);
  overflow: hidden;
  background: var(--bg-warm);
}
.post__hero img {
  inline-size: 100%; block-size: 100%;
  object-fit: cover;
  filter: saturate(0.95);
}
.post__hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    transparent 30%,
    color-mix(in oklab, var(--bg) 70%, transparent) 100%);
  pointer-events: none;
}

.post__head {
  margin-block-start: -8rem;
  position: relative;
  z-index: 1;
  background: var(--bg);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: clamp(2rem, 1.5rem + 2vw, 3.5rem) var(--gutter);
}
.post__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  font-family: var(--f-mono);
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--fg-soft);
  margin-block-end: 1.25rem;
}
.post__meta .post__cat {
  color: var(--c-ocean);
  border-block-end: 1px solid currentColor;
}
.post__title {
  font-family: var(--f-display);
  font-size: var(--t-3xl);
  font-weight: 360;
  letter-spacing: -0.035em;
  line-height: 0.92;
  text-wrap: balance;
  max-inline-size: 22ch;
}
.post__title em {
  font-style: italic;
  color: var(--c-ocean);
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.post__excerpt {
  margin-block-start: 1.25rem;
  font-family: var(--f-display);
  font-size: var(--t-md);
  font-style: italic;
  color: var(--fg-soft);
  max-inline-size: 60ch;
}

.post__body {
  padding: 0 var(--gutter) clamp(4rem, 3vw, 6rem);
  max-inline-size: 70ch;
  margin-inline: auto;
  font-size: var(--t-md);
  color: var(--fg);
  line-height: 1.7;
}
.post__body > * + * { margin-block-start: 1.25rem; }
.post__body h2 {
  font-size: var(--t-xl);
  margin-block-start: 3rem;
  letter-spacing: -0.02em;
  line-height: 1;
}
.post__body h2 em {
  font-style: italic;
  color: var(--c-ocean);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.post__body h3 {
  font-size: var(--t-lg);
  margin-block-start: 2.25rem;
  font-weight: 420;
  letter-spacing: -0.015em;
}
.post__body p { max-inline-size: none; }
.post__body ul, .post__body ol { padding-inline-start: 1.4rem; }
.post__body li { margin-block-start: 0.4rem; }
.post__body li::marker { color: var(--c-ocean); }

.post__body blockquote {
  margin: 2rem 0;
  padding: 0.5rem 0 0.5rem 1.5rem;
  border-inline-start: 3px solid var(--c-sun);
  font-family: var(--f-display);
  font-style: italic;
  font-size: var(--t-lg);
  color: var(--fg);
  line-height: 1.3;
}

.post__body figure {
  margin: 2.5rem 0;
}
.post__body figure img {
  inline-size: 100%;
  border-radius: var(--radius);
}
.post__body figcaption {
  margin-block-start: 0.6rem;
  font-family: var(--f-mono);
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-soft);
  text-align: center;
}

/* Numbered list of influencers */
.post__roster {
  margin: 2rem 0;
  display: grid;
  gap: 0.75rem;
  counter-reset: roster;
  padding: 0;
  list-style: none;
}
.post__roster li {
  counter-increment: roster;
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: color-mix(in oklab, var(--bg-warm) 60%, transparent);
  border: 1px solid var(--rule-soft);
  border-radius: var(--radius);
  font-size: var(--t-base);
  line-height: 1.5;
}
.post__roster li::before {
  content: counter(roster, decimal-leading-zero);
  font-family: var(--f-display);
  font-size: var(--t-lg);
  font-weight: 380;
  color: var(--c-ocean);
  letter-spacing: -0.02em;
  line-height: 1;
}
.post__roster strong {
  font-family: var(--f-display);
  font-weight: 420;
  font-size: var(--t-base);
  display: block;
  margin-block-end: 0.15rem;
}
.post__roster span {
  color: var(--fg-soft);
}

/* Post CTA at end */
.post__cta {
  margin-block-start: 3rem;
  padding: clamp(1.5rem, 1rem + 1vw, 2rem);
  border-radius: var(--radius-lg);
  background: var(--bg-deep);
  color: var(--c-foam);
  display: grid;
  gap: 1rem;
  text-align: center;
}
.post__cta h3 {
  font-family: var(--f-display);
  font-style: italic;
  font-size: var(--t-xl);
  font-weight: 360;
  color: var(--c-foam);
}
.post__cta p { color: color-mix(in oklab, var(--c-foam) 75%, transparent); margin-inline: auto; }
.post__cta .btn { --bg-btn: var(--c-foam); --fg-btn: var(--c-ink); justify-self: center; }
.post__cta .btn::before { background: var(--c-sun); }


/* ---------- HOMEPAGE BLOG GRID ----------------------------- */
.home-blog {
  padding-block: clamp(4rem, 3rem + 4vw, 7rem);
}
.home-blog__head {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 5rem);
  align-items: end;
  margin-block-end: clamp(2.5rem, 4vw, 4.5rem);
}
@media (max-width: 880px) {
  .home-blog__head { grid-template-columns: 1fr; }
}
.home-blog__head h2 em {
  font-style: italic;
  color: var(--c-ocean);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.home-blog__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 0.5rem + 1vw, 1.5rem);
}
@media (max-width: 880px) {
  .home-blog__grid { grid-template-columns: 1fr; }
}
.home-blog__foot {
  margin-block-start: 2rem;
  display: flex;
  justify-content: flex-end;
}
