/* ===== Blog ===== */
.blog-hero{ padding-bottom:40px; }
.blog-body{ padding-top:38px; }

.bp-filters{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:42px; }

/* featured */
.bp-featured{
  display:grid; grid-template-columns:1.15fr 1fr; gap:0; text-decoration:none;
  border:1px solid var(--line); border-radius:22px; overflow:hidden; margin-bottom:48px;
  background:rgba(255,255,255,.5); transition:box-shadow .35s ease, transform .35s ease;
}
.bp-featured:hover{ transform:translateY(-3px); box-shadow:0 40px 80px -50px rgba(20,30,20,.55); }
.bp-featured-img{ overflow:hidden; min-height:340px; }
.bp-featured-img .frame-img{ transition:transform .8s cubic-bezier(.2,.7,.2,1); }
.bp-featured:hover .bp-featured-img .frame-img{ transform:scale(1.05); }
.bp-featured-body{ padding:44px 44px; display:flex; flex-direction:column; align-items:flex-start; gap:14px; }
.bp-flag{ font-family:var(--mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--emerald-900); background:var(--gold); padding:5px 12px; border-radius:999px; }
.bp-featured-title{ font-family:var(--display); font-weight:500; font-size:clamp(30px,3.6vw,46px); line-height:1.04; color:var(--ink); margin:2px 0 0; }
.bp-featured-excerpt{ font-size:16px; line-height:1.6; color:var(--ink-soft); margin:0; max-width:38em; }
.bp-featured .btn{ margin-top:8px; }

/* meta line */
.bp-meta{ display:flex; align-items:center; gap:9px; font-size:12.5px; color:var(--ink-soft); font-family:var(--sans); }
.bp-cat{ color:var(--emerald-700); font-weight:500; letter-spacing:.02em; }
.bp-dot{ opacity:.5; }

/* grid */
.bp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px 24px; }
.bp-card{
  display:flex; flex-direction:column; text-decoration:none; border-radius:16px; overflow:hidden;
  background:rgba(255,255,255,.5); border:1px solid var(--line);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.bp-card:hover{ transform:translateY(-4px); box-shadow:0 30px 60px -42px rgba(20,30,20,.5); border-color:rgba(187,145,82,.4); }
.bp-thumb{ aspect-ratio:3/2; overflow:hidden; }
.bp-thumb .frame-img{ transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.bp-card:hover .bp-thumb .frame-img{ transform:scale(1.06); }
.bp-body{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:11px; flex:1; }
.bp-title{ font-family:var(--display); font-weight:500; font-size:24px; line-height:1.12; color:var(--ink); margin:2px 0 0; }
.bp-excerpt{ font-size:14px; line-height:1.55; color:var(--ink-soft); margin:0; flex:1; }
.bp-more{ display:inline-flex; align-items:center; gap:7px; font-size:13.5px; color:var(--emerald-700); font-weight:500; margin-top:4px; }
.bp-card:hover .bp-more svg{ transform:translateX(3px); }
.bp-more svg{ transition:transform .25s ease; }
body[dir="rtl"] .bp-card:hover .bp-more svg{ transform:translateX(-3px); }

@media(max-width:980px){
  .bp-grid{ grid-template-columns:repeat(2,1fr); }
  .bp-featured{ grid-template-columns:1fr; }
  .bp-featured-img{ min-height:240px; aspect-ratio:16/9; }
  .bp-featured-body{ padding:32px 28px; }
}
@media(max-width:620px){
  .bp-grid{ grid-template-columns:1fr; }
}

/* ===== Article ===== */
.article-hero{ position:relative; max-width:880px; margin:0 auto; padding:140px 28px 30px; text-align:center; }
.article-hero .bp-meta{ justify-content:center; margin-bottom:16px; }
.article-title{ font-family:var(--display); font-weight:500; font-size:clamp(36px,5.4vw,64px); line-height:1.02; color:var(--cream); letter-spacing:-.01em; margin:0 auto; max-width:16em; }
.article-back{ display:inline-flex; align-items:center; gap:8px; color:rgba(245,239,225,.8); text-decoration:none; font-size:13.5px; margin-bottom:22px; }
.article-back:hover{ color:var(--cream); }
.article-lead-img{ max-width:1020px; margin:6px auto 0; padding:0 28px; }
.article-lead-img .frame-img{ aspect-ratio:16/9; border-radius:20px; border:1px solid rgba(245,239,225,.16); }
.article-body{ max-width:720px; margin:0 auto; padding:14px 28px 40px; }
.article-body p{ font-size:18px; line-height:1.75; color:var(--ink); margin:0 0 22px; }
.article-body p.standfirst{ font-size:21px; line-height:1.6; color:var(--ink-soft); font-family:var(--display); }
.article-body h2{ font-family:var(--display); font-weight:500; font-size:32px; line-height:1.1; color:var(--emerald-800); margin:40px 0 14px; }
.article-body h3{ font-family:var(--display); font-weight:500; font-size:24px; color:var(--ink); margin:28px 0 10px; }
.article-body ul{ margin:0 0 22px; padding-inline-start:22px; display:flex; flex-direction:column; gap:10px; }
.article-body li{ font-size:17px; line-height:1.6; color:var(--ink); }
.article-body li::marker{ color:var(--gold); }
.article-quote{ margin:30px 0; padding:4px 0 4px 22px; border-inline-start:3px solid var(--gold); font-family:var(--display); font-size:26px; line-height:1.3; color:var(--emerald-800); font-style:italic; }
.article-cta{ margin:40px 0 0; padding:34px; border-radius:18px; text-align:center; background:linear-gradient(135deg, rgba(16,48,36,.06), rgba(187,145,82,.1)); border:1px solid var(--line); }
.article-cta h3{ margin:0 0 8px; color:var(--emerald-800); }
.article-cta p{ margin:0 0 18px; color:var(--ink-soft); font-size:15.5px; }
.article-tags{ display:flex; gap:9px; flex-wrap:wrap; margin:36px 0 0; padding-top:24px; border-top:1px solid var(--line); }
.article-tags span{ font-size:12px; color:var(--ink-soft); border:1px solid var(--line); padding:5px 13px; border-radius:999px; }
.article-related{ max-width:1020px; margin:0 auto; padding:10px 28px 96px; }
.article-related h2{ font-family:var(--display); font-weight:500; font-size:30px; color:var(--ink); margin:0 0 22px; text-align:center; }
.article-related .bp-grid{ grid-template-columns:repeat(3,1fr); }
@media(max-width:980px){ .article-related .bp-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:760px){ .article-related .bp-grid{ grid-template-columns:1fr; } .article-body p{ font-size:17px; } }

/* ---- filter pills (blog) ---- */
.pill{
  font-family:var(--sans); font-size:13.5px; padding:9px 18px; border-radius:999px; cursor:pointer;
  background:transparent; color:var(--emerald-700); border:1px solid rgba(17,66,49,.22);
  transition:background .2s ease, color .2s ease, border-color .2s ease;
}
.pill:hover{ border-color:var(--emerald-700); }
.pill.active{ background:var(--emerald-700); color:var(--cream); border-color:var(--emerald-700); }
