/*
Theme Name: Matrix Giant
Theme URI: https://matrixgiant.com
Author: Matrix Giant
Author URI: https://matrixgiant.com
Description: Custom WordPress theme for Matrix Giant — web, app, and AI development for service businesses across Canada and the United States. Built with a network/grid signature motif, Space Grotesk + IBM Plex typography, and a dual amber/mint accent system.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.6
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: matrix-giant
*/

/* ===================================================================
   MATRIX GIANT — DESIGN SYSTEM (ported from static build)
   =================================================================== */
/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,600;1,400&family=IBM+Plex+Mono:wght@500;600&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* Core palette */
  --ink:        #161D2E;   /* primary dark / headings on light */
  --ink-2:      #222B42;   /* secondary dark / gradients on dark sections */
  --ink-3:      #2C3654;   /* tertiary dark / card surfaces on dark */
  --paper:      #F0EEE7;   /* page background */
  --cream:      #FAF9F4;   /* card surface on light */
  --white:      #FFFFFF;

  --slate:      #5B6275;   /* secondary text on light */
  --slate-soft: #8A8FA0;   /* tertiary text / placeholders */
  --line:       #DEDAD0;   /* hairline borders on light */
  --line-dark:  rgba(255,255,255,0.12); /* hairline borders on dark */

  --amber:      #DE8C2E;   /* primary accent — service/build */
  --amber-dark: #B8701F;
  --amber-tint: #FBEDD9;

  --mint:       #1F9E8B;   /* secondary accent — AI / automation */
  --mint-dark:  #167766;
  --mint-tint:  #DFF1EC;

  --danger:     #C2452F;

  /* Type */
  --font-display: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif;
  --font-body:    'IBM Plex Sans', 'Helvetica Neue', Arial, sans-serif;
  --font-mono:    'IBM Plex Mono', 'Courier New', monospace;

  /* Scale */
  --fs-hero: clamp(2.5rem, 1.7rem + 3.6vw, 4.6rem);
  --fs-h1:   clamp(2.1rem, 1.5rem + 2.4vw, 3.2rem);
  --fs-h2:   clamp(1.65rem, 1.3rem + 1.4vw, 2.3rem);
  --fs-h3:   clamp(1.25rem, 1.1rem + 0.6vw, 1.55rem);
  --fs-lead: clamp(1.05rem, 0.95rem + 0.3vw, 1.25rem);
  --fs-body: 1rem;
  --fs-sm:   0.875rem;
  --fs-xs:   0.78rem;

  /* Layout */
  --container: 1220px;
  --container-narrow: 820px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 18px;
  --radius-pill: 999px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --section-pad: clamp(3.5rem, 4vw + 1.5rem, 6.5rem);

  --shadow-card: 0 1px 2px rgba(22,29,46,0.04), 0 8px 24px -8px rgba(22,29,46,0.10);
  --shadow-card-hover: 0 4px 8px rgba(22,29,46,0.06), 0 18px 36px -12px rgba(22,29,46,0.16);
  --shadow-pop: 0 20px 60px -16px rgba(22,29,46,0.35);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;scroll-behavior:auto !important;}
}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  font-size:var(--fs-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit;}
input,textarea,select{font:inherit;color:inherit;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.12;letter-spacing:-0.01em;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
:focus-visible{outline:2.5px solid var(--amber);outline-offset:3px;border-radius:2px;}

/* ---------- Layout helpers ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.container-narrow{
  width:100%;
  max-width:var(--container-narrow);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{padding:var(--section-pad) 0;}
.section-tight{padding:calc(var(--section-pad)*0.55) 0;}
.section--dark{background:var(--ink);color:var(--white);}
.section--paper{background:var(--paper);}
.section--cream{background:var(--cream);}
.section--line-top{border-top:1px solid var(--line);}
.section--line-top.on-dark{border-top:1px solid var(--line-dark);}

.grid{display:grid;gap:var(--gutter);}
.g-2{grid-template-columns:repeat(2,1fr);}
.g-3{grid-template-columns:repeat(3,1fr);}
.g-4{grid-template-columns:repeat(4,1fr);}
.g-6{grid-template-columns:repeat(6,1fr);}
@media (max-width:980px){
  .g-3{grid-template-columns:repeat(2,1fr);}
  .g-4{grid-template-columns:repeat(2,1fr);}
  .g-6{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:640px){
  .g-2,.g-3,.g-4{grid-template-columns:1fr;}
  .g-6{grid-template-columns:repeat(2,1fr);}
}

.flex{display:flex;}
.flex-center{display:flex;align-items:center;}
.flex-between{display:flex;align-items:center;justify-content:space-between;}
.flex-wrap{flex-wrap:wrap;}
.gap-xs{gap:.5rem;}
.gap-sm{gap:.85rem;}
.gap-md{gap:1.5rem;}
.gap-lg{gap:2.5rem;}

/* ---------- Typography ---------- */
.h1{font-size:var(--fs-h1);}
.h2{font-size:var(--fs-h2);}
.h3{font-size:var(--fs-h3);}
.lead{font-size:var(--fs-lead);color:var(--slate);line-height:1.55;font-weight:400;}
.section--dark .lead{color:#B7BCCC;}
p{max-width:68ch;}
.measure-wide{max-width:none;}
.text-center{text-align:center;}
.text-center p{margin-inline:auto;}
.muted{color:var(--slate);}
.section--dark .muted{color:#9DA3B6;}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  font-weight:500;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--amber-dark);
  margin-bottom:1rem;
}
.section--dark .eyebrow{color:var(--amber);}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--amber);flex-shrink:0;}
.eyebrow.mint{color:var(--mint-dark);}
.eyebrow.mint::before{background:var(--mint);}
.section--dark .eyebrow.mint{color:var(--mint);}

.section-head{max-width:640px;margin-bottom:clamp(2rem,4vw,3.25rem);}
.section-head.text-center{margin-inline:auto;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  font-family:var(--font-body);
  font-weight:600;
  font-size:0.95rem;
  padding:0.85rem 1.5rem;
  border-radius:var(--radius-sm);
  transition:transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease);
  white-space:nowrap;
  border:1.5px solid transparent;
  line-height:1.2;
}
.btn svg{width:16px;height:16px;flex-shrink:0;transition:transform .2s var(--ease);}
.btn:hover svg{transform:translateX(3px);}
.btn-primary{background:var(--amber);color:var(--ink);}
.btn-primary:hover{background:var(--amber-dark);color:var(--white);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(222,140,46,0.55);}
.btn-dark{background:var(--ink);color:var(--white);}
.btn-dark:hover{background:#0D1220;transform:translateY(-1px);box-shadow:0 10px 24px -10px rgba(0,0,0,0.45);}
.btn-ghost-light{border-color:rgba(255,255,255,0.35);color:var(--white);}
.btn-ghost-light:hover{border-color:var(--white);background:rgba(255,255,255,0.08);}
.btn-ghost-dark{border-color:var(--line);color:var(--ink);}
.btn-ghost-dark:hover{border-color:var(--ink);background:var(--ink);color:var(--white);}
.btn-mint{background:var(--mint);color:var(--white);}
.btn-mint:hover{background:var(--mint-dark);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(31,158,139,0.45);}
.btn-block{width:100%;}
.btn-lg{padding:1.05rem 2rem;font-size:1.02rem;}
.btn-sm{padding:.6rem 1.05rem;font-size:.85rem;}

.text-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-weight:600;font-size:.95rem;color:var(--ink);
  border-bottom:1.5px solid var(--amber);padding-bottom:2px;
  transition:gap .18s var(--ease), color .18s var(--ease);
}
.text-link:hover{gap:.65rem;color:var(--amber-dark);}
.text-link svg{width:14px;height:14px;}
.section--dark .text-link{color:var(--white);border-color:var(--amber);}

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease);
}
.site-header::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:rgba(240,238,231,0.88);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  transition:background .25s var(--ease);
}
.site-header.is-scrolled{border-bottom-color:var(--line);}
.site-header.is-scrolled::before{background:rgba(240,238,231,0.97);}
.nav-row{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
}
.brand{display:flex;align-items:center;gap:.65rem;font-family:var(--font-display);font-weight:700;font-size:1.18rem;letter-spacing:-0.01em;color:var(--ink);}
.brand-mark{width:30px;height:30px;flex-shrink:0;}
.nav-links{display:flex;align-items:center;gap:2.1rem;}
.nav-links a{
  font-size:.92rem;font-weight:500;color:var(--ink);position:relative;padding:.3rem 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--amber);
  transition:width .22s var(--ease);
}
.nav-links a:hover::after,.nav-links a.is-active::after{width:100%;}
.nav-links a.is-active{color:var(--amber-dark);}
.nav-cta{display:flex;align-items:center;gap:1.4rem;}
.nav-mobile-cta{display:none;}
.nav-phone{display:flex;align-items:center;gap:.45rem;font-size:.85rem;font-weight:600;color:var(--ink);}
.nav-phone svg{width:15px;height:15px;color:var(--amber);}
.nav-toggle{display:none;width:42px;height:42px;align-items:center;justify-content:center;border-radius:var(--radius-sm);}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);position:relative;transition:background .2s;}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);transition:transform .25s var(--ease), top .25s var(--ease);}
.nav-toggle span::before{top:-6px;}
.nav-toggle span::after{top:6px;}
.nav-toggle.is-open span{background:transparent;}
.nav-toggle.is-open span::before{top:0;transform:rotate(45deg);}
.nav-toggle.is-open span::after{top:0;transform:rotate(-45deg);}

@media (max-width:980px){
  .nav-links{
    position:fixed;top:78px;left:0;right:0;bottom:0;
    background:var(--paper);
    flex-direction:column;align-items:flex-start;gap:0;
    padding:1.5rem var(--gutter) 2rem;
    transform:translateY(-8px);opacity:0;visibility:hidden;
    transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s;
    overflow-y:auto;
  }
  .nav-links.is-open{opacity:1;visibility:visible;transform:translateY(0);}
  .nav-links a{width:100%;padding:1rem 0;border-bottom:1px solid var(--line);font-size:1.05rem;}
  .nav-links a::after{display:none;}
  .nav-phone{display:none;}
  .nav-cta > a.btn-primary{display:none;}
  .nav-toggle{display:flex;}
  .nav-mobile-cta{display:flex !important;width:100%;justify-content:center;margin-top:1.5rem;}
  .brand{white-space:nowrap;font-size:1.05rem;}
}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:calc(78px + var(--section-pad));padding-bottom:var(--section-pad);overflow:hidden;}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(2rem,5vw,4rem);align-items:center;
}
.hero-copy h1{margin-bottom:1.3rem;}
.hero-copy .lead{margin-bottom:2.1rem;max-width:46ch;}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem;}
.hero-trust{display:flex;flex-wrap:wrap;gap:.5rem 1.6rem;align-items:center;}
.hero-trust-item{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--slate);font-weight:500;}
.hero-trust-item svg{width:15px;height:15px;color:var(--mint-dark);flex-shrink:0;}

.dot-field{
  position:absolute;inset:0;
  background-image:radial-gradient(var(--line) 1px, transparent 1px);
  background-size:26px 26px;
  opacity:0.55;
  mask-image:linear-gradient(to bottom, transparent, black 12%, black 75%, transparent);
  pointer-events:none;
}
.section--dark .dot-field{background-image:radial-gradient(rgba(255,255,255,0.14) 1px, transparent 1px);}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-visual{order:-1;max-width:420px;margin:0 auto 1rem;}
}

/* ---------- Network diagram (signature element) ---------- */
.network-wrap{position:relative;}
.network-svg{width:100%;height:auto;overflow:visible;}
.node-pulse{animation:nodePulse 2.8s ease-in-out infinite;}
.node-pulse-b{animation-delay:.3s;}
.node-pulse-c{animation-delay:.6s;}
.node-pulse-d{animation-delay:.9s;}
.node-pulse-e{animation-delay:1.2s;}
.node-pulse-f{animation-delay:1.5s;}
@keyframes nodePulse{
  0%,100%{opacity:.5;}
  50%{opacity:1;}
}
/* Flowing data dots — each travels from the centre node to one industry node.
   Distances below correspond to a 600x600 viewBox, centre at (300,300). */
.flow-dot{animation-duration:3.2s;animation-timing-function:ease-in-out;animation-iteration-count:infinite;opacity:0;}
.flow-1{animation-name:flowTop;animation-delay:0s;}
.flow-2{animation-name:flowTopRight;animation-delay:.55s;}
.flow-3{animation-name:flowBottomRight;animation-delay:1.1s;}
.flow-4{animation-name:flowBottom;animation-delay:1.65s;}
.flow-5{animation-name:flowBottomLeft;animation-delay:2.2s;}
.flow-6{animation-name:flowTopLeft;animation-delay:2.75s;}
@keyframes flowTop{0%{transform:translate(0,0);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translate(0,-228px);opacity:0;}}
@keyframes flowTopRight{0%{transform:translate(0,0);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translate(197px,-114px);opacity:0;}}
@keyframes flowBottomRight{0%{transform:translate(0,0);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translate(197px,114px);opacity:0;}}
@keyframes flowBottom{0%{transform:translate(0,0);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translate(0,228px);opacity:0;}}
@keyframes flowBottomLeft{0%{transform:translate(0,0);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translate(-197px,114px);opacity:0;}}
@keyframes flowTopLeft{0%{transform:translate(0,0);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translate(-197px,-114px);opacity:0;}}
@media (prefers-reduced-motion: reduce){
  .node-pulse,.flow-dot{animation:none !important;opacity:0;}
}

/* ---------- Stat / trust strip ---------- */
.stat-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream);}
.stat-strip-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2rem;padding:2.4rem 0;}
.stat-item{flex:1;min-width:150px;}
.stat-num{font-family:var(--font-display);font-size:clamp(1.7rem,1.3rem+1.4vw,2.5rem);font-weight:700;color:var(--ink);display:flex;align-items:baseline;gap:.15rem;}
.stat-num span.unit{font-size:0.55em;color:var(--amber-dark);}
.stat-label{font-size:.85rem;color:var(--slate);margin-top:.35rem;max-width:20ch;}

/* ---------- Cards ---------- */
.card{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(1.5rem,2vw,2.1rem);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:#CFCABC;}
.card-icon{
  width:52px;height:52px;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  background:var(--amber-tint);color:var(--amber-dark);
  margin-bottom:1.3rem;
}
.card-icon svg{width:26px;height:26px;}
.card-icon.mint{background:var(--mint-tint);color:var(--mint-dark);}
.card h3{margin-bottom:.65rem;font-size:1.18rem;}
.card p{font-size:.94rem;color:var(--slate);margin-bottom:1rem;}
.card-link{font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem;color:var(--ink);}
.card-link svg{width:13px;height:13px;transition:transform .2s var(--ease);}
.card:hover .card-link svg{transform:translateX(3px);}

.card-tag{
  display:inline-block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em;
  padding:.25rem .55rem;border-radius:4px;background:var(--ink);color:var(--white);margin-bottom:.9rem;
}
.card-tag.new{background:var(--mint);}

/* Service block (full detail on services page) */
.service-block{padding:clamp(2.5rem,5vw,4.5rem) 0;border-top:1px solid var(--line);}
.service-block:first-of-type{border-top:none;}
.service-block-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(2rem,4vw,4rem);}
@media (max-width:900px){.service-block-grid{grid-template-columns:1fr;}}
.service-meta-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem;}
.service-meta-item{display:flex;gap:.85rem;align-items:flex-start;}
.service-meta-item svg{width:18px;height:18px;color:var(--amber-dark);flex-shrink:0;margin-top:3px;}
.included-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1.5rem;margin:1.5rem 0 2rem;}
@media (max-width:560px){.included-grid{grid-template-columns:1fr;}}
.included-item{display:flex;gap:.65rem;align-items:flex-start;font-size:.93rem;}
.included-item svg{width:16px;height:16px;color:var(--mint-dark);flex-shrink:0;margin-top:3px;}

/* ---------- Industry node cards ---------- */
.industry-card{
  position:relative;background:var(--ink);color:var(--white);
  border-radius:var(--radius-lg);padding:2rem 1.8rem;overflow:hidden;
  transition:transform .25s var(--ease);
}
.industry-card:hover{transform:translateY(-4px);}
.industry-card::before{
  content:"";position:absolute;top:-30%;right:-30%;width:70%;height:70%;
  background:radial-gradient(circle, var(--amber) 0%, transparent 70%);opacity:.18;
}
.industry-card .ic-icon{width:46px;height:46px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;position:relative;z-index:1;}
.industry-card .ic-icon svg{width:24px;height:24px;color:var(--amber);}
.industry-card h3{font-size:1.1rem;margin-bottom:.5rem;position:relative;z-index:1;}
.industry-card p{font-size:.88rem;color:#AEB3C4;position:relative;z-index:1;margin-bottom:0;}

/* ---------- Process steps ---------- */
.process-rail{position:relative;}
.process-step{
  display:grid;grid-template-columns:90px 1fr;gap:1.5rem;padding-bottom:2.75rem;position:relative;
}
.process-step:last-child{padding-bottom:0;}
.process-step::before{
  content:"";position:absolute;left:44px;top:60px;bottom:0;width:1px;background:var(--line);
}
.process-step:last-child::before{display:none;}
.process-num{
  font-family:var(--font-mono);font-size:.95rem;color:var(--amber-dark);font-weight:600;
  width:90px;height:46px;border-radius:var(--radius-sm);background:var(--cream);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.process-content h3{margin-bottom:.5rem;}
.process-content p{color:var(--slate);font-size:.94rem;margin-bottom:.85rem;}
.process-content .duration{font-family:var(--font-mono);font-size:.75rem;color:var(--mint-dark);background:var(--mint-tint);padding:.25rem .6rem;border-radius:4px;display:inline-block;}

/* ---------- Testimonials ---------- */
.testimonial-card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem;display:flex;flex-direction:column;height:100%;
}
.testimonial-stars{display:flex;gap:3px;margin-bottom:1.1rem;}
.testimonial-stars svg{width:15px;height:15px;color:var(--amber);}
.testimonial-quote{font-size:.98rem;line-height:1.65;color:var(--ink);margin-bottom:1.4rem;flex-grow:1;}
.testimonial-by{display:flex;align-items:center;gap:.75rem;border-top:1px solid var(--line);padding-top:1.1rem;}
.testimonial-avatar{
  width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--white);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:.85rem;flex-shrink:0;
}
.testimonial-name{font-weight:600;font-size:.88rem;}
.testimonial-co{font-size:.78rem;color:var(--slate);}

/* ---------- FAQ Accordion ---------- */
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  width:100%;padding:1.4rem 0;text-align:left;font-family:var(--font-display);font-weight:600;font-size:1.02rem;
}
.faq-q .plus{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);flex-shrink:0;position:relative;
  transition:transform .25s var(--ease), border-color .25s var(--ease);
}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--ink);transition:transform .25s var(--ease);}
.faq-q .plus::before{left:7px;right:7px;top:50%;height:1.6px;transform:translateY(-50%);}
.faq-q .plus::after{top:7px;bottom:7px;left:50%;width:1.6px;transform:translateX(-50%);}
.faq-item.is-open .plus{border-color:var(--amber);transform:rotate(180deg);}
.faq-item.is-open .plus::after{transform:translateX(-50%) scaleY(0);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease);}
.faq-a-inner{padding-bottom:1.5rem;color:var(--slate);font-size:.95rem;max-width:62ch;}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;}
@media (max-width:640px){.form-grid{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;}
.field.full{grid-column:1 / -1;}
.field label{font-size:.85rem;font-weight:600;color:var(--ink);}
.field .opt{color:var(--slate-soft);font-weight:400;}
.field input,.field select,.field textarea{
  background:var(--white);
  border:1.5px solid var(--line);
  border-radius:var(--radius-sm);
  padding:.85rem 1rem;
  font-size:.95rem;
  color:var(--ink);
  transition:border-color .18s var(--ease), box-shadow .18s var(--ease);
  width:100%;
}
.field input::placeholder,.field textarea::placeholder{color:var(--slate-soft);}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--ink);box-shadow:0 0 0 4px rgba(22,29,46,0.08);
}
.field textarea{resize:vertical;min-height:130px;}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:var(--danger);}
.field-error{font-size:.78rem;color:var(--danger);display:none;}
.field.has-error .field-error{display:block;}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%235B6275' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;}
.checkbox-row{display:flex;align-items:flex-start;gap:.65rem;font-size:.85rem;color:var(--slate);}
.checkbox-row input{width:17px;height:17px;margin-top:2px;accent-color:var(--ink);flex-shrink:0;}
.form-status{display:none;padding:.95rem 1.1rem;border-radius:var(--radius-sm);font-size:.9rem;margin-top:1rem;}
.form-status.is-success{display:block;background:var(--mint-tint);color:var(--mint-dark);border:1px solid var(--mint);}
.form-status.is-error{display:block;background:#FBE7E2;color:var(--danger);border:1px solid var(--danger);}
.honeypot{position:absolute;left:-9999px;top:-9999px;opacity:0;height:0;width:0;}

.form-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.75rem,3vw,2.75rem);}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#C9CCD8;padding:clamp(3.5rem,5vw,5.5rem) 0 0;}
.footer-top{display:grid;grid-template-columns:1.4fr 0.85fr 0.85fr 1.1fr;gap:2.5rem;padding-bottom:3rem;}
@media (max-width:900px){.footer-top{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-top{grid-template-columns:1fr;}}
.footer-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--white);margin-bottom:1rem;}
.footer-brand svg{width:28px;height:28px;}
.footer-about{font-size:.9rem;color:#9DA3B6;max-width:30ch;margin-bottom:1.4rem;}
.footer-social{display:flex;gap:.7rem;}
.footer-social a{width:36px;height:36px;border-radius:50%;border:1px solid var(--line-dark);display:flex;align-items:center;justify-content:center;transition:background .18s var(--ease), border-color .18s var(--ease);}
.footer-social a:hover{background:var(--amber);border-color:var(--amber);}
.footer-social svg{width:16px;height:16px;}
.footer-col h4{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:#9DA3B6;font-weight:500;margin-bottom:1.2rem;}
.footer-col ul{display:flex;flex-direction:column;gap:.75rem;}
.footer-col a{font-size:.92rem;color:#C9CCD8;transition:color .18s var(--ease);}
.footer-col a:hover{color:var(--amber);}
.footer-contact-item{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;margin-bottom:.9rem;}
.footer-contact-item svg{width:16px;height:16px;color:var(--amber);flex-shrink:0;margin-top:3px;}
.footer-bottom{
  border-top:1px solid var(--line-dark);padding:1.6rem 0 2rem;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  font-size:.82rem;color:#8A8FA0;
}
.footer-bottom-links{display:flex;gap:1.5rem;}
.footer-bottom-links a{color:#8A8FA0;}
.footer-bottom-links a:hover{color:var(--white);}
.footer-badges{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.2rem;}
.footer-badge{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:#9DA3B6;background:rgba(255,255,255,0.05);border:1px solid var(--line-dark);padding:.45rem .8rem;border-radius:var(--radius-pill);}
.footer-badge svg{width:14px;height:14px;color:var(--mint);}

/* ---------- Breadcrumb / page hero (sub-pages) ---------- */
.page-hero{padding-top:calc(78px + var(--section-pad)*0.85);padding-bottom:calc(var(--section-pad)*0.85);position:relative;overflow:hidden;}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--slate);margin-bottom:1.4rem;font-family:var(--font-mono);}
.section--dark .breadcrumb{color:#9DA3B6;}
.breadcrumb a:hover{color:var(--amber-dark);}
.breadcrumb svg{width:11px;height:11px;}

/* ---------- CTA banners ---------- */
.cta-banner{
  border-radius:var(--radius-lg);padding:clamp(2.25rem,4vw,3.75rem);position:relative;overflow:hidden;
  background:var(--ink);color:var(--white);
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.09) 1px, transparent 1px);
  background-size:22px 22px;
  mask-image:radial-gradient(circle at top right, black, transparent 70%);
}
.cta-banner-inner{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;}
.cta-banner h2{margin-bottom:.6rem;max-width:30ch;}
.cta-banner p{color:#B7BCCC;max-width:48ch;margin-bottom:0;}
.cta-banner-actions{display:flex;gap:1rem;flex-wrap:wrap;flex-shrink:0;}

/* ---------- Logo cloud / industries strip (text-based, no fake logos) ---------- */
.industry-strip{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;}
.industry-chip{
  font-size:.82rem;font-weight:600;padding:.55rem 1.1rem;border-radius:var(--radius-pill);
  border:1px solid var(--line);color:var(--slate);background:var(--cream);
}

/* ---------- Blog ---------- */
.blog-card{display:flex;flex-direction:column;height:100%;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .25s var(--ease), box-shadow .25s var(--ease);}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);}
.blog-card-top{padding:2rem 1.8rem 0;}
.blog-card-body{padding:1.2rem 1.8rem 1.8rem;display:flex;flex-direction:column;flex-grow:1;}
.blog-cat{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--amber-dark);margin-bottom:.85rem;display:block;}
.blog-card h3{font-size:1.12rem;margin-bottom:.7rem;line-height:1.32;}
.blog-card p{font-size:.9rem;color:var(--slate);margin-bottom:1.2rem;flex-grow:1;}
.blog-meta{display:flex;align-items:center;gap:.6rem;font-size:.78rem;color:var(--slate-soft);padding-top:1rem;border-top:1px solid var(--line);}
.blog-meta svg{width:13px;height:13px;}

.article-body{max-width:680px;margin:0 auto;}
.article-body h2{font-size:var(--fs-h3);margin:2.4rem 0 1rem;}
.article-body h3{font-size:1.18rem;margin:1.8rem 0 .85rem;}
.article-body p{margin-bottom:1.3rem;line-height:1.75;font-size:1.04rem;color:var(--ink);}
.article-body ul{margin:1.3rem 0;display:flex;flex-direction:column;gap:.6rem;}
.article-body li{position:relative;padding-left:1.4rem;line-height:1.6;}
.article-body li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:1px;background:var(--amber);}
.article-body blockquote{border-left:3px solid var(--amber);padding:.3rem 0 .3rem 1.5rem;margin:2rem 0;font-family:var(--font-display);font-size:1.2rem;font-weight:500;color:var(--ink);}
.article-pullstat{display:flex;gap:1.5rem;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-md);padding:1.5rem;margin:2rem 0;}

/* ---------- Misc utility ---------- */
.divider{height:1px;background:var(--line);width:100%;}
.pill-tag{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;padding:.4rem .85rem;border-radius:var(--radius-pill);background:var(--amber-tint);color:var(--amber-dark);}
.pill-tag.mint{background:var(--mint-tint);color:var(--mint-dark);}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease), transform .6s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;}}

.center-col{display:flex;flex-direction:column;align-items:center;text-align:center;}
.mt-0{margin-top:0;}
.mb-0{margin-bottom:0;}
.mt-sm{margin-top:1rem;}
.mt-md{margin-top:1.75rem;}
.mt-lg{margin-top:2.75rem;}
.mb-sm{margin-bottom:1rem;}
.mb-md{margin-bottom:1.75rem;}
.mb-lg{margin-bottom:2.75rem;}

/* North America coverage map block */
.coverage-block{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;}
@media (max-width:900px){.coverage-block{grid-template-columns:1fr;}}
.coverage-list{display:flex;flex-direction:column;gap:1.1rem;}
.coverage-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.3rem;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-md);}
.coverage-row .flag{font-family:var(--font-mono);font-size:.78rem;color:var(--slate);}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:1rem;background:var(--ink);color:var(--white);padding:.75rem 1.25rem;border-radius:var(--radius-sm);z-index:200;}
.skip-link:focus{left:1rem;}

/* 404 / thank-you full screen */
.full-screen-msg{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;}

/* ===================================================================
   WORDPRESS-SPECIFIC ADDITIONS
   =================================================================== */

/* wp_nav_menu() wraps links in <ul><li> — collapse those from the
   flex layout so the <a> tags behave as direct flex children, exactly
   like the static build's flat <a> list. */
.nav-links ul{display:contents;}
.nav-links li{display:contents;}

/* WordPress applies "current-menu-item" / "current_page_item" to the
   <li>, not the <a> — map that to our existing active-link styling. */
.nav-links li.current-menu-item > a,
.nav-links li.current_page_item > a,
.nav-links li.current-menu-parent > a{
  color:var(--amber-dark);
}
.nav-links li.current-menu-item > a::after,
.nav-links li.current_page_item > a::after,
.nav-links li.current-menu-parent > a::after{
  width:100%;
}

/* Footer menus also use <ul><li> by default; keep the existing
   .footer-col ul / .footer-col a styling working without changes. */
.footer-col ul{display:flex;flex-direction:column;gap:.75rem;}

/* Keep the fixed header clear of the WP admin toolbar when logged in. */
body.admin-bar .site-header{top:32px;}
@media (max-width:782px){
  body.admin-bar .site-header{top:46px;}
}

/* Native WordPress alignment/caption helper classes, in case any
   editor-inserted content (e.g. on the fallback page.php) uses them. */
.alignleft{float:left;margin:0 1.5rem 1rem 0;}
.alignright{float:right;margin:0 0 1rem 1.5rem;}
.aligncenter{display:block;margin:0 auto 1.5rem;}
.wp-caption-text{font-size:.82rem;color:var(--slate);margin-top:.5rem;}
.screen-reader-text{position:absolute;left:-9999px;}

/* Featured image support on blog cards (optional progressive enhancement) */
.blog-card-thumb{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;}
.blog-card-thumb + .blog-card-top{padding-top:1.5rem;}

/* Contact page inline status banner (server-rendered after form POST) */
.form-banner{padding:1rem 1.25rem;border-radius:var(--radius-sm);margin-bottom:1.5rem;font-size:.92rem;}
.form-banner.is-success{background:var(--mint-tint);color:var(--mint-dark);border:1px solid var(--mint);}
.form-banner.is-error{background:#FBE7E2;color:var(--danger);border:1px solid var(--danger);}
