/*
Theme Name: Barrall Consulting
Theme URI: https://barrall.com
Author: Barrall Consulting
Description: Custom block theme implementing the Barrall Consulting design system — warm-neutral canvas, clay accent, Schibsted/Hanken/JetBrains type. Operator, not advisor.
Version: 1.1.0
Requires at least: 6.5
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: barrall
*/

/* =========================================================================
   1. DESIGN TOKENS  (mirrors tokens/*.css from the design system)
   ========================================================================= */
:root {
  /* Warm neutrals (surfaces) */
  --ivory:#FBF7F0; --cream:#F4ECDF; --sand:#EADDC9; --linen:#E1D2B9; --taupe:#C7B393;
  /* Warm ink */
  --ink-900:#211C17; --ink-800:#2E2820; --ink-700:#3F372D; --ink-600:#564C40;
  --ink-500:#6E6253; --ink-400:#8C7E6C; --ink-300:#AC9F8C;
  /* Clay accent */
  --clay-700:#9C4226; --clay-600:#B24A2A; --clay-500:#C75A37; --clay-400:#D9774F;
  --clay-200:#EFC9B5; --clay-100:#F6E1D6;
  /* Honey + Evergreen */
  --honey-600:#C5872D; --honey-500:#DA9B3B; --honey-200:#F0DCB0; --honey-100:#F7ECD4;
  --forest-600:#3C6F52; --forest-500:#4C8266; --forest-100:#DCEAE0;
  --white:#FFFFFF; --black:#14110D;
  /* Semantic status */
  --success:#3C7D5A; --success-bg:#DDEBE0; --warning:#BF8526; --warning-bg:#F6E8CE;
  --danger:#B5402F; --danger-bg:#F3DBD3; --info:#3E6E8E; --info-bg:#DCE7ED;
  /* Semantic aliases */
  --surface-page:var(--ivory); --surface-raised:var(--cream); --surface-card:var(--white);
  --surface-sunken:var(--sand); --surface-inverse:var(--ink-900);
  --text-strong:var(--ink-900); --text-body:var(--ink-700); --text-secondary:var(--ink-500);
  --text-muted:var(--ink-400); --text-inverse:var(--ivory); --text-accent:var(--clay-600);
  --text-on-accent:#FFF6F1;
  --border-subtle:#E7DAC6; --border-default:#D8C6AB; --border-strong:#BCA585;
  --ring-focus:rgba(199,90,55,.38); --link:var(--clay-600); --link-hover:var(--clay-700);

  /* Typography */
  --font-display:"Schibsted Grotesk","Hanken Grotesk",system-ui,sans-serif;
  --font-text:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --weight-regular:400; --weight-medium:500; --weight-semibold:600; --weight-bold:700; --weight-display:800;
  --text-xs:.75rem; --text-sm:.875rem; --text-base:1rem; --text-md:1.0625rem; --text-lg:1.25rem;
  --text-xl:1.5rem; --text-2xl:1.875rem; --text-3xl:2.375rem;
  --text-4xl:clamp(2.75rem,4.8vw,3.75rem); --text-5xl:clamp(3.25rem,6vw,5rem);
  --leading-tight:1.05; --leading-snug:1.18; --leading-normal:1.35; --leading-relaxed:1.62;
  --tracking-tight:-0.02em; --tracking-snug:-0.011em; --tracking-caps:0.13em;
  --type-hero:var(--weight-display) var(--text-5xl)/var(--leading-tight) var(--font-display);
  --type-display:var(--weight-bold) var(--text-4xl)/var(--leading-tight) var(--font-display);
  --type-h1:var(--weight-bold) var(--text-3xl)/var(--leading-snug) var(--font-display);
  --type-h2:var(--weight-semibold) var(--text-2xl)/var(--leading-snug) var(--font-display);
  --type-h3:var(--weight-semibold) var(--text-xl)/var(--leading-snug) var(--font-display);
  --type-lead:var(--weight-regular) var(--text-lg)/var(--leading-relaxed) var(--font-text);
  --type-body:var(--weight-regular) var(--text-md)/var(--leading-relaxed) var(--font-text);
  --type-ui:var(--weight-medium) var(--text-sm)/var(--leading-normal) var(--font-text);
  --type-caption:var(--weight-medium) var(--text-xs)/var(--leading-normal) var(--font-text);

  /* Spacing / radii / layout */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem; --space-5:1.5rem;
  --space-6:2rem; --space-7:2.5rem; --space-8:3rem; --space-9:4rem; --space-10:5rem;
  --space-11:7rem; --space-12:9rem;
  --radius-xs:4px; --radius-sm:8px; --radius-md:12px; --radius-lg:18px; --radius-xl:26px;
  --radius-2xl:36px; --radius-pill:999px;
  --container-lg:75rem; --gutter:clamp(1.25rem,.5rem + 3vw,3.5rem);
  --control-h-sm:34px; --control-h-md:42px; --control-h-lg:52px;

  /* Elevation */
  --shadow-xs:0 1px 2px rgba(56,42,26,.06); --shadow-sm:0 2px 6px rgba(56,42,26,.07);
  --shadow-md:0 6px 18px -4px rgba(56,42,26,.12); --shadow-lg:0 18px 40px -14px rgba(56,42,26,.20);
  --shadow-card:0 1px 2px rgba(56,42,26,.05),0 8px 24px -12px rgba(56,42,26,.16);
  --shadow-card-hover:0 2px 4px rgba(56,42,26,.06),0 18px 38px -14px rgba(56,42,26,.22);
  --focus-ring:0 0 0 3px var(--ring-focus);

  /* Motion */
  --ease-standard:cubic-bezier(0.32,0.08,0.24,1);
  --dur-fast:120ms; --dur-base:200ms;
  --t-color:color var(--dur-fast) var(--ease-standard),background-color var(--dur-fast) var(--ease-standard),border-color var(--dur-fast) var(--ease-standard);
  --t-lift:transform var(--dur-base) var(--ease-standard),box-shadow var(--dur-base) var(--ease-standard);
}
@media (prefers-reduced-motion: reduce){ :root{ --dur-fast:0ms; --dur-base:0ms; } }

/* =========================================================================
   2. BASE
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
body.wp-site-blocks,body{ margin:0; font:var(--type-body); color:var(--text-body); background:var(--surface-page); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
h1,h2,h3,h4{ margin:0; color:var(--text-strong); letter-spacing:var(--tracking-tight); text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }
a{ color:var(--link); text-decoration:none; transition:var(--t-color); }
a:hover{ color:var(--link-hover); }
img{ max-width:100%; display:block; }
::selection{ background:var(--clay-200); color:var(--ink-900); }
:focus-visible{ outline:2px solid var(--clay-500); outline-offset:2px; border-radius:var(--radius-xs); }

.bc-wrap{ width:100%; max-width:var(--container-lg); margin:0 auto; padding:0 var(--gutter); }
.bc-eyebrow{ font:var(--type-caption); text-transform:uppercase; letter-spacing:var(--tracking-caps); color:var(--text-accent); }
.bc-mono{ font-family:var(--font-mono); }

/* =========================================================================
   3. BUTTONS
   ========================================================================= */
.bc-btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font:var(--weight-semibold) var(--text-base)/1 var(--font-text); letter-spacing:.005em;
  height:var(--control-h-md); padding:0 20px; border:1px solid transparent; border-radius:var(--radius-md);
  cursor:pointer; white-space:nowrap; text-decoration:none; transition:var(--t-color),var(--t-lift); }
.bc-btn svg{ width:18px; height:18px; }
.bc-btn--sm{ height:var(--control-h-sm); padding:0 14px; gap:7px; border-radius:var(--radius-sm); font-size:var(--text-sm); }
.bc-btn--sm svg{ width:15px; height:15px; }
.bc-btn--lg{ height:var(--control-h-lg); padding:0 28px; gap:10px; border-radius:var(--radius-lg); font-size:var(--text-lg); }
.bc-btn--full{ width:100%; }
.bc-btn--primary{ background:var(--clay-500); color:var(--text-on-accent); box-shadow:var(--shadow-sm); }
.bc-btn--primary:hover{ background:var(--clay-400); color:var(--text-on-accent); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.bc-btn--primary:active{ background:var(--clay-600); transform:translateY(0) scale(.985); }
.bc-btn--secondary{ background:var(--surface-card); color:var(--text-strong); border-color:var(--border-strong); box-shadow:var(--shadow-xs); }
.bc-btn--secondary:hover{ background:var(--cream); border-color:var(--ink-700); color:var(--text-strong); transform:translateY(-2px); }
.bc-btn--secondary:active{ background:var(--sand); transform:translateY(0) scale(.985); }
.bc-btn--ghost{ background:transparent; color:var(--text-accent); }
.bc-btn--ghost:hover{ background:var(--clay-100); color:var(--text-accent); }
.bc-btn--inverse{ background:var(--ivory); color:var(--ink-900); box-shadow:var(--shadow-md); }
.bc-btn--inverse:hover{ background:#fff; color:var(--ink-900); transform:translateY(-2px); }

/* =========================================================================
   4. CARD / BADGE / TAG / STAT
   ========================================================================= */
.bc-card{ position:relative; background:var(--surface-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg); padding:var(--space-6); box-shadow:var(--shadow-card);
  transition:var(--t-lift); overflow:hidden; }
.bc-card--interactive{ cursor:pointer; }
.bc-card--interactive:hover{ box-shadow:var(--shadow-card-hover); transform:translateY(-2px); }
.bc-card--accent::before{ content:""; position:absolute; inset-inline-start:0; top:0; width:100%; height:3px; background:var(--clay-500); }
.bc-card--outline{ outline:2px solid var(--clay-500); }

.bc-badge{ display:inline-flex; align-items:center; gap:5px; padding:3px 10px;
  font:var(--weight-semibold) var(--text-xs)/1.4 var(--font-text); letter-spacing:.02em;
  border-radius:var(--radius-pill); white-space:nowrap; }
.bc-badge--clay-soft{ background:var(--clay-100); color:var(--clay-700); }
.bc-badge--clay-solid{ background:var(--clay-500); color:var(--text-on-accent); }

.bc-tag{ display:inline-flex; align-items:center; gap:7px; padding:5px 12px;
  font:var(--weight-medium) var(--text-sm)/1 var(--font-text); color:var(--text-body);
  background:var(--surface-card); border:1px solid var(--border-default); border-radius:var(--radius-pill); }
.bc-tag svg{ width:14px; height:14px; }

.bc-stat__value{ display:block; font:var(--weight-medium) clamp(2.25rem,1.4rem + 2.6vw,3.25rem)/.95 var(--font-mono);
  color:var(--text-strong); letter-spacing:-.03em; }
.bc-stat__label{ display:block; margin-top:6px; font:var(--weight-semibold) var(--text-base)/1.3 var(--font-text); color:var(--text-body); }
.bc-stat__sub{ display:block; margin-top:4px; font:var(--weight-regular) var(--text-sm)/1.4 var(--font-text); color:var(--text-muted); }

/* =========================================================================
   5. HEADER
   ========================================================================= */
.bc-header{ position:sticky; top:0; z-index:50; background:color-mix(in srgb,var(--ivory) 86%,transparent);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px); border-bottom:1px solid var(--border-subtle); }
.bc-header__inner{ height:76px; display:flex; align-items:center; justify-content:space-between; gap:var(--space-5); }
.bc-logo{ display:inline-flex; align-items:center; }
.bc-logo svg{ height:38px; width:auto; display:block; }
.bc-nav{ display:flex; align-items:center; gap:var(--space-6); }
.bc-nav__links{ display:flex; align-items:center; gap:var(--space-6); }
.bc-nav__links a{ font:var(--type-ui); color:var(--text-secondary); padding-bottom:2px; border-bottom:2px solid transparent; }
.bc-nav__links a:hover{ color:var(--text-strong); }
.bc-nav__links a.is-active{ color:var(--text-strong); border-bottom-color:var(--clay-500); }
body.home .bc-nav__links a[data-nav="about"],
body.page-template-advisory .bc-nav__links a[data-nav="advisory"]{ color:var(--text-strong); border-bottom-color:var(--clay-500); }

/* =========================================================================
   6. SECTIONS — HOME
   ========================================================================= */
.bc-hero{ padding-top:var(--space-10); padding-bottom:var(--space-9); display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,0.62fr); gap:var(--space-9); align-items:center; }
.bc-hero > *{ min-width:0; }
.bc-hero__text{ display:flex; flex-direction:column; gap:var(--space-5); }
.bc-hero__text h1{ font:var(--type-hero); }
.bc-hero__lead{ font:var(--type-lead); color:var(--text-secondary); max-width:36ch; }
.bc-hero__cta{ display:flex; gap:var(--space-3); margin-top:var(--space-2); flex-wrap:wrap; }
.bc-hero__tags{ display:flex; gap:var(--space-3); margin-top:var(--space-3); flex-wrap:wrap; }
.bc-hero__media{ position:relative; }
.bc-portrait{ aspect-ratio:4/5; max-width:420px; margin-inline:auto; border-radius:var(--radius-2xl); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--border-subtle); }
.bc-portrait img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; }
.bc-portrait-card{ position:absolute; bottom:-18px; left:-18px; display:flex; align-items:center;
  gap:var(--space-3); background:var(--surface-card); border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg); padding:var(--space-4); box-shadow:var(--shadow-card); }
.bc-dot{ width:9px; height:9px; border-radius:50%; background:var(--success); flex:none; }
.bc-portrait-card span:last-child{ font:var(--type-ui); color:var(--text-body); }

.bc-proof{ border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); background:var(--surface-raised); }
.bc-proof__inner{ padding-top:var(--space-5); padding-bottom:var(--space-5); display:flex; align-items:center;
  gap:var(--space-6); flex-wrap:wrap; justify-content:space-between; }
.bc-proof__label{ font:var(--type-caption); text-transform:uppercase; letter-spacing:var(--tracking-caps); color:var(--text-muted); white-space:nowrap; }
.bc-proof__names{ display:flex; gap:var(--space-6); flex-wrap:wrap; align-items:center; }
.bc-proof__names span{ font:var(--weight-bold) var(--text-lg)/1 var(--font-display); color:var(--ink-400); letter-spacing:-.01em; }

.bc-track{ padding-top:var(--space-10); padding-bottom:var(--space-10); }
.bc-track__head{ display:flex; flex-direction:column; gap:var(--space-3); margin-bottom:var(--space-7); max-width:52ch; }
.bc-track__head h2{ font:var(--type-display); }
.bc-track__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-6); }
.bc-track__item{ padding-top:var(--space-4); border-top:2px solid var(--clay-500); }

.bc-writing{ background:var(--surface-raised); border-top:1px solid var(--border-subtle); }
.bc-writing__inner{ padding-top:var(--space-10); padding-bottom:var(--space-10); }
.bc-writing__head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:var(--space-7); gap:var(--space-5); flex-wrap:wrap; }
.bc-writing__head h2{ font:var(--type-display); }
.bc-writing__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
.bc-writing__grid .bc-card{ display:flex; flex-direction:column; gap:var(--space-4); }
.bc-writing__grid h3{ font:var(--type-h3); color:var(--text-strong); }
.bc-writing__meta{ margin-top:auto; display:flex; gap:var(--space-3); font:var(--type-caption); color:var(--text-muted); }

/* =========================================================================
   7. SECTIONS — ADVISORY
   ========================================================================= */
.bc-ahero{ padding-top:var(--space-10); padding-bottom:var(--space-8); max-width:60rem; }
.bc-ahero__in{ display:flex; flex-direction:column; gap:var(--space-4); }
.bc-ahero h1{ font:var(--type-display); }
.bc-ahero__lead{ font:var(--type-lead); color:var(--text-secondary); max-width:58ch; }

.bc-engagements{ padding-bottom:var(--space-10); }
.bc-engagements__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); align-items:stretch; }
.bc-eng{ display:flex; flex-direction:column; gap:var(--space-4); padding:var(--space-6); }
.bc-eng__top{ display:flex; justify-content:space-between; align-items:flex-start; }
.bc-eng__chip{ display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px;
  border-radius:var(--radius-md); background:var(--clay-100); color:var(--clay-600); }
.bc-eng__chip svg{ width:22px; height:22px; }
.bc-eng__name{ font:var(--type-h3); color:var(--text-strong); }
.bc-eng__price{ display:block; margin-top:var(--space-1); font:var(--weight-medium) var(--text-base)/1 var(--font-mono); color:var(--text-accent); }
.bc-eng__desc{ font:var(--type-body); color:var(--text-secondary); }
.bc-eng__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:var(--space-2); margin-top:auto; }
.bc-eng__list li{ display:flex; gap:var(--space-2); align-items:center; font:var(--type-ui); color:var(--text-body); }
.bc-eng__list svg{ width:16px; height:16px; color:var(--success); flex:none; }

.bc-how{ background:var(--surface-raised); border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); }
.bc-how__inner{ padding-top:var(--space-10); padding-bottom:var(--space-10); }
.bc-how h2{ font:var(--type-display); margin-bottom:var(--space-7); }
.bc-how .bc-eyebrow{ margin-bottom:var(--space-3); display:block; }
.bc-how__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-6); }
.bc-how__step{ display:flex; flex-direction:column; gap:var(--space-3); }
.bc-how__n{ font:var(--weight-medium) var(--text-2xl)/1 var(--font-mono); color:var(--clay-500); }
.bc-how__step h3{ font:var(--type-h3); color:var(--text-strong); }
.bc-how__step p{ font:var(--type-body); color:var(--text-secondary); }

.bc-contact{ padding-top:var(--space-10); padding-bottom:var(--space-11); }
.bc-contact__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:var(--space-9); align-items:start; }
.bc-contact__intro{ display:flex; flex-direction:column; gap:var(--space-4); }
.bc-contact__intro h2{ font:var(--type-display); }
.bc-contact__lead{ font:var(--type-lead); color:var(--text-secondary); }
.bc-contact__details{ display:flex; flex-direction:column; gap:var(--space-3); margin-top:var(--space-2); }
.bc-contact__details a,.bc-contact__details div{ display:flex; align-items:center; gap:var(--space-3); color:var(--text-body); font:var(--type-ui); }
.bc-contact__details svg{ width:18px; height:18px; color:var(--clay-500); flex:none; }

/* Form */
.bc-form{ display:flex; flex-direction:column; gap:var(--space-5); }
.bc-form__row{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); }
.bc-field{ display:flex; flex-direction:column; gap:6px; }
.bc-field label{ font:var(--weight-semibold) var(--text-sm)/1.3 var(--font-text); color:var(--text-body); }
.bc-input,.bc-select,.bc-textarea{ width:100%; font:var(--type-body); color:var(--text-strong);
  background:var(--surface-card); border:1px solid var(--border-default); border-radius:var(--radius-md);
  padding:0 14px; height:var(--control-h-md); transition:var(--t-color); }
.bc-textarea{ height:auto; min-height:118px; padding:10px 14px; resize:vertical; font-family:var(--font-text); }
.bc-input:focus,.bc-select:focus,.bc-textarea:focus{ outline:none; border-color:var(--clay-500); box-shadow:var(--focus-ring); }
.bc-check{ display:flex; gap:var(--space-2); align-items:center; font:var(--type-ui); color:var(--text-body); }
.bc-check input{ width:18px; height:18px; accent-color:var(--clay-500); }
.bc-success{ display:flex; flex-direction:column; gap:var(--space-3); align-items:flex-start; padding:var(--space-4) 0; }
.bc-success__icon{ display:inline-flex; width:48px; height:48px; align-items:center; justify-content:center;
  border-radius:var(--radius-pill); background:var(--success-bg); color:var(--success); }
.bc-success h3{ font:var(--type-h3); }
.bc-success p{ font:var(--type-body); color:var(--text-secondary); }

/* =========================================================================
   8. FOOTER
   ========================================================================= */
.bc-footer{ background:var(--ink-900); color:var(--text-inverse); }
.bc-footer__top{ padding-top:var(--space-9); padding-bottom:var(--space-7); display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:var(--space-7); }
.bc-footer__brand{ display:flex; flex-direction:column; gap:var(--space-4); }
.bc-footer__brand svg{ height:40px; width:auto; }
.bc-footer__brand p{ font:var(--type-body); color:rgba(251,247,240,.66); max-width:36ch; }
.bc-footer__col{ display:flex; flex-direction:column; gap:var(--space-3); }
.bc-footer__col .bc-eyebrow,.bc-footer__col-label{ font:var(--type-caption); text-transform:uppercase; letter-spacing:var(--tracking-caps); color:rgba(251,247,240,.5); }
.bc-footer__col a{ font:var(--type-ui); color:rgba(251,247,240,.82); }
.bc-footer__col a:hover{ color:#fff; }
.bc-footer__bottom{ padding-bottom:var(--space-6); display:flex; justify-content:space-between; gap:var(--space-4);
  font:var(--type-caption); color:rgba(251,247,240,.45); border-top:1px solid rgba(255,255,255,.08); padding-top:var(--space-5); }

/* =========================================================================
   9. GENERIC PAGE (Desktop Quote, Privacy, etc.)
   ========================================================================= */
.bc-page{ padding-top:var(--space-9); padding-bottom:var(--space-10); max-width:60rem; }
.bc-page h1.wp-block-post-title{ font:var(--type-display); margin-bottom:var(--space-6); }
.bc-page .entry-content > *{ margin-top:var(--space-4); }
.bc-page .entry-content h2{ font:var(--type-h2); margin-top:var(--space-7); }
.bc-page .entry-content h3{ font:var(--type-h3); margin-top:var(--space-5); }
.bc-page .entry-content ul{ padding-left:1.2em; }
.bc-page .entry-content img{ border-radius:var(--radius-lg); }
.bc-page .entry-content a{ color:var(--link); text-decoration:underline; text-underline-offset:2px; }

/* =========================================================================
   10. RESPONSIVE
   ========================================================================= */
@media (max-width:900px){
  .bc-hero{ grid-template-columns:1fr; gap:var(--space-7); }
  .bc-track__grid{ grid-template-columns:repeat(2,1fr); }
  .bc-writing__grid,.bc-engagements__grid,.bc-how__grid{ grid-template-columns:1fr; }
  .bc-contact__grid{ grid-template-columns:1fr; gap:var(--space-7); }
  .bc-footer__top{ grid-template-columns:1fr 1fr; }
  .bc-nav__links{ display:none; }
}
@media (max-width:560px){
  .bc-track__grid{ grid-template-columns:1fr; }
  .bc-form__row{ grid-template-columns:1fr; }
  .bc-footer__top{ grid-template-columns:1fr; }
  .bc-footer__bottom{ flex-direction:column; gap:var(--space-2); }
}

/* =========================================================================
   11. CORE BLOCK ADJUSTMENTS (editable page content)
   ========================================================================= */
/* Core button blocks → brand buttons */
.wp-block-button__link{ font:var(--weight-semibold) var(--text-base)/1 var(--font-text); letter-spacing:.005em;
  border-radius:var(--radius-md); padding:0 20px; min-height:var(--control-h-md); display:inline-flex;
  align-items:center; justify-content:center; box-shadow:var(--shadow-sm); transition:var(--t-color),var(--t-lift); }
.wp-block-button__link:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.bc-hero__text .wp-block-button__link{ min-height:var(--control-h-lg); padding:0 28px; border-radius:var(--radius-lg); font-size:var(--text-lg); }
.wp-block-button.is-style-outline > .wp-block-button__link{ background:var(--surface-card); color:var(--text-strong);
  border:1px solid var(--border-strong); box-shadow:var(--shadow-xs); }
.wp-block-button.is-style-outline > .wp-block-button__link:hover{ background:var(--cream); border-color:var(--ink-700); }

/* Engagement card: pin CTA to the bottom, full width */
.bc-eng .wp-block-buttons{ margin-top:auto; width:100%; }
.bc-eng .wp-block-button{ width:100%; }
.bc-eng .wp-block-button__link{ width:100%; }

/* Engagement checklist as an editable core list, with check marks */
.bc-eng__list{ list-style:none; margin-top:0; padding-left:0; }
.bc-eng__list li{ position:relative; padding-left:26px; display:block; }
.bc-eng__list li::before{ content:""; position:absolute; left:0; top:.18em; width:16px; height:16px;
  background-repeat:no-repeat; background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233C7D5A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); }

/* Core heading/paragraph spacing inside our layout groups is handled by flex/grid gap */
.bc-hero__text > *, .bc-track__head > *, .bc-ahero__in > *, .bc-contact__intro > *{ margin-block:0; }
.wp-block-group.bc-wrap{ margin-left:auto; margin-right:auto; }

/* Card inner blocks (writing + engagements) */
.bc-card > .bc-badge{ align-self:flex-start; }
.bc-writing__grid .bc-card .bc-writing__meta{ margin-top:auto; }
.bc-eng__title{ display:flex; flex-direction:column; gap:var(--space-1); }
.bc-eng__head{ display:flex; justify-content:space-between; align-items:flex-start; gap:var(--space-3); }

/* =========================================================================
   12. v1.1.0 — NATIVE COLUMNS LAYOUT (editor-safe; replaces CSS-grid sections)
   ========================================================================= */
.bc-hero{ display:block; }
.bc-hero__cols{ align-items:center; gap:var(--space-9); margin-block:0; }
.bc-track .wp-block-columns{ gap:var(--space-6); margin-block:0; }
.bc-writing__inner .wp-block-columns{ gap:var(--space-5); margin-block:0; }
.bc-engagements .wp-block-columns{ gap:var(--space-5); align-items:stretch; margin-block:0; }
.bc-how__inner .wp-block-columns{ gap:var(--space-6); margin-block:0; }
.bc-contact .wp-block-columns{ gap:var(--space-9); margin-block:0; }

/* Cards lay their contents out vertically */
.bc-card{ display:flex; flex-direction:column; gap:var(--space-4); }
.bc-card .bc-writing__meta{ margin-top:auto; }

/* Make column children fill the column so cards/stats are equal height */
.bc-engagements .wp-block-column,
.bc-track .wp-block-column,
.bc-writing__inner .wp-block-column{ display:flex; }
.bc-engagements .wp-block-column > .bc-eng,
.bc-track .wp-block-column > .bc-track__item,
.bc-writing__inner .wp-block-column > .bc-card{ width:100%; }

/* Control vertical rhythm ourselves (zero core's injected flow gap on these wrappers) */
.bc-track > *, .bc-writing__inner > *, .bc-how__inner > *{ margin-block-start:0; }
