/*
 * Wood Pecker Byron — Main Stylesheet
 * Version: 1.0.0
 *
 * Table of Contents:
 *   1.  CSS Custom Properties (Design System Variables)
 *   2.  Modern Reset
 *   3.  Typography
 *   4.  Layout System (.container, grids, spacing)
 *   5.  Header
 *   6.  Navigation
 *   7.  Footer
 *   8.  Buttons
 *   9.  Cards (.card-post, .card-project, .card-testimonial)
 *  10.  Forms
 *  11.  Badges & Tags
 *  12.  Sections (.section-hero, .section-cta, etc.) — Beaver Builder helpers
 *  13.  Page Hero
 *  14.  Project Templates
 *  15.  Blog Templates
 *  16.  Contact Page
 *  17.  Breadcrumbs
 *  18.  FAQ Accordion
 *  19.  WhatsApp Float Button
 *  20.  Pagination
 *  21.  Utility Classes
 *  22.  Accessibility
 *  23.  Print
 *
 * Colours, fonts, and spacing are controlled by CSS custom properties.
 * Override them via Customizer (outputs inline :root{} after this file).
 */


/* ═══════════════════════════════════════════════════════════════
   1. CSS CUSTOM PROPERTIES
   ═══════════════════════════════════════════════════════════════ */

:root {
  /* Brand Colours */
  --color-cream:    #EFE5DB;
  --color-sand:     #D8C7B3;
  --color-timber:   #8B6E52;
  --color-charcoal: #4A433D;

  /* Semantic Aliases */
  --color-bg:          var(--color-cream);
  --color-bg-alt:      var(--color-sand);
  --color-accent:      var(--color-timber);
  --color-text:        var(--color-charcoal);
  --color-text-light:  #7A7069;
  --color-text-muted:  #A09488;
  --color-white:       #FFFFFF;
  --color-border:      rgba(74, 67, 61, 0.15);
  --color-border-soft: rgba(74, 67, 61, 0.08);

  /* Accent variants */
  --color-accent-dark:  #6E5540;
  --color-accent-light: #A8896A;

  /* Typography */
  --font-heading: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-body:    'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Type Scale */
  --text-xs:   0.75rem;      /*  12px */
  --text-sm:   0.875rem;     /*  14px */
  --text-base: 1rem;         /*  16px */
  --text-md:   1.125rem;     /*  18px */
  --text-lg:   1.25rem;      /*  20px */
  --text-xl:   1.5rem;       /*  24px */
  --text-2xl:  1.875rem;     /*  30px */
  --text-3xl:  2.25rem;      /*  36px */
  --text-4xl:  3rem;         /*  48px */
  --text-5xl:  3.75rem;      /*  60px */

  /* Line Heights */
  --leading-tight:  1.25;
  --leading-snug:   1.375;
  --leading-base:   1.6;
  --leading-relaxed:1.75;

  /* Spacing Scale */
  --space-1:  0.25rem;   /*  4px */
  --space-2:  0.5rem;    /*  8px */
  --space-3:  0.75rem;   /* 12px */
  --space-4:  1rem;      /* 16px */
  --space-5:  1.25rem;   /* 20px */
  --space-6:  1.5rem;    /* 24px */
  --space-8:  2rem;      /* 32px */
  --space-10: 2.5rem;    /* 40px */
  --space-12: 3rem;      /* 48px */
  --space-16: 4rem;      /* 64px */
  --space-20: 5rem;      /* 80px */
  --space-24: 6rem;      /* 96px */
  --space-32: 8rem;      /* 128px */

  /* Layout */
  --container-max:        1200px;
  --container-wide-max:   1440px;
  --container-narrow-max: 760px;
  --container-padding:    clamp(1rem, 4vw, 2rem);

  /* Header */
  --header-height:        90px;
  --header-height-mobile: 70px;

  /* Borders */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(74, 67, 61, 0.08);
  --shadow-md: 0 4px 16px rgba(74, 67, 61, 0.12);
  --shadow-lg: 0 8px 32px rgba(74, 67, 61, 0.16);

  /* Transitions */
  --transition-fast:   150ms ease;
  --transition-base:   250ms ease;
  --transition-slow:   400ms ease;

  /* Z-index */
  --z-header:   100;
  --z-dropdown: 200;
  --z-float:    400;
}


/* ═══════════════════════════════════════════════════════════════
   2. MODERN RESET
   ═══════════════════════════════════════════════════════════════ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  min-height: 100vh;
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

button, input, select, textarea {
  font: inherit;
}

a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-accent-dark);
}

ul, ol {
  list-style: none;
}

/* ─── WordPress Core Alignments ───────────────────────────────── */
.alignleft  { float: left; margin-right: var(--space-6); }
.alignright { float: right; margin-left: var(--space-6); }
.aligncenter { display: block; margin-inline: auto; }
.alignwide  { max-width: 1100px; margin-inline: auto; }
.alignfull  { max-width: 100%; margin-inline: 0; }


/* ═══════════════════════════════════════════════════════════════
   3. TYPOGRAPHY
   ═══════════════════════════════════════════════════════════════ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: var(--leading-tight);
  color: var(--color-charcoal);
}

h1 { font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl)); }
h2 { font-size: clamp(var(--text-xl),  4vw, var(--text-3xl)); }
h3 { font-size: clamp(var(--text-lg),  3vw, var(--text-2xl)); }
h4 { font-size: var(--text-xl); }
h5 { font-size: var(--text-lg); }
h6 { font-size: var(--text-md); }

p {
  max-width: 72ch;
  margin-bottom: var(--space-4);
}

p:last-child { margin-bottom: 0; }

strong, b { font-weight: 600; }
em, i     { font-style: italic; }

/* Entry content — paragraphs, lists, headings in the WP editor */
.entry-content h2,
.entry-content h3,
.entry-content h4 {
  margin-top: var(--space-8);
  margin-bottom: var(--space-4);
}

.entry-content p,
.entry-content ul,
.entry-content ol {
  margin-bottom: var(--space-5);
}

.entry-content ul,
.entry-content ol {
  padding-left: var(--space-6);
  list-style: revert;
}

.entry-content li { margin-bottom: var(--space-2); }

.entry-content blockquote {
  border-left: 3px solid var(--color-timber);
  padding-left: var(--space-6);
  margin: var(--space-8) 0;
  font-style: italic;
  color: var(--color-text-light);
}

.entry-content a:not(.btn) {
  color: var(--color-accent);
  text-decoration: underline;
}

.entry-content figure { margin: var(--space-8) 0; }

.entry-content figcaption {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
  margin-top: var(--space-2);
}


/* ═══════════════════════════════════════════════════════════════
   4. LAYOUT SYSTEM
   ═══════════════════════════════════════════════════════════════ */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.container-wide {
  max-width: var(--container-wide-max);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.container-narrow {
  max-width: var(--container-narrow-max);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

/* Section spacing — apply to section wrappers */
.section-padding {
  padding-block: clamp(var(--space-12), 6vw, var(--space-24));
}

.section-padding--sm {
  padding-block: clamp(var(--space-8), 4vw, var(--space-16));
}

/* 2-column grid helper */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 480px), 1fr));
  gap: var(--space-8);
}

/* 3-column grid helper */
.grid-3 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  gap: var(--space-6);
}

/* 4-column grid helper */
.grid-4 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
  gap: var(--space-6);
}


/* ═══════════════════════════════════════════════════════════════
   5. HEADER
   ═══════════════════════════════════════════════════════════════ */

.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background-color: var(--color-cream);
  border-bottom: 1px solid var(--color-border);
  transition: box-shadow var(--transition-base);
}

.site-header.is-scrolled {
  box-shadow: var(--shadow-md);
}

.header-inner {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  height: var(--header-height);
}

/* Logo — image left, site title right, whole block links to homepage */
.header-logo { flex-shrink: 0; }

.site-logo {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
}

.site-logo__image {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.site-logo__img {
  height: 80px;
  width: auto;
  display: block;
}

.site-logo__name {
  font-family: var(--font-heading);
  font-size: 25px;
  font-weight: 700;
  color: var(--color-charcoal);
  line-height: 1.2;
  white-space: nowrap;
}

.site-logo:hover .site-logo__name {
  color: var(--color-accent);
}

/* Nav takes remaining space */
.primary-nav { flex: 1; }

/* Header actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-shrink: 0;
}

.header-phone {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-charcoal);
  text-decoration: none;
  white-space: nowrap;
}

.header-phone:hover { color: var(--color-accent); }

.header-phone__icon { flex-shrink: 0; }

.header-whatsapp {
  color: #25D366; /* WhatsApp green — intentionally not a theme variable */
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.header-whatsapp:hover { opacity: 0.8; }

.header-cta { /* Uses .btn.btn-primary */ }

/* Landing page header variant */
.site-header--landing .primary-nav { display: none; }


/* ═══════════════════════════════════════════════════════════════
   6. NAVIGATION
   ═══════════════════════════════════════════════════════════════ */

/* Desktop menu */
.primary-menu {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  margin: 0;
  padding: 0;
  justify-content: center;
}

.primary-menu > li {
  position: relative;
}

.primary-menu > li > a {
  display: block;
  padding: var(--space-2) var(--space-3);
  font-size: 17px;
  font-weight: 500;
  color: var(--color-charcoal);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast), background-color var(--transition-fast);
  white-space: nowrap;
}

.primary-menu > li > a:hover,
.primary-menu > li.current-menu-item > a,
.primary-menu > li.current-menu-ancestor > a {
  color: var(--color-accent);
  background-color: rgba(139, 110, 82, 0.08);
}

/* Chevron indicator for items with children */
.primary-menu > li.menu-item-has-children > a::after {
  content: '▾';
  margin-left: 4px;
  font-size: 0.75em;
  opacity: 0.6;
}

/* Dropdown submenu */
.primary-menu .sub-menu {
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 0;
  min-width: 200px;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  list-style: none;
  padding: var(--space-2) 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition:
    opacity var(--transition-fast),
    visibility var(--transition-fast),
    transform var(--transition-fast);
  z-index: var(--z-dropdown);
}

.primary-menu > li:hover > .sub-menu,
.primary-menu > li:focus-within > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.primary-menu .sub-menu a {
  display: block;
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-charcoal);
  text-decoration: none;
  transition: color var(--transition-fast), background-color var(--transition-fast);
}

.primary-menu .sub-menu a:hover {
  color: var(--color-accent);
  background-color: var(--color-bg);
}

/* Mobile toggle button */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  flex-shrink: 0;
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast);
}

.nav-toggle:hover { background-color: var(--color-border-soft); }

.nav-toggle__bar {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--color-charcoal);
  border-radius: 2px;
  transition:
    transform var(--transition-fast),
    opacity var(--transition-fast);
}

/* Open state: X icon */
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Submenu toggle (injected by JS on mobile) */
.submenu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  color: var(--color-charcoal);
}

/* ─── Mobile Navigation ──────────────────────────────────────── */
@media (max-width: 900px) {

  .nav-toggle { display: flex; }

  .header-inner { height: var(--header-height-mobile); }

  .header-phone { display: none; } /* Too cramped on mobile header */

  /* Hide the text label on mobile when a logo image is present.
     The image alone identifies the brand at small sizes.
     .site-logo--no-image is set in logo.php when no logo is uploaded,
     so the text always shows as fallback when there is no image. */
  .site-logo:not(.site-logo--no-image) .site-logo__name { display: none; }

  .site-logo__img { height: 56px; }

  .primary-nav {
    position: fixed;
    top: var(--header-height-mobile);
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-cream);
    border-top: 1px solid var(--color-border);
    overflow-y: auto;
    padding: var(--space-4) var(--container-padding);
    transform: translateX(-100%);
    visibility: hidden;
    transition:
      transform var(--transition-base),
      visibility var(--transition-base);
    z-index: calc(var(--z-header) - 1);
  }

  .primary-nav.is-open {
    transform: translateX(0);
    visibility: visible;
  }

  .primary-menu {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .primary-menu > li { width: 100%; }

  .primary-menu > li > a {
    font-size: var(--text-md);
    padding: var(--space-4) 0;
    border-bottom: 1px solid var(--color-border-soft);
    border-radius: 0;
  }

  .primary-menu .sub-menu {
    position: static;
    opacity: 1;
    visibility: hidden;
    height: 0;
    overflow: hidden;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    padding: 0;
    background: transparent;
    transition: height var(--transition-base), visibility var(--transition-base);
  }

  .primary-menu .sub-menu.is-open {
    visibility: visible;
    height: auto;
  }

  .primary-menu .sub-menu a {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border-soft);
    color: var(--color-text-light);
  }

  .submenu-toggle { display: flex; }
}


/* ═══════════════════════════════════════════════════════════════
   7. FOOTER
   ═══════════════════════════════════════════════════════════════ */

.site-footer {
  background-color: var(--color-charcoal);
  color: var(--color-sand);
  margin-top: auto;
}

.footer-top {
  padding-block: var(--space-16) var(--space-12);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-8);
}

.footer-col { }

/* Brand column */
.footer-logo img {
  height: 80px;
  width: auto;

  margin-bottom: var(--space-4);
}

.footer-site-name {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  color: var(--color-cream);
  margin-bottom: var(--space-4);
}

.footer-blurb {
  font-size: var(--text-sm);
  color: var(--color-sand);
  line-height: var(--leading-relaxed);
  max-width: 36ch;
  margin-bottom: var(--space-6);
}

/* Social */
.footer-social {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--color-sand);
  background: rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.footer-social__link:hover {
  background: var(--color-timber);
  color: var(--color-white);
}

/* Footer nav */
.footer-nav-title {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-cream);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-4);
}

.footer-nav {
  list-style: none;
  margin: 0 0 var(--space-8) 0;
  padding: 0;
}

.footer-nav li { margin-bottom: var(--space-2); }

.footer-nav a {
  font-size: var(--text-sm);
  color: var(--color-sand);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-nav a:hover { color: var(--color-cream); }

.footer-areas-list { columns: 2; gap: var(--space-4); }

/* Contact column */
.footer-contact { }

.footer-contact__item {
  font-size: var(--text-sm);
  color: var(--color-sand);
  margin-bottom: var(--space-3);
}

.footer-contact__item a {
  color: var(--color-sand);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-contact__item a:hover { color: var(--color-cream); }

/* Footer testimonial */
.footer-testimonial {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-testimonial__quote {
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-sand);
  margin-bottom: var(--space-2);
}

.footer-testimonial__author {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* Footer bottom bar */
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-block: var(--space-5);
}

.footer-bottom__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer-copyright,
.footer-legal {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: 0;
  max-width: none;
}

/* Landing footer */
.site-footer--landing .footer-bottom {
  border-top: 1px solid var(--color-border);
  background: var(--color-cream);
}

.site-footer--landing .footer-copyright { color: var(--color-text-muted); }

@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .footer-bottom__inner {
    flex-direction: column;
    text-align: center;
  }

  .footer-areas-list { columns: 1; }
}


/* ═══════════════════════════════════════════════════════════════
   8. BUTTONS
   ═══════════════════════════════════════════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-body);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1;
  text-decoration: none;
  border: 2px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  white-space: nowrap;
  transition:
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

/* Primary — timber brown fill */
.btn-primary {
  background-color: var(--color-timber);
  border-color: var(--color-timber);
  color: var(--color-white);
}

.btn-primary:hover {
  background-color: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
  color: var(--color-white);
}

/* Secondary — outlined */
.btn-secondary {
  background-color: transparent;
  border-color: var(--color-timber);
  color: var(--color-timber);
}

.btn-secondary:hover {
  background-color: var(--color-timber);
  color: var(--color-white);
}

/* Ghost — subtle */
.btn-ghost {
  background-color: transparent;
  border-color: var(--color-border);
  color: var(--color-text);
}

.btn-ghost:hover {
  background-color: var(--color-bg-alt);
  border-color: var(--color-sand);
}

/* Inverted — for dark backgrounds */
.btn-inverted {
  background-color: var(--color-white);
  border-color: var(--color-white);
  color: var(--color-timber);
}

.btn-inverted:hover {
  background-color: var(--color-cream);
  border-color: var(--color-cream);
}

/* Size variants */
.btn-sm { padding: var(--space-2) var(--space-4); font-size: var(--text-xs); }
.btn-lg { padding: var(--space-4) var(--space-8); font-size: var(--text-md); }


/* ═══════════════════════════════════════════════════════════════
   9. CARDS
   ═══════════════════════════════════════════════════════════════ */

.card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* ─── Project Card ─────────────────────────────────────────────── */
.card-project {
  background: var(--color-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card-project:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

/* Image wrap — relative so overlay and badges can position absolutely */
.card-project__image-wrap {
  display: block;
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
}

.card-project__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.card-project:hover .card-project__image { transform: scale(1.05); }

.card-project__image--placeholder {
  background: var(--color-sand);
  width: 100%;
  height: 100%;
}

/* Hover overlay */
.card-project__overlay {
  position: absolute;
  inset: 0;
  background: rgba(44, 38, 33, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition-base);
}

.card-project:hover .card-project__overlay { opacity: 1; }

.card-project__overlay-label {
  color: var(--color-white);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1.5px solid rgba(255,255,255,0.7);
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-sm);
}

/* Category badges overlaid on image (bottom-left) */
.card-project__badges {
  position: absolute;
  bottom: var(--space-3);
  left: var(--space-3);
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.card-project__body {
  padding: var(--space-5);
}

.card-project__title {
  font-size: var(--text-lg);
  margin-top: 0;
  margin-bottom: var(--space-2);
}

.card-project__title a {
  color: var(--color-charcoal);
  text-decoration: none;
}

.card-project__title a:hover { color: var(--color-accent); }

.card-project__location {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-text-light);
  margin-bottom: var(--space-3);
}

.card-project__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  margin-bottom: var(--space-4);
  line-height: var(--leading-relaxed);
}

.card-project__link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
}

.card-project__link:hover { color: var(--color-accent-dark); }

/* ─── Blog Post Card ────────────────────────────────────────────── */
.card-post { }

.card-post__image-link { display: block; aspect-ratio: 16/9; overflow: hidden; }

.card-post__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.card-post:hover .card-post__image { transform: scale(1.03); }

.card-post__body { padding: var(--space-5); }

.card-post__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.card-post__cat {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  text-decoration: none;
}

.card-post__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.card-post__title {
  font-size: var(--text-lg);
  margin-bottom: var(--space-3);
}

.card-post__title a {
  color: var(--color-charcoal);
  text-decoration: none;
}

.card-post__title a:hover { color: var(--color-accent); }

.card-post__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  margin-bottom: var(--space-4);
}

.card-post__link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
}

/* ─── Testimonial Card ──────────────────────────────────────────── */
.card-testimonial {
  padding: var(--space-6);
  background: var(--color-white);
  border: 1px solid var(--color-border);
}

.testimonial-stars {
  display: flex;
  gap: 2px;
  margin-bottom: var(--space-4);
}

.star { font-size: var(--text-md); }
.star--filled { color: #E8A020; }  /* Gold — intentionally fixed */
.star--empty  { color: var(--color-border); }

.testimonial-quote {
  font-style: italic;
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--color-charcoal);
  margin-bottom: var(--space-5);
}

.testimonial-author {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.testimonial-author__name {
  font-weight: 600;
  font-size: var(--text-sm);
}

.testimonial-author__role,
.testimonial-author__suburb,
.testimonial-author__service {
  font-size: var(--text-xs);
  color: var(--color-text-light);
}

.testimonial-author__project {
  font-size: var(--text-xs);
  color: var(--color-accent);
  text-decoration: none;
  margin-top: var(--space-1);
}

.testimonial-author__project:hover {
  text-decoration: underline;
}


/* ═══════════════════════════════════════════════════════════════
   10. FORMS
   ═══════════════════════════════════════════════════════════════ */

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="search"],
textarea,
select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  appearance: none;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(139, 110, 82, 0.12);
}

label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-charcoal);
  margin-bottom: var(--space-2);
}

.wpcf7-form p { margin-bottom: var(--space-4); }

.wpcf7-submit { /* Extends .btn.btn-primary via CF7 config */ }

/* CF7 response messages */
.wpcf7-response-output {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  margin-top: var(--space-4);
  font-size: var(--text-sm);
}

/* Search form */
.search-form {
  display: flex;
  gap: var(--space-2);
}

.search-form input[type="search"] { flex: 1; }

.search-form button {
  padding: var(--space-3) var(--space-5);
  background: var(--color-timber);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-weight: 600;
  transition: background-color var(--transition-fast);
}

.search-form button:hover { background: var(--color-accent-dark); }


/* ═══════════════════════════════════════════════════════════════
   11. BADGES & TAGS
   ═══════════════════════════════════════════════════════════════ */

.tag-badge {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  background: rgba(139, 110, 82, 0.1);
  color: var(--color-timber);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  text-decoration: none;
  border: 1px solid rgba(139, 110, 82, 0.2);
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

a.tag-badge:hover {
  background: var(--color-timber);
  color: var(--color-white);
}

.tag-badge--inverted {
  background: rgba(255, 255, 255, 0.15);
  color: var(--color-cream);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Taxonomy filter row */
.taxonomy-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-10);
}

.filter-tag {
  display: inline-block;
  padding: var(--space-2) var(--space-4);
  background: var(--color-white);
  color: var(--color-text-light);
  font-size: var(--text-sm);
  font-weight: 500;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition:
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast);
}

.filter-tag:hover,
.filter-tag--active {
  background: var(--color-timber);
  border-color: var(--color-timber);
  color: var(--color-white);
}


/* ═══════════════════════════════════════════════════════════════
   12. SECTIONS — Beaver Builder helper classes
   Apply these as Row Class in Beaver Builder > Row > Advanced > Class.
   ═══════════════════════════════════════════════════════════════ */

/* Background helpers */
.bg-cream    { background-color: var(--color-cream); }
.bg-sand     { background-color: var(--color-sand); }
.bg-timber   { background-color: var(--color-timber); color: var(--color-white); }
.bg-charcoal { background-color: var(--color-charcoal); color: var(--color-cream); }
.bg-white    { background-color: var(--color-white); }

/* Section padding presets */
.section-hero        { padding-block: 0; }
.section-trust-bar   { padding-block: var(--space-8);  background: var(--color-white); border-block: 1px solid var(--color-border); }
.section-services    { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-cream); }
.section-process     { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-sand); }
.section-projects    { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-cream); }
.section-testimonials{ padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-charcoal); color: var(--color-cream); }
.section-faq         { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-white); }
.section-cta-strip   { padding-block: clamp(var(--space-10), 5vw, var(--space-16)); background: var(--color-timber); color: var(--color-white); text-align: center; }
.section-areas       { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-sand); }
.section-contact     { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); background: var(--color-cream); }

/* Section title helper */
.section-title {
  font-size: clamp(var(--text-xl), 3.5vw, var(--text-3xl));
  margin-bottom: var(--space-3);
}

.section-subtitle {
  font-size: var(--text-md);
  color: var(--color-text-light);
  max-width: 60ch;
  margin-bottom: var(--space-10);
}

.section-testimonials .section-title,
.section-cta-strip .section-title { color: inherit; }

.section-cta-strip .section-subtitle { color: rgba(239, 229, 219, 0.8); margin-inline: auto; }

/* Process steps grid */
.process-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
  gap: var(--space-8);
  counter-reset: process-step;
}

.process-step {
  counter-increment: process-step;
  position: relative;
  padding-left: var(--space-8);
}

.process-step::before {
  content: counter(process-step, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-timber);
  opacity: 0.4;
  line-height: 1;
}

/* Testimonials grid */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  gap: var(--space-6);
}

/* Projects grids */
.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
  gap: var(--space-6);
}

.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
  gap: var(--space-6);
}


/* ═══════════════════════════════════════════════════════════════
   13. PAGE HERO
   ═══════════════════════════════════════════════════════════════ */

/* Eyebrow label — used in page-hero, sections, CTA */
.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-3);
}

.eyebrow--light {
  color: rgba(239, 229, 219, 0.75);
}

.page-hero {
  background-color: var(--color-sand);
  padding-block: clamp(var(--space-10), 5vw, var(--space-20));
  border-bottom: 1px solid var(--color-border);
}

.page-hero__title {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  margin-top: var(--space-2);
  margin-bottom: 0;
  max-width: 18ch;
}

.page-hero__subtitle {
  font-size: var(--text-md);
  color: var(--color-text-light);
  margin-top: var(--space-4);
  max-width: 55ch;
}

/* Projects intro section */
.projects-intro {
  background: var(--color-white);
  padding-block: clamp(var(--space-12), 5vw, var(--space-20));
  border-bottom: 1px solid var(--color-border);
  text-align: center;
}

.projects-intro__inner {
  max-width: 640px;
  margin-inline: auto;
}

.projects-intro__heading {
  font-size: clamp(var(--text-xl), 3vw, var(--text-3xl));
  margin-top: 0;
  margin-bottom: var(--space-4);
}

.projects-intro__text {
  font-size: var(--text-md);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
  margin: 0;
}

/* Page content area */
.page-content {
  padding-block: clamp(var(--space-10), 5vw, var(--space-16));
}

.page-content--full-width { padding-block: 0; }


/* ═══════════════════════════════════════════════════════════════
   14. PROJECT TEMPLATES
   ═══════════════════════════════════════════════════════════════ */

/* Single project hero image */
.project-hero {
  aspect-ratio: 21/9;
  overflow: hidden;
  background: var(--color-sand);
}

.project-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-header {
  padding-block: var(--space-10);
  border-bottom: 1px solid var(--color-border);
}

.project-types { margin-bottom: var(--space-3); }

.project-title { margin-block: var(--space-3) var(--space-6); }

/* Project meta definition list */
.project-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}

.project-meta__item { }

.project-meta__item dt {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.project-meta__item dd {
  font-size: var(--text-sm);
  color: var(--color-charcoal);
}

/* Gallery grid */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
  gap: var(--space-3);
}

.gallery-item { aspect-ratio: 4/3; overflow: hidden; border-radius: var(--radius-md); }

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.gallery-item:hover img { transform: scale(1.04); }

.project-content { padding-block: var(--space-12); }

/* Related projects */
.related-projects { margin-top: 0; }

.related-projects .section-title { margin-bottom: var(--space-8); }

.related-projects__cta {
  text-align: center;
  margin-top: var(--space-10);
}

@media (max-width: 768px) {
  .project-hero { aspect-ratio: 4/3; }
  .project-meta { flex-direction: column; gap: var(--space-4); }
}


/* ═══════════════════════════════════════════════════════════════
   15. BLOG TEMPLATES
   ═══════════════════════════════════════════════════════════════ */

/* Single post */
.single-post { }

.post-header {
  padding-block: var(--space-10);
  border-bottom: 1px solid var(--color-border);
}

.post-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.post-meta__cat {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-accent);
  text-decoration: none;
}

.post-meta__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.post-title {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  margin-bottom: var(--space-6);
}

.post-hero-image {
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-top: var(--space-8);
}

.post-hero-image img { width: 100%; }

.post-content { padding-block: var(--space-12); }

.post-footer { padding-block: var(--space-8); border-top: 1px solid var(--color-border); }

.post-tags { display: flex; flex-wrap: wrap; gap: var(--space-2); }

/* Archive layout */
.archive-layout { padding-block: var(--space-10); }


/* ═══════════════════════════════════════════════════════════════
   16. CONTACT PAGE
   ═══════════════════════════════════════════════════════════════ */

.contact-layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-12);
  align-items: start;
}

.contact-details {
  background: var(--color-sand);
  border-radius: var(--radius-md);
  padding: var(--space-8);
}

.contact-details__title {
  font-size: var(--text-xl);
  margin-bottom: var(--space-6);
}

.contact-details__item {
  margin-bottom: var(--space-5);
}

.contact-details__item strong {
  display: block;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-charcoal);
  margin-bottom: var(--space-1);
}

.contact-details__item a {
  color: var(--color-accent);
  text-decoration: none;
}

.contact-details__item a:hover { text-decoration: underline; }

@media (max-width: 900px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }
}

/* Contact form */
.contact-form__intro {
  margin-bottom: var(--space-6);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.contact-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

@media (max-width: 640px) {
  .contact-form__row { grid-template-columns: 1fr; }
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.contact-form__field label {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-charcoal);
  letter-spacing: 0.01em;
}

.contact-form__required {
  color: var(--color-accent);
  margin-left: 2px;
}

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text);
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-form input[type="text"]:focus,
.contact-form input[type="email"]:focus,
.contact-form input[type="tel"]:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--color-timber);
  box-shadow: 0 0 0 3px rgba(139, 110, 82, 0.15);
}

.contact-form textarea {
  resize: vertical;
  min-height: 140px;
  font-family: var(--font-body);
}

.contact-form input[aria-invalid="true"],
.contact-form textarea[aria-invalid="true"] {
  border-color: #B33A3A;
  background-color: #FBF3F3;
}

.contact-form__error {
  font-size: 14px;
  color: #B33A3A;
  margin: 0;
}

.contact-form__alert {
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-5);
  font-size: 15px;
  line-height: 1.5;
}

.contact-form__alert--success {
  background-color: #E8F0E5;
  border: 1px solid #B7CFAA;
  color: #2F5524;
}

.contact-form__alert--success p { margin: var(--space-1) 0 0; }

.contact-form__alert--error {
  background-color: #FBF3F3;
  border: 1px solid #E1B6B6;
  color: #7A2A2A;
}

.contact-form__actions {
  margin-top: var(--space-2);
}

.contact-form__submit { min-width: 180px; }

/* Honeypot — visually hidden, accessible to nothing useful */
.contact-form__honeypot {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* Thank You page */
.thank-you {
  padding-block: clamp(var(--space-16), 10vw, var(--space-32));
  text-align: center;
}

.thank-you__inner {
  max-width: 640px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.thank-you__icon {
  color: var(--color-timber);
  display: flex;
  align-items: center;
  justify-content: center;
}

.thank-you__title {
  font-family: var(--font-heading);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 700;
  color: var(--color-charcoal);
  margin: 0;
  line-height: 1.15;
}

.thank-you__message {
  font-size: 18px;
  line-height: 1.6;
  color: var(--color-text-light);
  margin: 0;
  max-width: 520px;
}

.thank-you__contact {
  list-style: none;
  padding: 0;
  margin: var(--space-2) 0 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-6);
}

.thank-you__contact li {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.thank-you__contact-label {
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}

.thank-you__contact a {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 600;
  color: var(--color-timber);
}

.thank-you__contact a:hover { color: var(--color-accent-dark); }

.thank-you__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
  margin-top: var(--space-6);
}


/* ═══════════════════════════════════════════════════════════════
   17. BREADCRUMBS
   ═══════════════════════════════════════════════════════════════ */

.breadcrumbs {
  margin-bottom: var(--space-4);
}

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

.breadcrumbs__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-charcoal);
}

.breadcrumbs__item a {
  color: var(--color-charcoal);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  text-decoration-color: rgba(74, 67, 61, 0.3);
  transition: color var(--transition-fast), text-decoration-color var(--transition-fast);
}

.breadcrumbs__item a:hover {
  color: var(--color-accent);
  text-decoration-color: currentColor;
}

.breadcrumbs__item--current { color: var(--color-charcoal); font-weight: 600; }

.breadcrumbs__sep {
  color: var(--color-charcoal);
  opacity: 0.5;
  font-size: var(--text-xs);
}

/* Rank Math / Yoast breadcrumbs */
.rank-math-breadcrumb,
#breadcrumbs {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  margin-bottom: var(--space-4);
}


/* ═══════════════════════════════════════════════════════════════
   18. FAQ ACCORDION
   ═══════════════════════════════════════════════════════════════ */

.faq-item {
  border-bottom: 1px solid var(--color-border);
}

.faq-item:first-child { border-top: 1px solid var(--color-border); }

.faq-item__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-5) 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: 500;
  color: var(--color-charcoal);
  gap: var(--space-4);
  transition: color var(--transition-fast);
}

.faq-item__question:hover { color: var(--color-accent); }

.faq-item__icon {
  flex-shrink: 0;
  transition: transform var(--transition-base);
  color: var(--color-accent);
}

.faq-item.is-open .faq-item__icon { transform: rotate(180deg); }

.faq-item__answer { background: var(--color-white); }

.faq-item__answer[hidden] { display: none; }

.faq-item__answer-inner {
  padding: 0 0 var(--space-6) 0;
  font-size: var(--text-base);
  color: var(--color-text-light);
  line-height: var(--leading-relaxed);
}

.faq-item__answer-inner p:last-child { margin-bottom: 0; }


/* ═══════════════════════════════════════════════════════════════
   19. WHATSAPP FLOAT BUTTON
   ═══════════════════════════════════════════════════════════════ */

.whatsapp-float {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-float);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background-color: #25D366;
  color: var(--color-white);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
  text-decoration: none;
  opacity: 0;
  visibility: hidden;
  transform: scale(0.8) translateY(8px);
  transition:
    opacity var(--transition-base),
    visibility var(--transition-base),
    transform var(--transition-base),
    background-color var(--transition-fast);
}

.whatsapp-float.is-visible {
  opacity: 1;
  visibility: visible;
  transform: scale(1) translateY(0);
}

.whatsapp-float:hover {
  background-color: #128C7E;
  color: var(--color-white);
  transform: scale(1.05);
}


/* ═══════════════════════════════════════════════════════════════
   20. PAGINATION
   ═══════════════════════════════════════════════════════════════ */

.pagination { margin-top: var(--space-12); }

.nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.nav-links .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding-inline: var(--space-3);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  color: var(--color-charcoal);
  text-decoration: none;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.nav-links .page-numbers:hover,
.nav-links .page-numbers.current {
  background: var(--color-timber);
  border-color: var(--color-timber);
  color: var(--color-white);
}

/* Search / archive result count */
.search-count {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
}

.search-results { display: flex; flex-direction: column; gap: var(--space-6); }

.search-result { padding-bottom: var(--space-6); border-bottom: 1px solid var(--color-border); }

.search-result__title { font-size: var(--text-lg); margin-bottom: var(--space-2); }

.search-result__title a { color: var(--color-charcoal); text-decoration: none; }
.search-result__title a:hover { color: var(--color-accent); }

.search-result__excerpt { font-size: var(--text-sm); color: var(--color-text-light); }

.search-result__link { font-size: var(--text-xs); color: var(--color-text-muted); }


/* ═══════════════════════════════════════════════════════════════
   21. UTILITY CLASSES
   ═══════════════════════════════════════════════════════════════ */

/* Text alignment */
.text-left    { text-align: left; }
.text-center  { text-align: center; }
.text-right   { text-align: right; }

/* Text colours */
.text-accent  { color: var(--color-accent); }
.text-muted   { color: var(--color-text-muted); }
.text-light   { color: var(--color-text-light); }
.text-cream   { color: var(--color-cream); }
.text-white   { color: var(--color-white); }

/* Font sizes */
.text-sm   { font-size: var(--text-sm); }
.text-lg   { font-size: var(--text-lg); }
.text-xl   { font-size: var(--text-xl); }

/* Display */
.d-none    { display: none; }
.d-block   { display: block; }
.d-flex    { display: flex; }
.d-grid    { display: grid; }

/* Spacing helpers */
.mt-0  { margin-top: 0; }
.mb-0  { margin-bottom: 0; }
.mt-4  { margin-top: var(--space-4); }
.mb-4  { margin-bottom: var(--space-4); }
.mt-8  { margin-top: var(--space-8); }
.mb-8  { margin-bottom: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mb-12 { margin-bottom: var(--space-12); }

/* 404 / No results */
.error-404, .no-results {
  padding-block: var(--space-20);
  text-align: center;
}

.error-404__title, .no-results__title {
  margin-bottom: var(--space-4);
}

.error-404__message {
  font-size: var(--text-md);
  color: var(--color-text-light);
  margin-bottom: var(--space-8);
}

.error-404__actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-12);
}

.error-404__search {
  max-width: 400px;
  margin-inline: auto;
}

.error-404__search p {
  margin-bottom: var(--space-4);
  color: var(--color-text-light);
  max-width: none;
}

/* Widget */
.widget { margin-bottom: var(--space-8); }
.widget-title { font-size: var(--text-lg); margin-bottom: var(--space-4); }


/* ═══════════════════════════════════════════════════════════════
   22. ACCESSIBILITY
   ═══════════════════════════════════════════════════════════════ */

/* Skip link */
.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 9999;
  padding: var(--space-3) var(--space-6);
  background: var(--color-charcoal);
  color: var(--color-white);
  font-weight: 600;
  text-decoration: none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}

.skip-link:focus {
  left: var(--space-4);
  top: 0;
}

/* Screen reader text */
.screen-reader-text,
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Focus ring for keyboard navigation */
*:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

/* Ensure BB canvas pages don't show focus on click */
.site-main:focus { outline: none; }


/* ═══════════════════════════════════════════════════════════════
   23. PRINT
   ═══════════════════════════════════════════════════════════════ */

@media print {
  .site-header,
  .site-footer,
  .whatsapp-float,
  .nav-toggle,
  .btn,
  .pagination {
    display: none !important;
  }

  body {
    font-size: 12pt;
    color: #000;
    background: #fff;
  }

  a { color: inherit; text-decoration: underline; }

  h1, h2, h3 { page-break-after: avoid; }

  img { max-width: 100% !important; }
}
