/* =========================================================================
   REDESIGN - Blog (the Loud Letter)
   Readable-first long-form + maximalist accents. Reuses core.css tokens.
   ========================================================================= */

.blogbody {
  background: var(--bone);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 18px;
  line-height: 1.6;
}
.blog-wrap { max-width: 1200px; margin: 0 auto; padding-inline: clamp(18px, 4vw, 56px); }
.measure { max-width: 720px; }

::selection { background: var(--c2); color: var(--bone); }

a.inline-link { color: inherit; text-decoration: underline; text-decoration-color: var(--c2); text-decoration-thickness: 2px; text-underline-offset: 3px; transition: color .15s; }
a.inline-link:hover { color: var(--c2); }

/* ---- top nav (shared, light) ---- */
.bnav {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 12px clamp(18px, 4vw, 56px);
  background: color-mix(in srgb, var(--bone) 86%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 2px solid var(--ink);
}
.bnav__logo { font-family: var(--f-head); font-size: 24px; text-transform: uppercase; letter-spacing: -0.02em; line-height: 1; }
.bnav__logo b { color: var(--c2); }
.bnav__links { display: flex; align-items: center; gap: 18px; }
.bnav__links a { font-family: var(--f-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }
.bnav__links a.on { color: var(--c2); }
.bnav__links a.cta { border: 2px solid var(--ink); padding: 7px 13px; border-radius: 999px; transition: background-color .15s, color .15s; }
.bnav__links a.cta:hover { background: var(--ink); color: var(--bone); }
@media (max-width: 680px) { .bnav__links a.hide-sm { display: none; } }

/* ---- masthead ---- */
.masthead { position: relative; padding: clamp(40px, 7vw, 96px) 0 clamp(26px, 4vw, 48px); overflow: clip; }
.masthead__kicker { font-family: var(--f-mono); font-size: 13px; letter-spacing: .24em; text-transform: uppercase; color: var(--c2); margin-bottom: 14px; }
.masthead__title { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(54px, 12vw, 168px); line-height: .9; letter-spacing: -0.02em; margin: 0; }
.masthead__title .it { font-family: var(--f-serif); font-style: italic; text-transform: none; letter-spacing: 0; }
.masthead__sub { font-family: var(--f-serif); font-style: italic; font-size: clamp(18px, 2.2vw, 28px); max-width: 30ch; margin-top: 18px; color: color-mix(in srgb, var(--ink) 80%, transparent); }
.masthead__sticker { position: absolute; right: 4%; top: 22%; font-family: var(--f-disp); font-weight: 800; text-transform: uppercase; background: var(--c1); color: var(--ink); border: 3px solid var(--ink); border-radius: 50%; width: 116px; height: 116px; display: grid; place-items: center; text-align: center; font-size: 14px; line-height: 1; box-shadow: 4px 4px 0 var(--ink); transform: rotate(9deg); }
@media (max-width: 720px) { .masthead__sticker { display: none; } }

/* ---- category filter ---- */
.cat-bar { display: flex; flex-wrap: wrap; gap: 9px; margin: 8px 0 clamp(28px, 4vw, 48px); }
.cat-bar button {
  font-family: var(--f-disp); font-weight: 800; text-transform: uppercase; font-size: 13px;
  color: var(--ink); background: transparent; border: 2.5px solid var(--ink); padding: 8px 15px;
  border-radius: 999px; cursor: pointer; transition: background-color .16s, color .16s, transform .15s cubic-bezier(.34,1.8,.5,1);
}
.cat-bar button:hover { transform: translateY(-2px) rotate(-1.5deg); }
.cat-bar button.on { background: var(--c2); color: var(--bone); border-color: var(--c2); box-shadow: 3px 3px 0 var(--ink); }

/* =========================================================================
   FEATURED POST
   ========================================================================= */
.featured {
  position: relative; cursor: pointer;
  display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(22px, 3vw, 48px);
  align-items: stretch; margin-bottom: clamp(36px, 5vw, 72px);
  border: 3px solid var(--ink); border-radius: 8px; overflow: hidden;
  background: var(--ink); color: var(--bone);
  box-shadow: 10px 10px 0 var(--ink);
}
.featured__title a::after { content: ""; position: absolute; inset: 0; z-index: 1; }
.featured__cta, .featured .post-meta { position: relative; z-index: 2; }
.featured__media { position: relative; min-height: 320px; }
.featured__media .ph { position: absolute; inset: 0; }
.featured__flag { position: absolute; top: 16px; left: 16px; z-index: 2; font-family: var(--f-disp); font-weight: 800; text-transform: uppercase; font-size: 12px; background: var(--c1); color: var(--ink); border: 2px solid var(--ink); padding: 6px 12px; border-radius: 999px; }
.featured__body { padding: clamp(24px, 3vw, 46px); display: flex; flex-direction: column; justify-content: center; gap: 16px; }
.featured__tag { font-family: var(--f-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--c1); }
.featured__title { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(34px, 4.6vw, 72px); line-height: .9; letter-spacing: -0.01em; margin: 0; }
.featured__title a { transition: color .18s; }
.featured__title a:hover { color: var(--c1); }
.featured__excerpt { font-size: clamp(16px, 1.3vw, 19px); color: color-mix(in srgb, var(--bone) 82%, transparent); max-width: 50ch; }
.post-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-family: var(--f-mono); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: color-mix(in srgb, var(--bone) 70%, transparent); }
.post-meta .av { width: 26px; height: 26px; border-radius: 50%; border: 2px solid currentColor; flex: none; }
.post-meta .dot { opacity: .5; }
.featured__cta { align-self: flex-start; margin-top: 4px; }
@media (max-width: 820px) { .featured { grid-template-columns: 1fr; } .featured__media { min-height: 240px; } }

/* =========================================================================
   POST GRID
   ========================================================================= */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.4vw, 36px); }
@media (max-width: 940px) { .post-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .post-grid { grid-template-columns: 1fr; } }

.post-card {
  position: relative; cursor: pointer;
  display: flex; flex-direction: column; background: var(--bone);
  border: 3px solid var(--ink); border-radius: 6px; overflow: hidden;
  box-shadow: 6px 6px 0 var(--ink);
  transition: transform .2s cubic-bezier(.34,1.5,.5,1), box-shadow .2s;
}
.post-card__title a::after { content: ""; position: absolute; inset: 0; z-index: 3; }
.post-card:hover { transform: translateY(-6px); box-shadow: 12px 14px 0 var(--ink); }
.post-card__media { position: relative; aspect-ratio: 16/10; }
.post-card__media .ph { position: absolute; inset: 0; }
.post-card__tag { position: absolute; top: 12px; left: 12px; z-index: 2; font-family: var(--f-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; background: var(--ink); color: var(--bone); padding: 4px 9px; border-radius: 999px; }
.post-card__body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.post-card__title { font-family: var(--f-disp); font-weight: 800; text-transform: none; font-size: clamp(20px, 1.8vw, 25px); line-height: 1.04; margin: 0; }
.post-card__title a { transition: color .16s; }
.post-card__title a:hover { color: var(--c2); }
.post-card__excerpt { font-size: 15px; line-height: 1.45; color: color-mix(in srgb, var(--ink) 78%, transparent); flex: 1; }
.post-card .post-meta { color: color-mix(in srgb, var(--ink) 62%, transparent); margin-top: 4px; }
.post-card .post-meta .av { border-color: var(--ink); }

.loadmore-wrap { display: flex; justify-content: center; margin: clamp(40px, 6vw, 76px) 0 0; }
.post-card.is-hidden { display: none; }

/* reveal (light) */
.b-reveal { opacity: 0; transform: translateY(26px); }
@media (prefers-reduced-motion: no-preference) {
  .b-reveal { transition: opacity .6s ease, transform .6s cubic-bezier(.16,1,.3,1); }
}
.b-reveal.in { opacity: 1; transform: none; }
html.b-nomotion .b-reveal { opacity: 1; transform: none; }

/* =========================================================================
   ARTICLE
   ========================================================================= */
.article-head { position: relative; padding: clamp(30px, 5vw, 72px) 0 clamp(20px, 3vw, 36px); overflow: clip; }
.crumbs { font-family: var(--f-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 18px; }
.crumbs a { color: var(--c2); }
.article-tag { display: inline-block; font-family: var(--f-disp); font-weight: 800; text-transform: uppercase; font-size: 13px; background: var(--c1); color: var(--ink); border: 2.5px solid var(--ink); padding: 6px 14px; border-radius: 999px; box-shadow: 3px 3px 0 var(--ink); transform: rotate(-2deg); }
.article-title { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(38px, 6.4vw, 96px); line-height: 1.04; letter-spacing: -0.02em; margin: 18px 0 0; max-width: 18ch; }
.article-deck { font-family: var(--f-serif); font-style: italic; font-size: clamp(20px, 2.4vw, 32px); line-height: 1.25; margin: clamp(32px, 4vw, 52px) 0 0; max-width: 40ch; color: color-mix(in srgb, var(--ink) 82%, transparent); }
.article-byline { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 26px; font-family: var(--f-mono); font-size: 13px; letter-spacing: .04em; text-transform: uppercase; }
.article-byline .av { width: 38px; height: 38px; border-radius: 50%; border: 2.5px solid var(--ink); flex: none; }
.article-byline .dot { opacity: .5; }

.article-cover { position: relative; aspect-ratio: 21/9; border: 3px solid var(--ink); border-radius: 8px; overflow: hidden; box-shadow: 8px 8px 0 var(--ink); margin: clamp(28px, 4vw, 52px) 0; }
.article-cover .ph { position: absolute; inset: 0; }
.article-cover figcaption { position: absolute; bottom: 0; left: 0; right: 0; z-index: 2; padding: 22px 16px 12px; font-family: var(--f-mono); font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--bone); background: linear-gradient(transparent, rgba(0,0,0,.7)); }

/* readable body */
.prose { font-size: clamp(17px, 1.25vw, 20px); line-height: 1.72; }
.prose > * { max-width: 720px; }
.prose > .full { max-width: 100%; }
.prose p { margin: 0 0 1.35em; }
.prose h2 { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(28px, 3.6vw, 50px); line-height: .96; letter-spacing: -0.01em; margin: 2em 0 .5em; }
.prose h2 .num { color: var(--c2); margin-right: .3em; }
.prose h3 { font-family: var(--f-disp); font-weight: 800; font-size: clamp(20px, 2vw, 28px); margin: 1.7em 0 .4em; }
.prose ul, .prose ol { margin: 0 0 1.35em; padding-left: 1.3em; }
.prose li { margin: .4em 0; }
.prose strong { font-weight: 700; }
.prose a { color: inherit; text-decoration: underline; text-decoration-color: var(--c2); text-decoration-thickness: 2px; text-underline-offset: 3px; }
.prose a:hover { color: var(--c2); }

.pullquote { margin: 1.6em 0; padding: 6px 0 6px 28px; border-left: 6px solid var(--c2); font-family: var(--f-serif); font-style: italic; font-size: clamp(24px, 3vw, 40px); line-height: 1.15; }
.pullquote cite { display: block; margin-top: 10px; font-family: var(--f-mono); font-style: normal; font-size: 13px; letter-spacing: .06em; text-transform: uppercase; color: color-mix(in srgb, var(--ink) 60%, transparent); }

figure.inline-fig { margin: 1.8em 0; }
figure.inline-fig .ph { aspect-ratio: 16/9; border: 3px solid var(--ink); border-radius: 6px; box-shadow: 6px 6px 0 var(--ink); position: relative; overflow: hidden; }
figure.inline-fig figcaption { margin-top: 10px; font-family: var(--f-mono); font-size: 12px; letter-spacing: .03em; color: color-mix(in srgb, var(--ink) 60%, transparent); }

.callout { margin: 1.8em 0; padding: 22px 24px; border: 3px solid var(--ink); border-radius: 6px; background: var(--c4); box-shadow: 6px 6px 0 var(--ink); }
.callout b { font-family: var(--f-disp); text-transform: uppercase; display: block; margin-bottom: 6px; font-size: 14px; letter-spacing: .04em; }
.callout p { margin: 0; font-size: 16px; }

pre.code { margin: 1.8em 0; padding: 20px 22px; background: var(--ink); color: var(--c1); border-radius: 6px; overflow-x: auto; font-family: var(--f-mono); font-size: 14px; line-height: 1.6; box-shadow: 6px 6px 0 rgba(0,0,0,.4); }
pre.code .c { color: color-mix(in srgb, var(--bone) 55%, transparent); }
pre.code .k { color: var(--c3); }

.article-foot { border-top: 3px solid var(--ink); margin-top: clamp(40px, 6vw, 76px); padding-top: 26px; }
.share { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.share span { font-family: var(--f-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; margin-right: 4px; }
.share a { font-family: var(--f-disp); font-weight: 700; text-transform: uppercase; font-size: 13px; border: 2px solid var(--ink); padding: 7px 13px; border-radius: 999px; transition: background-color .15s, color .15s, transform .15s; }
.share a:hover { background: var(--ink); color: var(--bone); transform: translateY(-2px); }

/* related + cta */
.related { margin-top: clamp(44px, 6vw, 84px); }
.related h2 { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(28px, 4vw, 56px); line-height: .9; margin: 0 0 24px; }

.blog-cta { margin-top: clamp(48px, 7vw, 96px); margin-bottom: clamp(64px, 9vw, 120px); background: var(--ink); color: var(--bone); border-radius: 10px; padding: clamp(34px, 5vw, 72px); text-align: center; position: relative; overflow: hidden; }
.blog-cta h2 { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(40px, 7vw, 110px); line-height: .84; margin: 0 0 10px; }
.blog-cta h2 .o { color: var(--c1); }
.blog-cta p { font-family: var(--f-serif); font-style: italic; font-size: clamp(18px, 2vw, 26px); margin: 0 auto 24px; max-width: 26ch; color: color-mix(in srgb, var(--bone) 84%, transparent); }

/* blog footer */
.bfoot { margin-top: clamp(50px, 7vw, 90px); border-top: 3px solid var(--ink); }
.bfoot__row { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; padding: 26px 0; font-family: var(--f-mono); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; }
.bfoot__logo { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(34px, 6vw, 72px); line-height: .8; padding-bottom: 14px; }
.bfoot__logo b { color: var(--c2); }

/* accent marquee (light) - full-bleed to the viewport edges */
.b-marquee { overflow: hidden; border-block: 3px solid var(--ink); background: var(--c1); color: var(--ink); width: 100vw; margin-inline: calc(50% - 50vw); }
.b-marquee__track { display: flex; width: max-content; animation: bmarq 30s linear infinite; }
.b-marquee:hover .b-marquee__track { animation-play-state: paused; }
.b-marquee span { font-family: var(--f-head); text-transform: uppercase; font-size: clamp(22px, 3vw, 40px); padding: .25em .4em; white-space: nowrap; }
.b-marquee .s { -webkit-text-stroke: 1.5px var(--ink); color: transparent; }
@keyframes bmarq { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .b-marquee__track { animation: none; } }
