/* ══════════════════════════════════════════════════════
   BLOG PAGE - scoped styles (both themes)
   ══════════════════════════════════════════════════════ */
.page-blog {
  --bl-paper: #FAFAFA;
  --bl-card: #FFFFFF;
  --bl-ink: #1A1A1A;
  --bl-ink-light: #666;
  --bl-border: #E5E5E5;
  --bl-orange: #E68900;
  --bl-orange-hover: #FF9800;
  --bl-ease: cubic-bezier(.4,0,.2,1);

  background: var(--bl-paper);
  color: var(--bl-ink);
  font-family: var(--f-b);
  line-height: 1.6;
  padding-top: 70px; /* clearance for fixed global header */
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
[data-theme="dark"] .page-blog,
html:not([data-theme="light"]) .page-blog {
  --bl-paper: #0A0A0A;
  --bl-card: #111;
  --bl-ink: #F0F0F0;
  --bl-ink-light: #9A9A9A;
  --bl-border: rgba(255,255,255,.08);
  --bl-orange: #FF9800;
  --bl-orange-hover: #FFB74D;
}
.page-blog *, .page-blog *::before, .page-blog *::after { box-sizing: border-box; }
.page-blog .bl-container { max-width: 1320px; margin: 0 auto; padding: 0 40px; }

/* ── HERO HEADER ── */
.page-blog .bl-header { padding: 80px 0 60px; position: relative; }
.page-blog .tag-meta{
  font-family: var(--f-m); font-size: .65rem; color: var(--bl-orange);
  text-transform: uppercase; letter-spacing: .15em;
  display: flex; align-items: center; gap: 12px; margin-bottom: 24px;
}
.page-blog .tag-meta::before{ content:""; width:8px; height:8px; background: var(--bl-orange); border-radius:50%; }
.page-blog .bl-title{
  font-family: var(--f-d); font-size: clamp(3.5rem, 10vw, 8rem); font-weight: 900;
  line-height: .9; letter-spacing: -.04em; text-transform: uppercase;
  display: flex; flex-direction: column;
}
.page-blog .bl-title .stroke{ color: var(--bl-orange); }
.page-blog .bl-title .solid { color: var(--bl-ink); }
.page-blog .bl-title .solid span{ color: var(--bl-orange); }

/* ── FILTERS ── */
.page-blog .bl-filters{
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  margin-bottom: 72px; border-top: 1px solid var(--bl-border); padding-top: 32px;
}
.page-blog .f-label{
  font-family: var(--f-m); font-size: .65rem; color: var(--bl-ink-light);
  text-transform: uppercase; letter-spacing: .1em; margin-right: 16px;
}
.page-blog .f-btn{
  background: transparent; border: 1px solid var(--bl-border);
  padding: 10px 24px; font-family: var(--f-m); font-size: .7rem; font-weight: 700;
  color: var(--bl-ink); text-transform: uppercase; letter-spacing: .05em;
  cursor: pointer; transition: all .3s var(--bl-ease);
  clip-path: polygon(4px 0, 100% 0, 100% calc(100% - 4px), calc(100% - 4px) 100%, 0 100%, 0 4px);
}
.page-blog .f-btn:hover{ border-color: var(--bl-ink); }
.page-blog .f-btn.active{
  background: var(--bl-orange); border-color: var(--bl-orange); color: var(--bl-paper);
  clip-path: polygon(1% 0%, 100% 4%, 98% 100%, 0% 96%);
}

/* ── COMMON POST ELEMENTS ── */
.page-blog .post-cat{
  background: var(--bl-orange); color: var(--bl-paper);
  font-family: var(--f-m); font-size: .6rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .1em;
  padding: 6px 12px; display: inline-block; margin-bottom: 16px;
}
.page-blog .post-meta{
  font-family: var(--f-m); font-size: .65rem; color: var(--bl-ink-light);
  text-transform: uppercase; letter-spacing: .05em;
  display: flex; gap: 16px; margin-top: 24px;
}
.page-blog .read-more{
  margin-top: auto; font-family: var(--f-m); font-size: .7rem; font-weight: 700;
  color: var(--bl-orange); text-transform: uppercase; letter-spacing: .1em;
  display: inline-flex; align-items: center; gap: 8px; text-decoration: none; transition: .3s;
}
.page-blog .read-more::after{ content:'→'; transition: transform .3s var(--bl-ease); }
.page-blog .read-more:hover{ color: var(--bl-ink); }
.page-blog .read-more:hover::after{ transform: translateX(5px); }

/* ── FEATURED POST ── */
.page-blog .featured-post{
  position: relative; margin-bottom: 120px; display: block;
  text-decoration: none; color: inherit;
}
.page-blog .fp-img-wrap{
  width: 75%; height: 600px; overflow: hidden;
  clip-path: polygon(0 0, 100% 0, 95% 100%, 0 100%);
  transition: clip-path .6s var(--bl-ease);
}
.page-blog .fp-img-wrap img{
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(100%) contrast(1.1);
  transition: filter .6s var(--bl-ease), transform .8s var(--bl-ease);
}
.page-blog .fp-content{
  position: absolute; bottom: -40px; right: 0; width: 50%;
  background: var(--bl-ink); color: var(--bl-paper); padding: 56px;
  clip-path: polygon(2% 0, 100% 0, 100% 100%, 0 98%);
  box-shadow: -20px 20px 60px rgba(0,0,0,.1);
  transition: transform .4s var(--bl-ease);
}
[data-theme="dark"] .page-blog .fp-content,
html:not([data-theme="light"]) .page-blog .fp-content{
  background: #F0F0F0; color: #1A1A1A;
}
.page-blog .fp-content .post-cat{ background: var(--bl-paper); color: var(--bl-ink); }
.page-blog .fp-content h2{
  font-family: var(--f-d); font-size: clamp(2rem, 3vw, 3rem); font-weight: 800;
  line-height: 1.1; letter-spacing: -.02em; margin-bottom: 24px;
}
.page-blog .fp-content p{ color: #A0A0A0; font-size: 1.1rem; line-height: 1.6; }
[data-theme="dark"] .page-blog .fp-content p,
html:not([data-theme="light"]) .page-blog .fp-content p{ color: #555; }
.page-blog .fp-content .post-meta{ border-top: 1px solid #333; padding-top: 24px; color: #888; }
[data-theme="dark"] .page-blog .fp-content .post-meta,
html:not([data-theme="light"]) .page-blog .fp-content .post-meta{ border-top-color: #CCC; color: #666; }
.page-blog .featured-post:hover .fp-img-wrap{ clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); }
.page-blog .featured-post:hover .fp-img-wrap img{ filter: grayscale(0%); transform: scale(1.05); }
.page-blog .featured-post:hover .fp-content{ transform: translate(-10px, -10px); }

/* ── MASONRY GRID ── */
.page-blog .bl-grid{
  display: grid; grid-template-columns: repeat(12, 1fr);
  gap: 40px; margin-bottom: 120px;
}
.page-blog .post-card{
  display: flex; flex-direction: column; text-decoration: none; color: inherit;
}
.page-blog .pc-img-wrap{
  width: 100%; height: 320px; overflow: hidden; margin-bottom: 24px;
  clip-path: polygon(0 0, 100% 2%, 98% 100%, 0 98%);
  transition: clip-path .5s var(--bl-ease);
}
.page-blog .pc-img-wrap img{
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(100%) contrast(1.1);
  transition: all .6s var(--bl-ease);
}
.page-blog .post-card h3{
  font-family: var(--f-d); font-size: clamp(1.4rem, 2vw, 1.8rem); font-weight: 800;
  line-height: 1.1; letter-spacing: -.02em; margin-bottom: 16px; transition: color .3s;
}
.page-blog .post-card p{ color: var(--bl-ink-light); font-size: 1rem; line-height: 1.6; margin-bottom: 24px; }
.page-blog .post-card:hover .pc-img-wrap{ clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); }
.page-blog .post-card:hover .pc-img-wrap img{ filter: grayscale(0%); transform: scale(1.05); }
.page-blog .post-card:hover h3{ color: var(--bl-orange); }

/* Asymmetric grid placements (cycles through 4 patterns) */
.page-blog .post-card.span-7 { grid-column: span 7; }
.page-blog .post-card.span-7 .pc-img-wrap { height: 400px; }
.page-blog .post-card.span-5 { grid-column: span 5; }
.page-blog .post-card.span-5 .pc-img-wrap { height: 400px; clip-path: polygon(2% 0, 100% 0, 100% 98%, 0 100%); }
.page-blog .post-card.span-4 { grid-column: span 4; }
.page-blog .post-card.span-8 { grid-column: span 8; }
.page-blog .post-card.span-8 .pc-img-wrap { clip-path: polygon(0 2%, 100% 0, 98% 100%, 0 100%); }
.page-blog .post-card.span-12 { grid-column: span 12; }
.page-blog .post-card.span-12 .pc-img-wrap { height: 440px; clip-path: polygon(0 0, 100% 1%, 99% 100%, 0 99%); }

/* Hidden by filter */
.page-blog .post-card.is-hidden,
.page-blog .featured-post.is-hidden { display: none; }

/* ── NEWSLETTER (brutalist) ── */
.page-blog .bl-nl{
  background: var(--bl-ink); color: var(--bl-paper); padding: 0;
  border-top: 10px solid var(--bl-orange); overflow: hidden;
  display: flex; flex-direction: column;
}
[data-theme="dark"] .page-blog .bl-nl,
html:not([data-theme="light"]) .page-blog .bl-nl{ background: #1A1A1A; color: #F0F0F0; }
.page-blog .nl-marquee{
  display: flex; gap: 40px; width: max-content; padding: 24px 0;
  border-bottom: 1px solid #333; animation: blMarquee 15s linear infinite;
}
.page-blog .nl-marquee span{
  font-family: var(--f-d); font-size: 1.5rem; font-weight: 900;
  text-transform: uppercase; color: transparent; -webkit-text-stroke: 1px #555;
}
.page-blog .nl-marquee span::after{ content:'◆'; color: var(--bl-orange); font-size: .8rem; margin-left: 40px; -webkit-text-stroke: 0; }
@keyframes blMarquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.page-blog .nl-inner{
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  padding: 80px 40px; max-width: 1320px; margin: 0 auto; width: 100%;
}
.page-blog .nl-text h2{
  font-family: var(--f-d); font-size: clamp(2.5rem, 4vw, 4rem); font-weight: 900;
  line-height: 1; letter-spacing: -.03em; margin-bottom: 16px;
}
.page-blog .nl-text p{ color: #A0A0A0; font-size: 1.1rem; }
.page-blog .nl-form{ display: flex; align-items: stretch; height: 72px; }
.page-blog .nl-form input{
  flex-grow: 1; background: #111; border: 1px solid #333; border-right: none;
  padding: 0 32px; color: #FFF; font-family: var(--f-b); font-size: 1.1rem;
  outline: none; transition: .3s;
}
.page-blog .nl-form input:focus{ border-color: var(--bl-orange); background: #000; }
.page-blog .nl-form button{
  background: var(--bl-orange); color: var(--bl-ink); border: none; padding: 0 40px;
  font-family: var(--f-d); font-weight: 800; font-size: 1rem; text-transform: uppercase;
  cursor: pointer; transition: .3s var(--bl-ease);
  clip-path: polygon(10px 0, 100% 0, 100% 100%, 0 100%);
}
.page-blog .nl-form button:hover{ background: var(--bl-paper); }

@media (max-width: 1024px) {
  .page-blog .fp-img-wrap { width: 100%; height: 400px; clip-path: none; }
  .page-blog .fp-content { position: relative; width: 90%; margin: -60px auto 0; bottom: 0; clip-path: none; }
  .page-blog .bl-grid { grid-template-columns: 1fr; gap: 64px; }
  .page-blog .post-card.span-7, .page-blog .post-card.span-5,
  .page-blog .post-card.span-4, .page-blog .post-card.span-8,
  .page-blog .post-card.span-12 { grid-column: span 1; }
  .page-blog .post-card .pc-img-wrap { height: 280px; clip-path: none; }
  .page-blog .nl-inner { grid-template-columns: 1fr; gap: 32px; padding: 64px 24px; }
  .page-blog .nl-form { flex-direction: column; height: auto; gap: 16px; }
  .page-blog .nl-form input { border-right: 1px solid #333; padding: 20px; }
  .page-blog .nl-form button { padding: 20px; clip-path: none; }
  .page-blog .bl-container { padding: 0 24px; }
}
