/* Fonts: served by existing TenderBuilt mu-plugin @font-face rules
   (Barlow Semi Condensed + Inter, self-hosted woff2 in /wp-content/uploads/fonts/) */

/* ============================================================
   TenderBuilt — Website
   Built on TenderBuilt Design System v1.0
   ============================================================ */

/* ── Fonts ───────────────────────────────────────────────── */
/* ── Tokens ──────────────────────────────────────────────── */
:root{
  --tb-charcoal: #1C1C1A;
  --tb-charcoal-rgb: 28, 28, 26;
  --tb-charcoal-2: #2D2D2B;
  --tb-charcoal-3: #4A4A45;
  --tb-charcoal-4: #6B6B67;
  --tb-charcoal-5: #B5B2AB;
  --tb-charcoal-6: #D6D2CA;
  --tb-charcoal-7: #ECEAE5;
  --tb-cream: #F0EDE6;
  --tb-cream-rgb: 240, 237, 230;
  --tb-white: #FFFFFF;
  --tb-ochre: #C49A3C;
  --tb-ochre-rgb: 196, 154, 60;
  --tb-ochre-deep: #A37E2E;
  --tb-ochre-tint: #F7ECCC;
  --tb-ochre-10: rgba(196,154,60,0.10);
  --tb-ochre-20: rgba(196,154,60,0.20);
  --tb-success: #2F7D5B;
  --tb-warning: #B5722A;
  --tb-error:   #B0392B;

  --tb-font-display: 'Barlow Semi Condensed', 'Arial Narrow', sans-serif;
  --tb-font-body: 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;

  /* Web type scale (px) */
  --tb-t-eyebrow: 12px;
  --tb-t-body-sm: 14px;
  --tb-t-body:    16px;
  --tb-t-lead:    20px;
  --tb-t-h4:      18px;
  --tb-t-h3:      14px;
  --tb-t-h2:      40px;
  --tb-t-h1:      64px;
  --tb-t-display: 112px;
  --tb-t-mega:    180px;

  /* Spacing */
  --tb-space-1: 4px;
  --tb-space-2: 8px;
  --tb-space-3: 12px;
  --tb-space-4: 16px;
  --tb-space-5: 20px;
  --tb-space-6: 24px;
  --tb-space-8: 32px;
  --tb-space-10: 40px;
  --tb-space-12: 48px;
  --tb-space-16: 64px;
  --tb-space-20: 80px;
  --tb-space-24: 96px;
  --tb-space-32: 128px;

  --tb-container-max: 1320px;
  --tb-container-pad: 40px;

  --tb-tracking-eyebrow: 0.18em;
  --tb-tracking-label: 0.12em;
  --tb-tracking-mega: -0.025em;
}

.tb-page, .tb-page *, .tb-page *::before, .tb-page *::after { box-sizing: border-box; margin: 0; padding: 0; }
html{ scroll-behavior: smooth; }
.tb-page{
  font-family: var(--tb-font-body);
  font-size: var(--tb-t-body);
  line-height: 1.55;
  color: var(--tb-charcoal);
  background: var(--tb-white);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.tb-page a{ color: inherit; text-decoration: none; }
.tb-page img, .tb-page svg{ display: block; max-width: 100%; }
.tb-page button{ font: inherit; cursor: pointer; }

/* ── Layout helpers ─────────────────────────────────────── */
.tb-page .container{
  max-width: var(--tb-container-max);
  margin: 0 auto;
  padding: 0 var(--tb-container-pad);
}
.tb-page .section{
  padding: var(--tb-space-32) 0;
}
.tb-page .section--tight{ padding: var(--tb-space-20) 0; }
.tb-page .section--dark{ background: var(--tb-charcoal); color: var(--tb-cream); }
.tb-page .section--cream{ background: var(--tb-cream); }

/* ── Type primitives ────────────────────────────────────── */
.tb-page .eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: var(--tb-t-eyebrow);
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-ochre);
}
.tb-page .eyebrow--on-light{ color: var(--tb-ochre-deep); }
.tb-page .eyebrow::before{
  content: '';
  display: inline-block;
  width: 28px;
  height: 2px;
  background: currentColor;
}
.tb-page .eyebrow--no-rule::before{ display: none; }

.tb-page .section-num{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: var(--tb-t-eyebrow);
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-ochre);
}
.tb-page .section-num--muted{ color: var(--tb-charcoal-4); }

.tb-page .h-display{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(56px, 9.5vw, 144px);
  line-height: 0.92;
  letter-spacing: -0.02em;
}
.tb-page .h-mega{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(72px, 13vw, 200px);
  line-height: 0.86;
  letter-spacing: -0.03em;
}
.tb-page .h1{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(40px, 5.5vw, 64px);
  line-height: 1.0;
  letter-spacing: -0.015em;
}
.tb-page .h2{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: clamp(28px, 3.4vw, 40px);
  line-height: 1.08;
  letter-spacing: -0.01em;
}
.tb-page .h3{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: var(--tb-t-h3);
  letter-spacing: var(--tb-tracking-label);
  text-transform: uppercase;
  color: var(--tb-charcoal);
}
.tb-page .h3::after{
  content: '';
  display: block;
  width: 28px;
  height: 3px;
  background: var(--tb-ochre);
  margin-top: 10px;
}
.tb-page .h3--inverse{ color: var(--tb-cream); }
.tb-page .h4{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: var(--tb-t-h4);
  letter-spacing: 0.01em;
}
.tb-page .lead{
  font-family: var(--tb-font-body);
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.5;
  font-weight: 400;
  color: var(--tb-charcoal-2);
  max-width: 60ch;
}
.tb-page .lead--inverse{ color: var(--tb-charcoal-5); }
.tb-page .text-muted{ color: var(--tb-charcoal-4); }

.tb-page .ochre{ color: var(--tb-ochre); }
.tb-page .ochre-deep{ color: var(--tb-ochre-deep); }

/* ── Header / nav ───────────────────────────────────────── */
.tb-page .site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--tb-charcoal);
  color: var(--tb-cream);
  border-bottom: 1px solid var(--tb-charcoal-2);
}
.tb-page .site-header__row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 76px;
  gap: var(--tb-space-8);
}
.tb-page .site-header__brand{
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.tb-page .site-header__brand .a{ color: var(--tb-cream); }
.tb-page .site-header__brand .b{ color: var(--tb-ochre); }
.tb-page .site-header__brand .dot{
  display: inline-block;
  width: 6px; height: 6px;
  margin: 0 0 4px 6px;
  background: var(--tb-ochre);
}
.tb-page .site-nav{
  display: flex;
  align-items: center;
  gap: var(--tb-space-8);
  flex-shrink: 1;
  min-width: 0;
}
.tb-page .site-nav a{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tb-charcoal-5);
  padding: 8px 0;
  position: relative;
  transition: color .15s ease;
  white-space: nowrap;
}
.tb-page .site-nav a:hover{ color: var(--tb-cream); }
.tb-page .site-nav a.is-active{ color: var(--tb-cream); }
.tb-page .site-nav a.is-active::after{
  content: '';
  position: absolute;
  left: 0; right: 0;
  bottom: -4px;
  height: 2px;
  background: var(--tb-ochre);
}
.tb-page .site-header__cta{
  display: flex;
  align-items: center;
  gap: var(--tb-space-4);
  flex-shrink: 0;
}
.tb-page .site-header__cta .btn{
  white-space: nowrap;
  flex-shrink: 0;
}
.tb-page .site-header__phone{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.14em;
  color: var(--tb-charcoal-5);
  white-space: nowrap;
  flex-shrink: 0;
}
.tb-page .site-header__phone strong{ color: var(--tb-cream); font-weight: 700; }

/* ── Buttons ─────────────────────────────────────────────── */
.tb-page .btn{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 16px 24px;
  border: 2px solid transparent;
  background: transparent;
  color: var(--tb-charcoal);
  transition: opacity .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  cursor: pointer;
}
.tb-page .btn:hover{ opacity: 0.88; }
.tb-page .btn .arrow{
  display: inline-block;
  width: 20px; height: 2px;
  background: currentColor;
  position: relative;
  transition: transform .15s ease;
}
.tb-page .btn .arrow::after{
  content: '';
  position: absolute;
  right: -1px; top: -4px;
  width: 10px; height: 10px;
  border-right: 2px solid currentColor;
  border-top: 2px solid currentColor;
  transform: rotate(45deg);
  transform-origin: right center;
}
.tb-page .btn:hover .arrow{ transform: translateX(4px); }

.tb-page .btn--ochre{
  background: var(--tb-ochre);
  color: var(--tb-charcoal);
  border-color: var(--tb-ochre);
}
.tb-page .btn--ochre:hover{ background: var(--tb-ochre-deep); border-color: var(--tb-ochre-deep); opacity: 1; }
.tb-page .btn--ghost-light{
  border-color: var(--tb-cream);
  color: var(--tb-cream);
}
.tb-page .btn--ghost-light:hover{ background: var(--tb-cream); color: var(--tb-charcoal); opacity: 1; }
.tb-page .btn--ghost-dark{
  border-color: var(--tb-charcoal);
  color: var(--tb-charcoal);
}
.tb-page .btn--ghost-dark:hover{ background: var(--tb-charcoal); color: var(--tb-cream); opacity: 1; }
.tb-page .btn--link{
  padding: 0;
  border: none;
  background: transparent;
  color: var(--tb-ochre-deep);
}
.tb-page .btn--link:hover{ color: var(--tb-ochre); opacity: 1; }

/* ── Cards / surfaces ───────────────────────────────────── */
.tb-page .card{
  background: var(--tb-white);
  border: 1px solid var(--tb-charcoal-6);
  padding: var(--tb-space-8);
  position: relative;
  transition: border-color .15s ease, transform .15s ease;
}
.tb-page .card--dark{
  background: var(--tb-charcoal-2);
  border-color: var(--tb-charcoal-3);
  color: var(--tb-cream);
}
.tb-page .card--cream{ background: var(--tb-cream); border-color: var(--tb-charcoal-6); }
.tb-page .card__top-rule{
  position: absolute;
  top: -1px; left: -1px;
  width: 56px; height: 4px;
  background: var(--tb-ochre);
}

.tb-page .callout{
  border-left: 4px solid var(--tb-ochre);
  background: var(--tb-cream);
  padding: var(--tb-space-6) var(--tb-space-8);
}
.tb-page .callout__label{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-ochre-deep);
  margin-bottom: 8px;
}

/* ── Lists with ochre squares ───────────────────────────── */
.tb-page .tb-list{ list-style: none; padding: 0; margin: 0; }
.tb-page .tb-list li{
  position: relative;
  padding-left: 22px;
  margin-bottom: 10px;
  line-height: 1.5;
}
.tb-page .tb-list li::before{
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 7px; height: 7px;
  background: var(--tb-ochre);
}

/* ── Tables ─────────────────────────────────────────────── */
.tb-page .tb-table{
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.tb-page .tb-table thead th{
  background: var(--tb-charcoal);
  color: var(--tb-cream);
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-label);
  text-transform: uppercase;
  text-align: left;
  padding: 14px 16px;
  border-bottom: 3px solid var(--tb-ochre);
}
.tb-page .tb-table tbody td{
  padding: 14px 16px;
  border-bottom: 1px solid var(--tb-charcoal-6);
  vertical-align: top;
}
.tb-page .tb-table tbody tr:nth-child(even) td{ background: var(--tb-cream); }

/* ── Footer ─────────────────────────────────────────────── */
.tb-page .site-footer{
  background: var(--tb-charcoal);
  color: var(--tb-charcoal-5);
  padding: var(--tb-space-24) 0 var(--tb-space-8);
}
.tb-page .site-footer .container{ display: block; }
.tb-page .site-footer__grid{
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--tb-space-12);
  align-items: start;
  padding-bottom: var(--tb-space-12);
  border-bottom: 1px solid var(--tb-charcoal-2);
}
.tb-page .site-footer h4{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-ochre);
  margin-bottom: 16px;
}
.tb-page .site-footer ul{ list-style: none; }
.tb-page .site-footer ul li{ margin-bottom: 10px; font-size: 14px; }
.tb-page .site-footer ul a{ color: var(--tb-charcoal-5); transition: color .15s ease; }
.tb-page .site-footer ul a:hover{ color: var(--tb-cream); }
.tb-page .site-footer__brand-block{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 36px;
  letter-spacing: 0.06em;
  margin-bottom: 16px;
}
.tb-page .site-footer__brand-block .a{ color: var(--tb-cream); }
.tb-page .site-footer__brand-block .b{ color: var(--tb-ochre); }
.tb-page .site-footer__bottom{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--tb-space-6);
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
}

/* ── Hero ───────────────────────────────────────────────── */
.tb-page .hero{
  background: var(--tb-charcoal);
  color: var(--tb-cream);
  position: relative;
  overflow: hidden;
}
.tb-page .hero__inner{
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--tb-space-16);
  padding: var(--tb-space-24) 0 var(--tb-space-32);
  align-items: end;
  min-height: 720px;
}
.tb-page .hero__meta{
  display: flex;
  align-items: center;
  gap: var(--tb-space-8);
  padding: 24px 0 0;
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-5);
  border-top: 1px solid var(--tb-charcoal-2);
  margin-bottom: var(--tb-space-16);
}
.tb-page .hero__meta .dot{
  width: 4px; height: 4px;
  background: var(--tb-ochre);
  border-radius: 50%;
}
.tb-page .hero__title{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(56px, 7vw, 104px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: var(--tb-cream);
  margin-bottom: var(--tb-space-10);
}
.tb-page .hero__title .em{ color: var(--tb-ochre); font-style: normal; }
.tb-page .hero__lead{
  font-family: var(--tb-font-body);
  font-size: 20px;
  line-height: 1.5;
  color: var(--tb-charcoal-5);
  max-width: 52ch;
  margin-bottom: var(--tb-space-10);
}
.tb-page .hero__ctas{
  display: flex;
  gap: var(--tb-space-3);
  flex-wrap: wrap;
  margin-bottom: var(--tb-space-12);
}
.tb-page .hero__sidebar{
  display: flex;
  flex-direction: column;
  gap: var(--tb-space-6);
}
.tb-page .hero__photo{
  width: 100%;
  height: 460px;
  background: var(--tb-charcoal-2);
}
.tb-page .hero__photo image-slot{
  width: 100%;
  height: 100%;
}
.tb-page .hero__caption{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-5);
  display: flex;
  justify-content: space-between;
  padding-top: var(--tb-space-3);
  border-top: 1px solid var(--tb-charcoal-2);
}

/* ── Stats bar ──────────────────────────────────────────── */
.tb-page .stats{
  background: var(--tb-cream);
  border-top: 3px solid var(--tb-ochre);
  border-bottom: 1px solid var(--tb-charcoal-6);
}
.tb-page .stats__grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.tb-page .stats__cell{
  padding: var(--tb-space-10) var(--tb-space-8);
  border-right: 1px solid var(--tb-charcoal-6);
}
.tb-page .stats__cell:last-child{ border-right: none; }
.tb-page .stats__num{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(48px, 5.5vw, 72px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--tb-charcoal);
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.tb-page .stats__num .unit{
  font-size: 0.45em;
  color: var(--tb-ochre-deep);
  font-weight: 700;
}
.tb-page .stats__label{
  margin-top: 12px;
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
}

/* ── Section heading patterns ───────────────────────────── */
.tb-page .section-head{
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--tb-space-12);
  margin-bottom: var(--tb-space-16);
  padding-bottom: var(--tb-space-8);
  border-bottom: 1px solid var(--tb-charcoal-6);
  align-items: end;
}
.tb-page .section-head--dark{ border-bottom-color: var(--tb-charcoal-3); }
.tb-page .section-head__num{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(64px, 8vw, 120px);
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--tb-ochre);
}
.tb-page .section-head__num small{
  display: block;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow);
  color: var(--tb-charcoal-4);
  font-weight: 700;
  margin-bottom: 12px;
}
.tb-page .section-head--dark .section-head__num small{ color: var(--tb-charcoal-5); }
.tb-page .section-head__body{
  align-self: end;
  padding-bottom: 8px;
}
.tb-page .section-head__title{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(36px, 4.4vw, 56px);
  line-height: 1.02;
  letter-spacing: -0.015em;
  margin-bottom: var(--tb-space-4);
}
.tb-page .section-head__sub{
  font-size: 18px;
  line-height: 1.5;
  color: var(--tb-charcoal-3);
  max-width: 60ch;
}
.tb-page .section-head--dark .section-head__title{ color: var(--tb-cream); }
.tb-page .section-head--dark .section-head__sub{ color: var(--tb-charcoal-5); }

/* ── Process / How it works ─────────────────────────────── */
.tb-page .process{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--tb-charcoal-6);
}
.tb-page .process__step{
  padding: var(--tb-space-10) var(--tb-space-6) var(--tb-space-10) 0;
  border-right: 1px solid var(--tb-charcoal-6);
  position: relative;
}
.tb-page .process__step:last-child{ border-right: none; }
.tb-page .process__step:not(:last-child){ padding-right: var(--tb-space-8); }
.tb-page .process__step:not(:first-child){ padding-left: var(--tb-space-6); }
.tb-page .process__num{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 14px;
  letter-spacing: var(--tb-tracking-eyebrow);
  color: var(--tb-ochre);
  margin-bottom: var(--tb-space-6);
}
.tb-page .process__title{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 26px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: var(--tb-space-4);
}
.tb-page .process__body{
  font-size: 15px;
  line-height: 1.55;
  color: var(--tb-charcoal-3);
}
.tb-page .process__time{
  margin-top: var(--tb-space-6);
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
}

/* ── Services grid ──────────────────────────────────────── */
.tb-page .services{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--tb-space-6);
}
.tb-page .service{
  background: var(--tb-white);
  border: 1px solid var(--tb-charcoal-6);
  padding: var(--tb-space-10) var(--tb-space-8);
  position: relative;
  transition: background .2s ease, border-color .2s ease;
}
.tb-page .service::before{
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 64px; height: 4px;
  background: var(--tb-ochre);
}
.tb-page .service:hover{ background: var(--tb-cream); }
.tb-page .service__num{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: var(--tb-tracking-eyebrow);
  color: var(--tb-ochre-deep);
  margin-bottom: var(--tb-space-6);
}
.tb-page .service__title{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 26px;
  line-height: 1.1;
  margin-bottom: var(--tb-space-4);
  letter-spacing: -0.01em;
}
.tb-page .service__body{
  font-size: 15px;
  line-height: 1.55;
  color: var(--tb-charcoal-3);
  margin-bottom: var(--tb-space-6);
}

/* ── Quote ──────────────────────────────────────────────── */
.tb-page .quote{
  background: var(--tb-charcoal);
  color: var(--tb-cream);
  padding: var(--tb-space-20) 0;
}
.tb-page .quote__inner{
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--tb-space-12);
  align-items: start;
}
.tb-page .quote__mark{
  font-family: var(--tb-font-display);
  font-weight: 900;
  font-size: 200px;
  line-height: 0.7;
  color: var(--tb-ochre);
}
.tb-page .quote__text{
  font-family: var(--tb-font-display);
  font-weight: 500;
  font-size: clamp(26px, 2.6vw, 36px);
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--tb-cream);
  margin-bottom: var(--tb-space-8);
}
.tb-page .quote__attr{
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-5);
}
.tb-page .quote__attr strong{ color: var(--tb-cream); font-weight: 700; }
.tb-page .quote__attr .sep{
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--tb-ochre);
}

/* ── Sample tender preview ──────────────────────────────── */
.tb-page .sample{
  background: var(--tb-charcoal);
  color: var(--tb-cream);
}
.tb-page .sample__layout{
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: var(--tb-space-16);
  align-items: center;
}
.tb-page .sample__doc{
  background: var(--tb-white);
  color: var(--tb-charcoal);
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
  width: 100%;
  aspect-ratio: 210/297;
  padding: 38px 32px;
  font-size: 9.5px;
  line-height: 1.55;
  position: relative;
  transform: rotate(-1.5deg);
  transform-origin: center;
}
.tb-page .sample__doc::before{
  content: '';
  position: absolute;
  top: 14px; left: 32px; right: 32px;
  height: 1px;
  border-bottom: 1px solid var(--tb-ochre);
}
.tb-page .sample-running{
  position: absolute;
  top: -2px; left: 32px; right: 32px;
  display: flex;
  justify-content: space-between;
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 7px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--tb-charcoal-3);
  padding-bottom: 6px;
}
.tb-page .sample-running .wm .a{ color: var(--tb-charcoal); }
.tb-page .sample-running .wm .b{ color: var(--tb-ochre); }
.tb-page .sample-eyebrow{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--tb-ochre-deep);
  margin-bottom: 6px;
}
.tb-page .sample-h1{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 24px;
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 10px;
}
.tb-page .sample-h3{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 8.5px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  margin-bottom: 4px;
  position: relative;
}
.tb-page .sample-h3::after{
  content: '';
  display: block;
  width: 14px; height: 1.5px;
  background: var(--tb-ochre);
  margin-top: 4px;
}
.tb-page .sample-h3-block{ margin: 18px 0 8px; }
.tb-page .sample-body{ color: var(--tb-charcoal-3); margin-bottom: 8px; }
.tb-page .sample-callout{
  background: var(--tb-cream);
  border-left: 2px solid var(--tb-ochre);
  padding: 7px 10px;
  margin: 10px 0;
}
.tb-page .sample-callout-label{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 7px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--tb-ochre-deep);
  margin-bottom: 3px;
}
.tb-page .sample-table{
  width: 100%;
  border-collapse: collapse;
  margin: 10px 0;
  font-size: 8px;
}
.tb-page .sample-table th{
  background: var(--tb-charcoal);
  color: var(--tb-cream);
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 7px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  text-align: left;
  padding: 6px 8px;
  border-bottom: 2px solid var(--tb-ochre);
}
.tb-page .sample-table td{
  padding: 6px 8px;
  border-bottom: 0.5px solid var(--tb-charcoal-6);
  vertical-align: top;
  color: var(--tb-charcoal-3);
}
.tb-page .sample-table tr:nth-child(even) td{ background: var(--tb-cream); }
.tb-page .sample-list{ list-style: none; margin: 6px 0; }
.tb-page .sample-list li{
  position: relative;
  padding-left: 12px;
  margin-bottom: 3px;
  color: var(--tb-charcoal-3);
}
.tb-page .sample-list li::before{
  content: '';
  position: absolute;
  left: 0; top: 5px;
  width: 4px; height: 4px;
  background: var(--tb-ochre);
}
.tb-page .sample-footer{
  position: absolute;
  bottom: 14px; left: 32px; right: 32px;
  display: flex;
  justify-content: space-between;
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 7px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
  border-top: 0.5px solid var(--tb-charcoal-6);
  padding-top: 4px;
}

/* ── Case studies ───────────────────────────────────────── */
.tb-page .cases{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--tb-space-6);
}
.tb-page .case{
  background: var(--tb-white);
  border: 1px solid var(--tb-charcoal-6);
  display: grid;
  grid-template-rows: 320px auto;
  position: relative;
}
.tb-page .case__media{
  background: var(--tb-charcoal-2);
  position: relative;
  overflow: hidden;
}
.tb-page .case__media image-slot{ width: 100%; height: 100%; }
.tb-page .case__badge{
  position: absolute;
  top: 16px; left: 16px;
  background: var(--tb-ochre);
  color: var(--tb-charcoal);
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  padding: 6px 12px;
  z-index: 2;
}
.tb-page .case__body{ padding: var(--tb-space-8); }
.tb-page .case__client{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.tb-page .case__client .dot{ width: 4px; height: 4px; background: var(--tb-ochre); }
.tb-page .case__title{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: var(--tb-space-3);
}
.tb-page .case__excerpt{
  font-size: 15px;
  line-height: 1.5;
  color: var(--tb-charcoal-3);
  margin-bottom: var(--tb-space-6);
}
.tb-page .case__stats{
  display: flex;
  gap: var(--tb-space-6);
  padding-top: var(--tb-space-4);
  border-top: 1px solid var(--tb-charcoal-6);
}
.tb-page .case__stat-num{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 28px;
  line-height: 1;
  color: var(--tb-charcoal);
}
.tb-page .case__stat-label{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
  margin-top: 4px;
}

/* ── FAQ ────────────────────────────────────────────────── */
.tb-page .faq{
  border-top: 1px solid var(--tb-charcoal-6);
}
.tb-page .faq__item{
  border-bottom: 1px solid var(--tb-charcoal-6);
}
.tb-page .faq__q{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--tb-space-6);
  width: 100%;
  padding: var(--tb-space-6) 0;
  background: transparent;
  border: none;
  text-align: left;
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--tb-charcoal);
  cursor: pointer;
}
.tb-page .faq__q-num{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow);
  color: var(--tb-ochre-deep);
  width: 48px;
  flex: 0 0 48px;
}
.tb-page .faq__q-text{ flex: 1; }
.tb-page .faq__toggle{
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border: 1px solid var(--tb-charcoal-6);
  background: var(--tb-white);
  flex: 0 0 32px;
  position: relative;
  transition: background .15s ease;
}
.tb-page .faq__toggle::before, .tb-page .faq__toggle::after{
  content: '';
  position: absolute;
  background: var(--tb-charcoal);
  transition: transform .2s ease;
}
.tb-page .faq__toggle::before{ width: 12px; height: 2px; }
.tb-page .faq__toggle::after{ width: 2px; height: 12px; }
.tb-page .faq__item[open] .faq__toggle{ background: var(--tb-ochre); border-color: var(--tb-ochre); }
.tb-page .faq__item[open] .faq__toggle::after{ transform: scaleY(0); }
.tb-page .faq__q::-webkit-details-marker{ display: none; }
.tb-page .faq__q{ list-style: none; }
.tb-page .faq__a{ overflow: hidden; }
.tb-page .faq__a-inner{
  padding: 0 80px var(--tb-space-6) 48px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--tb-charcoal-3);
  max-width: 75ch;
}

/* ── Pricing ────────────────────────────────────────────── */
.tb-page .pricing{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--tb-charcoal-6);
}
.tb-page .plan{
  padding: var(--tb-space-10) var(--tb-space-8) var(--tb-space-8);
  border-right: 1px solid var(--tb-charcoal-6);
  background: var(--tb-white);
  display: flex;
  flex-direction: column;
}
.tb-page .plan:last-child{ border-right: none; }
.tb-page .plan--featured{ background: var(--tb-charcoal); color: var(--tb-cream); position: relative; }
.tb-page .plan--featured::before{
  content: 'MOST POPULAR';
  position: absolute;
  top: 0; left: 0; right: 0;
  background: var(--tb-ochre);
  color: var(--tb-charcoal);
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-align: center;
  padding: 8px;
}
.tb-page .plan--featured{ padding-top: calc(var(--tb-space-10) + 20px); }
.tb-page .plan__eyebrow{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-ochre-deep);
  margin-bottom: var(--tb-space-4);
}
.tb-page .plan--featured .plan__eyebrow{ color: var(--tb-ochre); }
.tb-page .plan__name{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 36px;
  line-height: 1;
  letter-spacing: -0.015em;
  margin-bottom: var(--tb-space-4);
}
.tb-page .plan__price{
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: var(--tb-space-3);
}
.tb-page .plan__price-num{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: 56px;
  line-height: 1;
  letter-spacing: -0.02em;
}
.tb-page .plan__price-unit{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: var(--tb-tracking-label);
  color: var(--tb-charcoal-4);
  text-transform: uppercase;
}
.tb-page .plan--featured .plan__price-unit{ color: var(--tb-charcoal-5); }
.tb-page .plan__desc{
  color: var(--tb-charcoal-3);
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: var(--tb-space-8);
  padding-bottom: var(--tb-space-6);
  border-bottom: 1px solid var(--tb-charcoal-6);
}
.tb-page .plan--featured .plan__desc{ color: var(--tb-charcoal-5); border-bottom-color: var(--tb-charcoal-3); }
.tb-page .plan__features{ list-style: none; margin: 0; padding: 0; flex: 1; }
.tb-page .plan__features li{
  position: relative;
  padding-left: 22px;
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 1.5;
}
.tb-page .plan__features li::before{
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 6px; height: 6px;
  background: var(--tb-ochre);
}
.tb-page .plan__cta{ margin-top: var(--tb-space-8); }

/* ── CTA strip ──────────────────────────────────────────── */
.tb-page .cta{
  background: var(--tb-cream);
  border-top: 4px solid var(--tb-ochre);
}
.tb-page .cta__inner{
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--tb-space-12);
  padding: var(--tb-space-20) 0;
  align-items: center;
}
.tb-page .cta__title{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 0.96;
  letter-spacing: -0.015em;
}
.tb-page .cta__title .em{ color: var(--tb-ochre-deep); }
.tb-page .cta__details{
  display: flex;
  flex-direction: column;
  gap: var(--tb-space-4);
}
.tb-page .cta__detail{
  display: flex;
  align-items: baseline;
  gap: var(--tb-space-3);
  padding: 16px 0;
  border-bottom: 1px solid var(--tb-charcoal-6);
}
.tb-page .cta__detail:first-child{ border-top: 1px solid var(--tb-charcoal-6); }
.tb-page .cta__detail-label{
  font-family: var(--tb-font-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-4);
  flex: 0 0 100px;
}
.tb-page .cta__detail-value{
  font-family: var(--tb-font-body);
  font-weight: 500;
  font-size: 18px;
  color: var(--tb-charcoal);
}

/* ── Page banner (sub-pages) ────────────────────────────── */
.tb-page .banner{
  background: var(--tb-charcoal);
  color: var(--tb-cream);
  padding: var(--tb-space-20) 0 var(--tb-space-16);
  position: relative;
}
.tb-page .banner__crumbs{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-5);
  margin-bottom: var(--tb-space-8);
  display: flex;
  gap: 10px;
}
.tb-page .banner__crumbs .sep{
  color: var(--tb-ochre);
}
.tb-page .banner__inner{
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--tb-space-12);
  align-items: end;
}
.tb-page .banner__title{
  font-family: var(--tb-font-display);
  font-weight: 800;
  font-size: clamp(48px, 7vw, 96px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: var(--tb-cream);
}
.tb-page .banner__title .em{ color: var(--tb-ochre); }
.tb-page .banner__sub{
  font-size: 18px;
  line-height: 1.5;
  color: var(--tb-charcoal-5);
  max-width: 50ch;
  padding-bottom: 6px;
}

/* ── Form ───────────────────────────────────────────────── */
.tb-page .form{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--tb-space-6);
}
.tb-page .form__field{ display: flex; flex-direction: column; gap: 6px; }
.tb-page .form__field--full{ grid-column: 1 / -1; }
.tb-page .form__label{
  font-family: var(--tb-font-display);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tb-charcoal-3);
}
.tb-page .form__input, .tb-page .form__select, .tb-page .form__textarea{
  font-family: var(--tb-font-body);
  font-size: 16px;
  padding: 14px 16px;
  background: var(--tb-white);
  border: 1px solid var(--tb-charcoal-6);
  border-radius: 0;
  color: var(--tb-charcoal);
  transition: border-color .15s ease;
}
.tb-page .form__input:focus, .tb-page .form__select:focus, .tb-page .form__textarea:focus{
  outline: none;
  border-color: var(--tb-ochre);
}
.tb-page .form__textarea{ min-height: 140px; resize: vertical; }
.tb-page .form__help{
  font-size: 13px;
  color: var(--tb-charcoal-4);
}

/* ── Tweaks reset (the panel uses its own) ───────────────── */

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 1180px) {
  .tb-page .site-header__phone{ display: none; }
}
@media (max-width: 1100px) {
  .tb-page .hero__inner{ grid-template-columns: 1fr; gap: var(--tb-space-10); min-height: auto; padding-bottom: var(--tb-space-20); }
  .tb-page .hero__sidebar{ order: -1; }
  .tb-page .hero__photo{ height: 360px; }
  .tb-page .stats__grid{ grid-template-columns: repeat(2, 1fr); }
  .tb-page .stats__cell:nth-child(2n){ border-right: none; }
  .tb-page .stats__cell:nth-child(1), .tb-page .stats__cell:nth-child(2){ border-bottom: 1px solid var(--tb-charcoal-6); }
  .tb-page .process{ grid-template-columns: repeat(2, 1fr); }
  .tb-page .process__step:nth-child(2n){ border-right: none; }
  .tb-page .process__step:nth-child(1), .tb-page .process__step:nth-child(2){ border-bottom: 1px solid var(--tb-charcoal-6); }
  .tb-page .services{ grid-template-columns: 1fr 1fr; }
  .tb-page .cases{ grid-template-columns: 1fr; }
  .tb-page .case{ grid-template-rows: 260px auto; }
  .tb-page .pricing{ grid-template-columns: 1fr; }
  .tb-page .plan{ border-right: none; border-bottom: 1px solid var(--tb-charcoal-6); }
  .tb-page .plan:last-child{ border-bottom: none; }
  .tb-page .sample__layout, .tb-page .quote__inner, .tb-page .cta__inner, .tb-page .banner__inner, .tb-page .section-head{ grid-template-columns: 1fr; gap: var(--tb-space-8); }
  .tb-page .section-head{ padding-bottom: var(--tb-space-6); }
  .tb-page .quote__mark{ font-size: 120px; line-height: 0.7; }
  .tb-page .form{ grid-template-columns: 1fr; }
  .tb-page .site-footer__grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 980px) {
  .tb-page .site-nav{ display: none; }
}
@media (max-width: 720px) {
  :root{ --tb-container-pad: 20px; }
  .tb-page .site-header__row{ height: 64px; }
  .tb-page .site-nav{ display: none; }
  .tb-page .services{ grid-template-columns: 1fr; }
  .tb-page .stats__grid{ grid-template-columns: 1fr; }
  .tb-page .stats__cell{ border-right: none; border-bottom: 1px solid var(--tb-charcoal-6); }
  .tb-page .stats__cell:last-child{ border-bottom: none; }
  .tb-page .process{ grid-template-columns: 1fr; }
  .tb-page .process__step{ border-right: none; border-bottom: 1px solid var(--tb-charcoal-6); }
  .tb-page .process__step:last-child{ border-bottom: none; }
  .tb-page .section{ padding: var(--tb-space-20) 0; }
  .tb-page .site-footer__grid{ grid-template-columns: 1fr; }
  .tb-page .faq__q{ font-size: 18px; }
  .tb-page .faq__a-inner{ padding: 0 0 var(--tb-space-6) 48px; }
}

/* Retainer 'Best Value' badge variant */
.tb-page .plan--featured.plan--best::before { content: 'BEST VALUE'; }

/* Arrow chevron vertical-centre fix: rotate about box centre with the box centred on the
   shaft, so the tip lands exactly on the shaft centreline (was ~3.5px high). */
.tb-page .btn .arrow::after {
  right: -2px;
  top: 50%;
  width: 9px;
  height: 9px;
  margin-top: -4.5px;
  transform: rotate(45deg);
  transform-origin: center center;
}
.tb-page .btn:hover .arrow::after { transform: rotate(45deg); }

/* ── Theme neutraliser: applies only on redesign pages (body.tb-redesign set by mu-plugin) ── */
body.tb-redesign { margin: 0; }
body.tb-redesign .site-content, body.tb-redesign .content-area, body.tb-redesign .site-main,
body.tb-redesign .inside-article, body.tb-redesign .entry-content {
  margin: 0; padding: 0; max-width: 100%; width: 100%;
}
body.tb-redesign .grid-container { max-width: 100%; padding: 0; }
body.tb-redesign .entry-header, body.tb-redesign .entry-meta,
body.tb-redesign .post-navigation, body.tb-redesign #comments { display: none; }
/* Fallback only: hides theme header/footer if remove_action is bypassed (ours render outside #page) */
body.tb-redesign #page .site-header, body.tb-redesign #page .site-footer,
body.tb-redesign #page .main-navigation { display: none; }

/* GP Disable Elements collision fix: GP emits .site-header/.site-footer {display:none}
   on pages where its defaults are disabled; restore display for the TB design-system
   header/footer which share those class names (scoped under .tb-page). */
.tb-page .site-header { display: block; }
.tb-page .site-footer { display: block; }

/* WPForms TB skin (contact page) — mirrors the .form design language */
.tb-page .wpforms-container { max-width: none; }
.tb-page .wpforms-form .wpforms-field { padding: 0 0 22px 0; }
.tb-page .wpforms-form .wpforms-field-label {
  font-family: var(--tb-font-display); font-weight: 600; font-size: 11px;
  letter-spacing: var(--tb-tracking-eyebrow); text-transform: uppercase;
  color: var(--tb-charcoal-3); margin-bottom: 6px;
}
.tb-page .wpforms-form .wpforms-required-label { color: var(--tb-ochre-deep); }
.tb-page .wpforms-form .wpforms-field-sublabel { font-size: 13px; color: var(--tb-charcoal-4); }
.tb-page .wpforms-form input[type="text"], .tb-page .wpforms-form input[type="email"],
.tb-page .wpforms-form input[type="tel"], .tb-page .wpforms-form input[type="number"],
.tb-page .wpforms-form input[type="date"], .tb-page .wpforms-form input[type="url"],
.tb-page .wpforms-form select, .tb-page .wpforms-form textarea {
  font-family: var(--tb-font-body); font-size: 16px !important; padding: 14px 16px !important;
  background: var(--tb-white); border: 1px solid var(--tb-charcoal-6) !important;
  border-radius: 0 !important; color: var(--tb-charcoal); width: 100%; max-width: 100%;
  transition: border-color .15s ease;
}
.tb-page .wpforms-form input:focus, .tb-page .wpforms-form select:focus, .tb-page .wpforms-form textarea:focus {
  outline: none !important; box-shadow: none !important; border-color: var(--tb-ochre) !important;
}
.tb-page .wpforms-form textarea { min-height: 140px; resize: vertical; }
.tb-page .wpforms-form button[type="submit"], .tb-page .wpforms-form .wpforms-submit {
  font-family: var(--tb-font-display); font-weight: 600; font-size: 12px;
  letter-spacing: var(--tb-tracking-eyebrow); text-transform: uppercase;
  background: var(--tb-ochre) !important; color: var(--tb-charcoal) !important;
  border: 0 !important; border-radius: 0 !important; padding: 16px 28px !important;
  cursor: pointer; transition: background .15s ease;
}
.tb-page .wpforms-form button[type="submit"]:hover, .tb-page .wpforms-form .wpforms-submit:hover {
  background: var(--tb-ochre-deep) !important; color: var(--tb-white) !important;
}

/* WPForms TB skin v2: select clipping + medium-size width */
.tb-page .wpforms-form select { height: auto !important; padding: 12px 16px !important; line-height: 1.4 !important; }
.tb-page .wpforms-form .wpforms-field-medium,
.tb-page .wpforms-form .wpforms-field-row.wpforms-field-medium { max-width: 100% !important; }

/* WPForms TB skin v3: force container to fill its parent column (was collapsing to ~269px) */
.tb-page .wpforms-container,
.tb-page .wpforms-container-full,
.tb-page .wpforms-form { width: 100% !important; max-width: 100% !important; }
/* RESOURCES PAGE — added 2026-06-12 */
.tb-page .resources-hero { background: var(--tb-charcoal); color: var(--tb-cream); padding: 96px 0 80px; }
.tb-page .resources-hero .eyebrow { color: var(--tb-ochre); }
.tb-page .resources-hero h1 { font-family: "Barlow Semi Condensed", sans-serif; font-size: clamp(48px, 6vw, 88px); line-height: 0.95; font-weight: 700; margin: 16px 0 28px; color: var(--tb-cream); max-width: 14ch; }
.tb-page .resources-hero .lede { font-size: 18px; line-height: 1.55; max-width: 62ch; color: rgba(240,237,230,0.78); margin-bottom: 48px; }
.tb-page .resources-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 32px; border-top: 1px solid rgba(240,237,230,0.12); border-bottom: 1px solid rgba(240,237,230,0.12); padding: 32px 0; margin-bottom: 40px; max-width: 760px; }
.tb-page .resources-stats .stat-num { display: block; font-family: "Barlow Semi Condensed", sans-serif; font-size: 56px; font-weight: 700; color: var(--tb-ochre); line-height: 1; }
.tb-page .resources-stats .stat-label { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(240,237,230,0.6); margin-top: 8px; display: block; }
.tb-page .resources-catnav { display: flex; flex-wrap: wrap; gap: 18px 28px; font-family: monospace; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; }
.tb-page .resources-catnav a { color: rgba(240,237,230,0.85); text-decoration: none; border-bottom: 1px dashed rgba(196,154,60,0.4); padding-bottom: 4px; transition: color 0.15s; }
.tb-page .resources-catnav a:hover { color: var(--tb-ochre); border-bottom-color: var(--tb-ochre); }
.tb-page .resource-cat-head { margin-bottom: 44px; max-width: 760px; }
.tb-page .resource-cat-head h2 { font-family: "Barlow Semi Condensed", sans-serif; font-size: clamp(32px, 4vw, 52px); font-weight: 700; line-height: 1.05; margin: 16px 0 16px; color: var(--tb-charcoal); }
.tb-page .resource-cat-head p { font-size: 16px; line-height: 1.6; color: #4a4a44; max-width: 62ch; margin: 0; }
.tb-page .resource-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; }
.tb-page .resource-card { background: #fff; border-left: 4px solid var(--tb-ochre); padding: 28px 28px 32px; text-decoration: none; color: var(--tb-charcoal); transition: transform 0.15s ease, box-shadow 0.15s ease; display: flex; flex-direction: column; gap: 12px; }
.tb-page .resource-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(28,28,26,0.08); }
.tb-page .resource-card h3 { font-family: "Barlow Semi Condensed", sans-serif; font-size: 22px; font-weight: 600; line-height: 1.2; color: var(--tb-charcoal); margin: 0; }
.tb-page .resource-card p { font-size: 14px; line-height: 1.55; color: #5a5a55; margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; flex-grow: 1; }
.tb-page .resource-card .card-read { font-family: monospace; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--tb-ochre); margin-top: 4px; }
.tb-page .section--alt-white { background: #fff; }
/* SINGLE POST CHROME SUPPRESSION — added 2026-06-12 */
/* Theme header/footer/nav/entry-meta replaced by GP Hook Elements 354/355 — featured image kept as custom hero */
body.single-post > header.site-header,
body.single-post > footer.site-footer,
body.single-post > #generate-top-bar,
body.single-post .top-bar,
body.single-post .entry-header,
body.single-post footer.entry-meta,
body.single-post nav.post-navigation,
body.single-post #comments,
body.single-post .comments-area { display: none !important; }

/* Ensure the article wrapper sits flush since we hid the entry header */
body.single-post .site { padding-top: 0 !important; }
body.single-post .inside-article { padding-top: 0 !important; }


/* SEPARATE: theme footer suppression (the GP theme nests footer.site-info inside div.site-footer) */
html body.single-post div.site-footer { display: none !important; }

/* ============================================================
   MOBILE FIXES — added 2026-06-13
   ============================================================ */

/* ── #3 Mobile navigation (hamburger) ─────────────────────────
   Desktop: burger hidden, nav inline (existing rules).
   <=980px: existing rule hides .site-nav; the burger appears and toggles
   it open as a full-width panel under the header bar. Logo + Book-a-call
   stay visible; only the six links go behind the burger. */
.tb-page .site-header__burger{
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  flex-shrink: 0;
}
.tb-page .site-header__burger span{
  display: block;
  width: 24px;
  height: 2px;
  margin: 0 auto;
  background: var(--tb-cream);
  transition: transform .2s ease, opacity .2s ease;
}

@media (max-width: 980px){
  .tb-page .site-header__burger{ display: flex; }

  .tb-page .site-header.is-nav-open .site-nav{
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 60;
    background: var(--tb-charcoal);
    border-bottom: 3px solid var(--tb-ochre);
    padding: 4px var(--tb-container-pad) 16px;
    box-shadow: 0 16px 28px rgba(0,0,0,0.32);
  }
  .tb-page .site-header.is-nav-open .site-nav a{
    padding: 15px 2px;
    font-size: 15px;
    white-space: normal;
    border-bottom: 1px solid var(--tb-charcoal-2);
  }
  .tb-page .site-header.is-nav-open .site-nav a:last-child{ border-bottom: 0; }

  .tb-page .site-header.is-nav-open .site-header__burger span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
  .tb-page .site-header.is-nav-open .site-header__burger span:nth-child(2){ opacity: 0; }
  .tb-page .site-header.is-nav-open .site-header__burger span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }

  .tb-page .site-header__cta .btn{ padding: 11px 16px; font-size: 12px; }
  .tb-page .site-header__cta .btn .arrow{ display: none; }
}
@media (max-width: 420px){
  .tb-page .site-header__brand{ font-size: 19px; letter-spacing: 0.08em; }
  .tb-page .site-header__cta .btn{ padding: 10px 12px; }
}

/* ── #2 Article TOC: stack above the body on mobile ───────────
   The desktop two-column (TOC beside body) is defined outside this
   file; !important collapses it here regardless of the source rule. */
@media (max-width: 1100px){
  .tb-page.tb-article-page,
  .tb-article-page{ display: block !important; }
  .tb-article-page .tb-article__toc{
    width: auto !important;
    max-width: none !important;
    margin: 0 0 2rem 0 !important;
  }
  .tb-article-page .tb-article__body{ width: auto !important; }
}

/* ── #1 Table overflow on mobile ──────────────────────────────
   .tb-table cells force a min-width past the viewport on phones;
   trim padding/font and let long values wrap. */
@media (max-width: 720px){
  .tb-page .tb-table{ font-size: 13px; }
  .tb-page .tb-table thead th,
  .tb-page .tb-table tbody td{
    padding: 10px 10px;
    overflow-wrap: anywhere;
  }
}
