
/* ====================================================================
   BLOG HOME (scoped)
   Only applies inside .blog-masonry-posts
=====================================================================*/

/* wrap spacing only here */
.blog-masonry-posts {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: max(0.5ch, 2cqw);
}

/* grid */
.blog-masonry-posts .posts{
    --card-min: 175px;

    display: grid;
    grid-auto-flow: row dense;
    grid-template-columns: repeat(auto-fit, minmax(var(--card-min), 1fr));
    grid-auto-rows: 8px;
    gap: 1ch;
    list-style: none;
    padding: 0;
    margin: 0;
}

/* card */
.blog-masonry-posts .post{
    background: var(--bg-lighter);
    color: var(--ink);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-soft);
    transition: translate .18s ease, box-shadow .18s ease, background .18s ease;
}
.blog-masonry-posts .post__inner{
    padding: 0.5ch;
}
.blog-masonry-posts .post:hover{
    background: var(--bg-lighter-lighter);
    box-shadow: var(--shadow);
    translate: 0 -2px;
}
.blog-masonry-posts .post:has(a:focus-visible){
    outline: 2px solid var(--line);
    outline-offset: 2px;
}

.blog-masonry-posts .post--featured {
    grid-column: span 2;
}
.blog-masonry-posts .post--featured .post__title{
    font-size: clamp(1.15rem, 0.9rem + 1.4vw, 1.8rem);
}

/* media */
.blog-masonry-posts .post__media{
    overflow: hidden;
    border-radius: calc(var(--radius) - 4px);
    margin-bottom: clamp(0.5rem, 0.3rem + 0.6vw, 0.8rem);
}
.blog-masonry-posts .post__media img{
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    vertical-align: middle;
    border-radius: inherit;
}

/* body */
.blog-masonry-posts .post__body{
    padding-inline: 2px;
}

.blog-masonry-posts .post__kicker{
    font-weight: 800;
    font-size:  clamp(0.65rem, 0.52rem + 0.25vw, 0.75rem);
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--ink-muted);
    margin: 0 0 .35rem 0;
}

.blog-masonry-posts .post__title{
    font-size: clamp(1.00rem, 0.85rem + 0.95vw, 1.125rem);
    margin: 0 0 .45rem 0;
    hyphens: auto;
}

.blog-masonry-posts .post__excerpt{
    font-size: clamp(0.75rem, 0.75rem + 0.3vw, 0.9rem);
    line-height: 1.55;
    color: var(--ink-muted);
    margin: 0;
}

.blog-masonry-posts .post__meta{
    font-size: clamp(0.78rem, 0.68rem + 0.25vw, 0.9rem);
    color: var(--ink-muted);
    margin: .6rem 0 0 0;
}

/* link */
.blog-masonry-posts .post__link{
    display:block;
    color:inherit;
    text-decoration:none; }
.blog-masonry-posts .post__link:focus-visible{
    outline: 0;
    box-shadow: 0 0 0 3px var(--line);
    border-radius: calc(var(--radius) - 2px);
}

/* text-only cards */
.blog-masonry-posts .post:not(:has(.post__media img)) .post__inner{
    padding-block-start: calc(var(--pad-card) * 1.1);
}



/* ====================================================================
    POST PAGES
=====================================================================*/

/* Blog post shell */
.blog-post {
    margin-left: auto;
    margin-right: auto;
    margin-inline: auto;
    max-width: var(--read-maxw);
    padding: 2ch;
}

.blog-post-figure {
  margin: 0;
  overflow: clip;
  text-align:center;
}

.blog-post-figure img {
  border-radius: var(--radius);
  border: 1px solid #000000;
  box-shadow: 0 10px 30px rgb(0 0 0 / 0.35);
  display: inline-block;
  width: auto;
  height: auto;
  max-height: 95svh;
  max-width: 100%;
  object-fit: cover;
}

.blog-post-title {
    font-size: clamp(1.75rem, 4vw, 2.25rem);
}

/* Tags as pills */
.blog-post-tags {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  padding: 0;
  margin: 1rem 0 0;
}
.blog-post-tag a {
  display: inline-block;
  padding: .4rem .7rem;
  border: 1px solid rgb(255 255 255 / .22);
  color: var(--ink-muted);
  border-radius: 999px;
  text-decoration: none;
  font-size: .9rem;
  line-height: 1;
}
.blog-post-tag a:hover,
.blog-post-tag a:focus-visible {
  color: var(--ink);
  border-color: rgb(255 255 255 / .5);
}
