.cta-band::before {
  content: ""; position: absolute; inset: -2%; z-index: 0;
  background: url(../../img/bg/6abbe8c0-2342-4012-bffc-e86cadb0ad1c.jpg) center 32% / cover no-repeat;
  transform-origin: 68% 34%;
  animation: ctaZoom 26s ease-in-out infinite alternate;
  will-change: transform;
}

/* ============================================================
   COFFEE LADY — About page
   Editorial overhaul. Builds on jura.css (palette, nav, footer,
   buttons, cta-band, quote drawer). Self-contained section styles.
   ============================================================ */

/* ---------- shared section heading ---------- */
.ab-h2 { font-size: clamp(28px, 3.4vw, 44px); }

/* ============================================================
   HERO — full-bleed photo, centred copy (matches home)
   ============================================================ */
.ab-hero {
  position: relative; overflow: hidden; color: var(--brand-text);
  display: grid; place-items: center; text-align: center;
  background:
    radial-gradient(110% 80% at 78% 6%, rgba(191,56,38,.26), transparent 55%),
    radial-gradient(90% 80% at 10% 100%, rgba(207,106,67,.20), transparent 60%),
    linear-gradient(180deg, var(--brand-bg-2), var(--brand-bg));
}

.ab-hero .hero-photo { position: absolute; inset: 0; z-index: 0; overflow: hidden; }

.ab-hero .hero-photo img {
  width: 100%; height: 100%; object-fit: cover;
  object-position: 64% 22%;
  transform-origin: 64% 22%;
  animation: abHeroZoom 26s ease-in-out infinite alternate;
  will-change: transform;
}

@keyframes abHeroZoom { from { transform: scale(1); } to { transform: scale(1.12); } }

@media (prefers-reduced-motion: reduce){ .ab-hero .hero-photo img { animation: none; } }

.ab-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(22,17,15,.42), rgba(22,17,15,.56)),
    linear-gradient(110deg, rgba(135,29,21,.24), rgba(194,94,56,.10));
}

.ab-hero .wrap { position: relative; z-index: 2; max-width: 1600px; padding: 116px 48px 104px; }

.ab-hero h1 {
  color: #fff; font-size: clamp(36px, 5.2vw, 64px); line-height: 1.05;
  letter-spacing: -0.03em; margin-bottom: 22px;
}

.ab-hero h1 em { font-style: normal; color: var(--terracotta-soft); }

.ab-hero-sub {
  font-size: clamp(16px, 1.55vw, 19px); color: var(--brand-muted);
  max-width: 60ch; margin: 0 auto 30px; font-weight: 400; line-height: 1.65;
}

.ab-hero-cta { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-bottom: 0; }

.ab-hero-meta {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 12px;
  margin-bottom: 34px;
  font-size: 13.5px; color: var(--brand-text); font-weight: 600;
}

.ab-hero-meta > span {
  display: inline-flex; align-items: center; gap: 9px;
  background: rgba(255,255,255,.06); border: 1px solid var(--brand-line);
  padding: 9px 16px; border-radius: 999px; backdrop-filter: blur(6px); white-space: nowrap;
}

.ab-hero-meta .tick {
  width: 18px; height: 18px; flex-shrink: 0; border-radius: 50%;
  background: rgba(226,165,131,.16); border: 1px solid rgba(226,165,131,.4);
  color: var(--terracotta-soft); display: grid; place-items: center;
}

@media (min-width: 921px){ .ab-hero { min-height: 747px; } }

@media (max-width: 700px){ .ab-hero .wrap { padding: 84px 22px 76px; } }

@media (max-width: 640px){ .ab-hero .wrap { padding: 76px 20px 66px; } }

/* breadcrumb over the hero photo (no bar) */
.ab-hero .hero-crumb { position: absolute; top: 0; left: 0; right: 0; z-index: 3; }

.ab-hero .hero-crumb .wrap { max-width: 1600px; padding: 20px 48px 0; text-align: left; }

.ab-hero .hero-crumb .breadcrumb {
  display: flex; align-items: center; gap: 9px; flex-wrap: wrap;
  font-size: 13px; font-weight: 500; color: rgba(255,255,255,.72);
}

.ab-hero .hero-crumb .breadcrumb a { color: rgba(255,255,255,.72); }

.ab-hero .hero-crumb .breadcrumb a:hover { color: #fff; }

.ab-hero .hero-crumb .breadcrumb .sep { opacity: .5; }

.ab-hero .hero-crumb .breadcrumb .here { color: #fff; font-weight: 600; }

@media (max-width: 700px){ .ab-hero .hero-crumb .wrap { padding: 16px 22px 0; } }

/* ============================================================
   STATS — Why Choose Coffee Lady?
   ============================================================ */
.ab-stats { background: var(--paper); }

.ab-stats-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 28px; flex-wrap: wrap; margin-bottom: 40px;
}

.ab-stats-head p { font-size: 15px; color: var(--ink-soft); font-weight: 400; max-width: 42ch; }

.ab-stat-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden;
}

.ab-stat { padding: 34px 30px; border-right: 1px solid var(--line); }

.ab-stat:last-child { border-right: none; }

.ab-stat .num {
  font-size: clamp(40px, 4.6vw, 56px); font-weight: 600; letter-spacing: -0.03em;
  line-height: 1; color: var(--red); margin-bottom: 14px;
}

.ab-stat .num .u { color: var(--red); }

.ab-stat .lbl { font-size: 14px; color: var(--ink-soft); font-weight: 500; line-height: 1.45; }

.ab-trust-note {
  display: flex; align-items: center; gap: 16px; margin-top: 22px;
  padding: 20px 26px; background: var(--terracotta-deep); border: 1px solid var(--terracotta-deep);
  border-radius: var(--radius); font-size: 15px; font-weight: 500; color: #fff;
}

.ab-trust-note .ic {
  width: 44px; height: 44px; flex-shrink: 0; border-radius: 12px;
  background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.3); color: #fff;
  display: grid; place-items: center;
}

@media (max-width: 880px){
  .ab-stat-grid { grid-template-columns: 1fr 1fr; }
  .ab-stat:nth-child(1), .ab-stat:nth-child(2) { border-bottom: 1px solid var(--line); }
  .ab-stat:nth-child(2) { border-right: none; }
}

@media (max-width: 520px){
  .ab-stat-grid { grid-template-columns: 1fr; }
  .ab-stat { border-right: none; border-bottom: 1px solid var(--line); }
  .ab-stat:last-child { border-bottom: none; }
}

/* ============================================================
   APPROACH — editorial, sticky image
   ============================================================ */
.ab-approach { background: var(--cream); }

.ab-approach-grid {
  display: grid; grid-template-columns: .86fr 1.14fr; gap: 58px; align-items: start;
}

.ab-approach-figure { position: sticky; top: 102px; }

.ab-approach-figure .pic {
  border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.ab-approach-figure .pic img { width: 100%; height: 520px; object-fit: cover; display: block; }

.ab-approach-figure .cap {
  margin-top: 16px; display: flex; align-items: center; gap: 12px;
  font-size: 13.5px; color: var(--ink-soft); font-weight: 500;
}

.ab-approach-figure .cap .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--terracotta); flex-shrink: 0; }

.ab-approach-copy h2 { margin-bottom: 22px; max-width: 16ch; }

.ab-approach-copy .intro { font-size: 16.5px; color: var(--ink-soft); font-weight: 400; line-height: 1.7; }

.ab-approach-copy .intro + .intro { margin-top: 16px; }

.ab-block { margin-top: 34px; padding-top: 30px; border-top: 1px solid var(--line); }

.ab-block h3 {
  font-size: 19px; margin-bottom: 12px;
  display: flex; align-items: center; gap: 12px;
}

.ab-block h3 .bi {
  width: 34px; height: 34px; flex-shrink: 0; border-radius: 10px;
  background: #fff; border: 1px solid var(--line); color: var(--red);
  display: grid; place-items: center;
}

.ab-block p { font-size: 15px; color: var(--ink-soft); font-weight: 400; line-height: 1.7; }

.ab-pullquote {
  margin-top: 34px; padding: 26px 30px; border-radius: var(--radius);
  background: var(--ink); color: #fff;
  font-size: clamp(19px, 2vw, 23px); font-weight: 600; letter-spacing: -0.01em; line-height: 1.4;
  position: relative;
}

.ab-pullquote em { font-style: normal; color: var(--terracotta-soft); }

@media (max-width: 880px){
  .ab-approach-grid { grid-template-columns: 1fr; gap: 36px; }
  .ab-approach-figure { position: static; }
  .ab-approach-figure .pic img { height: 380px; }
}

/* ============================================================
   PANELS — How it works / What makes us different
   ============================================================ */
.ab-panels { background: var(--paper); }

.ab-panels-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

.ab-panel {
  border-radius: 20px; padding: 44px 42px; color: #fff;
  display: flex; flex-direction: column;
}

.ab-panel.terra { background: linear-gradient(160deg, var(--terracotta), var(--terracotta-deep)); }

.ab-panel.red { background: linear-gradient(160deg, var(--red), var(--burgundy)); }

.ab-panel h3 { color: #fff; font-size: clamp(24px, 2.6vw, 30px); margin-bottom: 14px; max-width: 16ch; }

.ab-panel .pintro { font-size: 15px; color: rgba(255,255,255,.92); font-weight: 400; line-height: 1.65; margin-bottom: 24px; }

.ab-panel ul { list-style: none; display: flex; flex-direction: column; gap: 2px; margin-top: auto; }

.ab-panel li {
  display: flex; align-items: flex-start; gap: 13px;
  padding: 14px 0; border-top: 1px solid rgba(255,255,255,.18);
  font-size: 15.5px; font-weight: 500; line-height: 1.45;
}

.ab-panel li:last-child { border-bottom: 1px solid rgba(255,255,255,.18); }

.ab-panel li .ck {
  width: 24px; height: 24px; flex-shrink: 0; border-radius: 50%; margin-top: 1px;
  background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.34);
  display: grid; place-items: center; color: #fff;
}

.ab-panel .pfoot { font-size: 14.5px; color: rgba(255,255,255,.9); font-weight: 500; margin-top: 22px; font-style: italic; }

@media (max-width: 860px){
  .ab-panels-grid { grid-template-columns: 1fr; }
  .ab-panel { padding: 38px 32px; }
}

/* ============================================================
   REVIEWS — Google business
   ============================================================ */
.ab-reviews { background: var(--cream-2); }

.ab-reviews-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 56px; align-items: center; }

.ab-reviews-copy .stars { display: inline-flex; gap: 3px; color: #f5b942; margin-bottom: 18px; }

.ab-reviews-copy .stars svg { width: 22px; height: 22px; }

.ab-reviews-copy h2 { margin-bottom: 18px; max-width: 16ch; }

.ab-reviews-copy p { font-size: 16px; color: var(--ink-soft); font-weight: 400; line-height: 1.7; margin-bottom: 28px; max-width: 46ch; }

.ab-review-card {
  background: var(--paper); border: 1px solid var(--line); border-radius: 20px;
  padding: 38px 40px; box-shadow: var(--shadow-soft); position: relative;
}

.ab-review-card .g-badge {
  display: inline-flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600;
  color: var(--ink-soft); margin-bottom: 22px;
}

.ab-review-card .g-badge .g {
  width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center;
  background: #fff; border: 1px solid var(--line); color: #4285F4; font-weight: 700; font-size: 14px;
}

.ab-review-card .r-stars { display: inline-flex; gap: 2px; color: #f5b942; margin-bottom: 16px; }

.ab-review-card .r-stars svg { width: 18px; height: 18px; }

.ab-review-card .r-quote { font-size: 19px; font-weight: 500; color: var(--ink); line-height: 1.55; letter-spacing: -0.01em; margin-bottom: 20px; }

.ab-review-card .r-headline { font-size: 16px; font-weight: 600; color: var(--ink); margin-bottom: 18px; }

.ab-review-card .r-who { display: flex; align-items: center; gap: 13px; padding-top: 20px; border-top: 1px solid var(--line); }

.ab-review-card .r-av {
  width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(150deg, var(--red), var(--terracotta-deep));
  display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 16px;
}

.ab-review-card .r-name { font-size: 15.5px; font-weight: 600; color: var(--ink); }

.ab-review-card .r-role { font-size: 13px; color: var(--ink-faint); font-weight: 500; }

@media (max-width: 860px){
  .ab-reviews-grid { grid-template-columns: 1fr; gap: 34px; }
  .ab-review-card { padding: 32px 28px; }
}

/* ============================================================
   BRANDS — leading brands we work with
   ============================================================ */
.ab-brands { background: var(--paper); }

.ab-brands-head { text-align: center; margin-bottom: 44px; }

.ab-brands-head p { font-size: 15px; color: var(--ink-soft); font-weight: 400; max-width: 56ch; margin: 14px auto 0; }

.ab-brand-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }

@media (max-width: 900px){ .ab-brand-grid { grid-template-columns: repeat(3, 1fr); } }

@media (max-width: 540px){ .ab-brand-grid { grid-template-columns: repeat(2, 1fr); } }

.ab-brand-cell {
  position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 130px; padding: 26px 18px; text-align: center;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm);
  transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.ab-brand-cell:hover { border-color: var(--terracotta); transform: translateY(-3px); box-shadow: var(--shadow-card); }

.ab-brand-cell img {
  max-width: 78%; max-height: 44px; width: auto; height: auto;
  object-fit: contain; display: block; opacity: .88;
  transition: opacity .18s ease, transform .18s ease;
}

.ab-brand-cell:hover img { opacity: 1; transform: translateY(-2px); }

.ab-brand-cell .bt-go {
  position: absolute; left: 0; right: 0; bottom: 13px;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  font-size: 12.5px; font-weight: 600; color: var(--red);
  opacity: 0; transform: translateY(4px);
  transition: opacity .18s ease, transform .18s ease;
}

.ab-brand-cell:hover .bt-go { opacity: 1; transform: none; }

@media (hover: none){ .ab-brand-cell .bt-go { opacity: 1; transform: none; color: var(--ink-faint); } .ab-brand-cell img { opacity: 1; } }

/* reveal-on-scroll (mirrors jura.css) */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }

/* ============================================================
   MOBILE REFINEMENTS
   ============================================================ */
@media (max-width: 860px){
  /* reviews: centre the copy + CTA, fill the width (no right-side gap) */
  .ab-reviews-copy { text-align: center; }
  .ab-reviews-copy h2 { max-width: 100%; margin-left: auto; margin-right: auto; }
  .ab-reviews-copy p { max-width: 52ch; margin-left: auto; margin-right: auto; }
}

@media (max-width: 640px){
  /* tighten vertical rhythm on small screens */
  .section { padding: 60px 0; }
}
