.cta-band::before {
  content: ""; position: absolute; inset: -2%; z-index: 0;
  background: url(../../img/bg/67f2c2fd-d0df-4f6f-89da-359ba86093e8.jpg) center 32% / cover no-repeat;
  transform-origin: 68% 34%;
  animation: ctaZoom 26s ease-in-out infinite alternate;
  will-change: transform;
}

/* ============================================================
   COFFEE LADY — Blog / Journal page
   Editorial overhaul. Builds on jura.css (palette, nav, footer,
   buttons, cta-band, quote drawer). Self-contained section styles.
   ============================================================ */

.bl-h2 { font-size: clamp(28px, 3.4vw, 44px); }

/* ============================================================
   HERO — compact dark brand band
   ============================================================ */
.bl-hero {
  position: relative; overflow: hidden; color: var(--brand-text);
  background:
    radial-gradient(110% 90% at 82% 0%, rgba(191,56,38,.26), transparent 56%),
    radial-gradient(90% 90% at 6% 100%, rgba(207,106,67,.20), transparent 60%),
    linear-gradient(180deg, var(--brand-bg-2), var(--brand-bg));
}

.bl-hero .hero-photo { position: absolute; inset: 0; z-index: 0; overflow: hidden; }

.bl-hero .hero-photo img {
  width: 100%; height: 100%; object-fit: cover;
  object-position: 50% 42%;
  transform-origin: 50% 42%;
  animation: blHeroZoom 26s ease-in-out infinite alternate;
  will-change: transform;
}

@keyframes blHeroZoom { from { transform: scale(1); } to { transform: scale(1.1); } }

@media (prefers-reduced-motion: reduce){ .bl-hero .hero-photo img { animation: none; } }

.bl-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(22,17,15,.44), rgba(22,17,15,.58)),
    linear-gradient(110deg, rgba(135,29,21,.24), rgba(194,94,56,.10));
}

.bl-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 22px 22px; opacity: .5;
}

.bl-hero .wrap { position: relative; z-index: 2; }

/* breadcrumb aligned under the logo (matches nav width on other pages) */
.bl-hero .hero-crumb { position: relative; z-index: 2; }

.bl-hero .hero-crumb .wrap { max-width: 1600px; padding: 24px 48px 0; }

.bl-hero .breadcrumb {
  display: flex; align-items: center; gap: 9px; flex-wrap: wrap;
  font-size: 13px; font-weight: 500; color: rgba(255,255,255,.72);
}

.bl-hero .breadcrumb a { color: rgba(255,255,255,.72); }

.bl-hero .breadcrumb a:hover { color: #fff; }

.bl-hero .breadcrumb .sep { opacity: .5; }

.bl-hero .breadcrumb .here { color: #fff; font-weight: 600; }

/* centered hero copy */
.bl-hero-copy {
  position: relative; z-index: 2; max-width: 1000px; margin: 0 auto;
  padding: 54px 28px 70px; text-align: center;
}

.bl-hero h1 {
  color: #fff; font-size: clamp(34px, 4.8vw, 58px); line-height: 1.05;
  letter-spacing: -0.03em; max-width: 18ch; margin: 0 auto 20px;
}

.bl-hero h1 em { font-style: normal; color: var(--terracotta-soft); }

.bl-hero-sub {
  font-size: clamp(16px, 1.55vw, 18.5px); color: var(--brand-muted);
  max-width: 60ch; margin: 0 auto; font-weight: 400; line-height: 1.65;
}

@media (max-width: 700px){
  .bl-hero .hero-crumb .wrap { padding: 18px 22px 0; }
  .bl-hero-copy { padding: 40px 22px 54px; }
}

/* ============================================================
   FEATURED LEAD ARTICLE
   ============================================================ */
.bl-featured { background: var(--paper); }

.bl-featured .wrap { max-width: 1180px; }

.bl-feat-head {
  display: flex; align-items: center; gap: 14px; margin-bottom: 26px;
}

.bl-feat-head .bl-tag-lead {
  font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--red);
}

.bl-feat-head .rule { flex: 1; height: 1px; background: var(--line); }

.bl-feat {
  display: grid; grid-template-columns: 1.06fr .94fr; gap: 0;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-soft);
}

.bl-feat-media { position: relative; min-height: 380px; background: var(--cream-2); }

.bl-feat-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

.bl-feat-body { padding: 46px 48px; display: flex; flex-direction: column; }

.bl-cat {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 600; letter-spacing: .02em;
  color: var(--terracotta-deep); background: var(--cream);
  border: 1px solid var(--line); padding: 6px 13px; border-radius: 999px;
}

.bl-cat .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--terracotta); }

.bl-feat-body h2 {
  font-size: clamp(26px, 2.7vw, 34px); line-height: 1.12; letter-spacing: -0.02em;
  margin: 20px 0 16px; max-width: 18ch;
}

.bl-feat-body h2 a:hover { color: var(--red); }

.bl-feat-excerpt { font-size: 16px; color: var(--ink-soft); font-weight: 400; line-height: 1.7; max-width: 52ch; }

.bl-feat-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
  margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--line);
}

.bl-meta { display: flex; align-items: center; gap: 14px; font-size: 13px; color: var(--ink-faint); font-weight: 500; }

.bl-meta .m { display: inline-flex; align-items: center; gap: 7px; }

.bl-meta .m svg { color: var(--terracotta-deep); }

.bl-meta .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--line); }

@media (max-width: 880px){
  .bl-feat { grid-template-columns: 1fr; }
  .bl-feat-media { min-height: 260px; }
  .bl-feat-body { padding: 34px 28px; }
}

/* ============================================================
   ARTICLES — toolbar + grid
   ============================================================ */
.bl-articles { background: var(--cream); }

.bl-articles .wrap { max-width: 1180px; }

.bl-toolbar {
  display: flex; align-items: center; justify-content: space-between; gap: 22px; flex-wrap: wrap;
  margin-bottom: 38px;
}

.bl-search { position: relative; flex: 1; min-width: 240px; max-width: 360px; }

.bl-search svg { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--ink-faint); pointer-events: none; }

.bl-search input {
  width: 100%; padding: 13px 18px 13px 44px; border-radius: 999px;
  border: 1px solid var(--line); background: var(--cream-2); color: var(--ink);
  font-family: inherit; font-size: 14.5px; transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.bl-search input::placeholder { color: var(--ink-faint); }

.bl-search input:focus { outline: none; background: #fff; border-color: var(--red); box-shadow: 0 0 0 3px rgba(191,56,38,.1); }

.bl-chips { display: flex; flex-wrap: wrap; gap: 8px; }

.bl-chip {
  padding: 9px 17px; border-radius: 999px; font-size: 13.5px; font-weight: 600;
  background: var(--paper); color: var(--ink-soft); border: 1px solid var(--line);
  transition: all .16s ease; white-space: nowrap;
}

.bl-chip:hover { border-color: var(--terracotta); color: var(--ink); }

.bl-chip.active { background: var(--ink); color: #fff; border-color: var(--ink); }

@media (max-width: 720px){
  .bl-toolbar { flex-direction: column; align-items: stretch; }
  .bl-search { max-width: 100%; }
  .bl-chips { overflow-x: auto; padding-bottom: 4px; -webkit-overflow-scrolling: touch; }
}

.bl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }

@media (max-width: 920px){ .bl-grid { grid-template-columns: 1fr 1fr; } }

@media (max-width: 560px){ .bl-grid { grid-template-columns: 1fr; } }

.bl-card {
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--paper); border: 1px solid var(--line-soft); border-radius: var(--radius);
  box-shadow: var(--shadow-card); transition: transform .2s ease, box-shadow .2s ease;
}

.bl-card:hover { transform: translateY(-4px); box-shadow: 0 1px 2px rgba(42,34,30,.05), 0 26px 50px -30px rgba(42,34,30,.55); }

.bl-card-media { position: relative; height: 210px; background: var(--cream-2); border-bottom: 1px solid var(--line-soft); overflow: hidden; }

.bl-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }

.bl-card:hover .bl-card-media img { transform: scale(1.05); }

.bl-card-body { padding: 22px 24px 0; display: flex; flex-direction: column; flex: 1; }

.bl-card-tag {
  font-size: 12px; font-weight: 600; letter-spacing: .04em;
  color: var(--terracotta-deep); margin-bottom: 11px;
}

.bl-card-body h3 {
  font-size: 19px; line-height: 1.25; letter-spacing: -0.01em; margin-bottom: 11px;
}

.bl-card-body h3 a { background-image: linear-gradient(var(--red), var(--red)); background-size: 0 1.5px; background-repeat: no-repeat; background-position: 0 100%; transition: background-size .25s ease, color .15s ease; }

.bl-card:hover .bl-card-body h3 a { color: var(--red); }

.bl-card-body p { font-size: 14.5px; color: var(--ink-soft); font-weight: 400; line-height: 1.65; }

.bl-card-foot {
  margin-top: auto; padding: 18px 24px 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}

.bl-card-foot .bl-meta { font-size: 12.5px; gap: 10px; }

.bl-readmore {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13.5px; font-weight: 600; color: var(--red);
}

.bl-readmore svg { transition: transform .2s ease; }

.bl-card:hover .bl-readmore svg { transform: translateX(3px); }

/* empty state */
.bl-empty {
  display: none; text-align: center; padding: 60px 20px;
  color: var(--ink-soft); font-size: 16px; font-weight: 400;
}

.bl-empty.show { display: block; }

/* ============================================================
   PAGINATION — matches category page (.pager pills)
   ============================================================ */
.pager { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 52px; }

.pager button {
  min-width: 44px; height: 44px; padding: 0 14px; font-family: inherit;
  font-size: 15px; font-weight: 600; color: var(--ink-soft);
  background: var(--paper); border: 1px solid var(--line); border-radius: 999px;
  display: grid; place-items: center; cursor: pointer;
  transition: color .16s ease, border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}

.pager button:hover:not(:disabled) { border-color: var(--terracotta-deep); color: var(--terracotta-deep); transform: translateY(-1px); }

.pager button.active { background: var(--terracotta-deep); border-color: var(--terracotta-deep); color: #fff; box-shadow: 0 10px 20px -12px rgba(194,94,56,.95); }

.pager button.active:hover { transform: none; color: #fff; }

.pager button:disabled { opacity: .4; cursor: default; }

.pager .pg-arrow { width: 44px; min-width: 44px; padding: 0; color: var(--ink); }

.pager .pg-arrow svg { display: block; }

@media (prefers-reduced-motion: reduce){ .pager button:hover:not(:disabled) { transform: none; } }

/* reveal-on-scroll (mirrors jura.css) */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }

@media (max-width: 640px){
  .section { padding: 60px 0; }
}

/* ============================================================
   COFFEE LADY — Blog article / detail page
   Centered editorial layout, no sidebar. Builds on jura.css +
   shares the blog overhaul's palette, nav, footer, cta-band.
   ============================================================ */

/* ============================================================
   ARTICLE HERO — compact dark brand band, centered
   ============================================================ */
.art-hero {
  position: relative; overflow: hidden; color: var(--brand-text);
  background:
    radial-gradient(110% 90% at 82% 0%, rgba(191,56,38,.26), transparent 56%),
    radial-gradient(90% 90% at 6% 100%, rgba(207,106,67,.20), transparent 60%),
    linear-gradient(180deg, var(--brand-bg-2), var(--brand-bg));
}

.art-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 22px 22px; opacity: .55;
}

.art-hero .hero-crumb { position: relative; z-index: 2; }

.art-hero .hero-crumb .wrap { max-width: 1600px; padding: 24px 48px 0; }

.art-hero .breadcrumb {
  display: flex; align-items: center; gap: 9px; flex-wrap: wrap;
  font-size: 13px; font-weight: 500; color: rgba(255,255,255,.72); margin: 0;
}

.art-hero .breadcrumb a { color: rgba(255,255,255,.72); }

.art-hero .breadcrumb a:hover { color: #fff; }

.art-hero .breadcrumb .sep { opacity: .5; }

.art-hero .breadcrumb .here { color: #fff; font-weight: 600; }

.art-hero-copy {
  position: relative; z-index: 2; max-width: 860px; margin: 0 auto;
  padding: 46px 28px 150px; text-align: center;
}

.art-cat {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; letter-spacing: .01em;
  color: var(--terracotta-soft);
  background: rgba(226,165,131,.1); border: 1px solid rgba(226,165,131,.3);
  padding: 7px 15px; border-radius: 999px; margin-bottom: 22px;
}

.art-cat .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--terracotta-soft); }

.art-hero h1 {
  color: #fff; font-size: clamp(32px, 4.6vw, 54px); line-height: 1.06;
  letter-spacing: -0.03em; max-width: 20ch; margin: 0 auto 24px;
}

.art-meta {
  display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap;
  font-size: 14px; color: var(--brand-muted); font-weight: 500;
}

.art-meta .m { display: inline-flex; align-items: center; gap: 8px; }

.art-meta .m svg { color: var(--terracotta-soft); }

.art-meta .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--brand-line); }

.art-meta .author { color: var(--brand-text); }

@media (max-width: 700px){
  .art-hero .hero-crumb .wrap { padding: 18px 22px 0; }
  .art-hero-copy { padding: 34px 22px 130px; }
}

/* ============================================================
   FEATURED IMAGE — pulled up to overlap the hero
   ============================================================ */
.art-figure {
  position: relative; z-index: 3;
  max-width: 1040px; margin: -110px auto 0; padding: 0 28px;
}

.art-figure figure { margin: 0; }

.art-figure img {
  width: 100%; height: clamp(280px, 42vw, 480px); object-fit: cover;
  border-radius: 20px;
  box-shadow: 0 30px 70px -34px rgba(42,34,30,.62);
}

.art-figure figcaption {
  text-align: center; font-size: 13px; color: var(--ink-faint);
  font-weight: 400; margin-top: 16px;
}

@media (max-width: 700px){
  .art-figure { margin-top: -96px; padding: 0 22px; }
}

/* ============================================================
   ARTICLE BODY — centered single column, no sidebar
   ============================================================ */
.art-body { background: var(--paper); padding: 70px 0 90px; }

.art-prose { max-width: 740px; margin: 0 auto; padding: 0 28px; }

.art-prose > p {
  font-size: 18px; line-height: 1.78; color: #4d453f; font-weight: 400;
  margin-bottom: 22px;
}

.art-prose > p:first-of-type { font-size: 19.5px; line-height: 1.7; color: var(--ink); }

.art-prose a:not(.btn) {
  color: var(--red); font-weight: 600;
  background-image: linear-gradient(var(--red), var(--red));
  background-size: 100% 1.5px; background-repeat: no-repeat; background-position: 0 100%;
  padding-bottom: 1px; transition: color .15s ease, opacity .15s ease;
}

.art-prose a:not(.btn):hover { color: var(--red-dark); opacity: .85; }

.art-prose h2 {
  font-size: clamp(25px, 2.5vw, 32px); line-height: 1.18; letter-spacing: -0.02em;
  margin: 56px 0 8px;
}

.art-prose h2 + .art-rule {
  width: 54px; height: 3px; border-radius: 3px; background: var(--terracotta-deep);
  margin: 0 0 22px;
}

.art-prose h3 {
  font-size: 20px; line-height: 1.3; letter-spacing: -0.01em;
  margin: 36px 0 12px; color: var(--ink);
}

.art-prose h3 .num {
  color: var(--terracotta-deep); margin-right: 10px; font-weight: 600;
}

/* lead summary callout */
.art-summary {
  background: var(--cream-2); border: 1px solid var(--line);
  border-radius: 16px; padding: 26px 30px; margin: 4px 0 38px;
}

.art-summary h2 {
  font-size: 15px; font-weight: 600; letter-spacing: .02em; color: var(--terracotta-deep);
  margin: 0 0 10px; display: inline-flex; align-items: center; gap: 9px;
}

.art-summary h2 svg { color: var(--terracotta-deep); }

.art-summary p {
  font-size: 16px; line-height: 1.7; color: var(--ink-soft); font-weight: 400; margin: 0;
}

/* pull quote — centered, no left-border accent */
.art-quote {
  text-align: center; max-width: 30ch; margin: 46px auto; padding: 0 10px;
}

.art-quote .mark {
  font-size: 64px; line-height: .5; color: var(--terracotta);
  font-weight: 700; display: block; margin-bottom: 18px; height: 30px;
}

.art-quote p {
  font-size: clamp(21px, 2.4vw, 27px); line-height: 1.4; letter-spacing: -0.02em;
  color: var(--ink); font-weight: 600;
}

/* divider */
.art-divider { height: 1px; background: var(--line); margin: 50px 0; border: none; }

/* end contact CTA box */
.art-cta {
  background: var(--cream); border: 1px solid var(--line); border-radius: 18px;
  padding: 36px 38px; margin: 48px 0 0; text-align: center;
}

.art-cta h3 { font-size: 23px; margin-bottom: 10px; }

.art-cta p { font-size: 15.5px; color: var(--ink-soft); font-weight: 400; line-height: 1.65; max-width: 52ch; margin: 0 auto 22px; }

/* back to blog */
.art-back { display: flex; justify-content: center; margin-top: 44px; }

.art-prose .art-back a {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 14.5px; font-weight: 600; color: var(--ink);
  padding: 12px 22px; border-radius: 999px; border: 1px solid var(--line);
  background: var(--paper); background-image: none;
  transition: border-color .16s ease, color .16s ease, transform .16s ease;
}

.art-prose .art-back a svg { transition: transform .18s ease; }

.art-prose .art-back a:hover { border-color: var(--terracotta-deep); color: var(--terracotta-deep); opacity: 1; transform: translateY(-1px); }

.art-prose .art-back a:hover svg { transform: translateX(-3px); }

@media (prefers-reduced-motion: reduce){ .art-prose .art-back a:hover { transform: none; } }

@media (max-width: 560px){
  .art-summary, .art-cta { padding: 24px 22px; }
  .art-body { padding: 56px 0 70px; }
}

/* ============================================================
   RELATED ARTICLES
   ============================================================ */
.art-related { background: var(--cream); }

.art-related .wrap { max-width: 1180px; }

.art-related-head {
  display: flex; align-items: center; gap: 14px; margin-bottom: 30px;
}

.art-related-head h2 { font-size: clamp(24px, 2.6vw, 32px); }

.art-related-head .rule { flex: 1; height: 1px; background: var(--line); }

.art-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }

@media (max-width: 920px){ .art-related-grid { grid-template-columns: 1fr 1fr; } }

@media (max-width: 560px){ .art-related-grid { grid-template-columns: 1fr; } }
