/* ==========================================================================
   WORQsense Design System — Homepage Redesign
   Premium editorial re-tone: Inter · Teal-900 darks · hairline rules
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* --------------------------------------------------------------------------
   TOKENS
   -------------------------------------------------------------------------- */
:root {
  /* ---- Original Colours Palette (locked) ---- */
  --paper:        #EDEAE4;
  --paper-card:   #F5F4F0;
  --paper-sunk:   #E1DED7;
  --ink:          #0D3B44;
  --ink-2:        #1A6876;
  --on-ink:       #F5F4F0;
  --on-ink-muted: rgba(245,244,240,.68);
  --on-ink-faint: rgba(245,244,240,.42);
  --hair-ink:     rgba(245,244,240,.17);
  --text:         #1A1A1A;
  --text-muted:   #5C5D5F;
  --text-faint:   #8B9099;
  --hair:         rgba(26,26,26,.12);
  --hair-strong:  rgba(26,26,26,.22);
  --accent:       #1A6876;
  --accent-deep:  #0D3B44;
  --cta:          #1B8FA0;
  --cta-deep:     #156F7F;
  --on-cta:       #FFFFFF;
  --spark:        #1B8FA0;

  /* ---- Legacy colour tokens (compatibility with inner pages) ---- */
  --teal-100: #E0F7FA;
  --teal-200: #B2EBF2;
  --teal-300: #1AAFBF;
  --teal-500: #1B8FA0;
  --teal-600: #268E9B;
  --teal-700: #1A6876;
  --teal-900: #0D3B44;
  --grey-50:  #EDEAE4;
  --grey-100: #E8E9EB;
  --grey-300: #B2B5BC;
  --grey-400: #8B9099;
  --grey-500: #6B717F;
  --grey-700: #5C5D5F;
  --grey-900: #1A1A1A;
  --blue-50:  #EAF2FB;
  --blue-500: #4A6FA5;
  --blue-700: #3A5A9E;
  --green-50:  #EAF3DE;
  --green-600: #4A7538;
  --red-50:    #FCEAE8;
  --red-600:   #C04535;
  --amber-50:  #FBF5E4;
  --amber-500: #C49A27;
  --color-primary:        var(--teal-500);
  --color-primary-dark:   var(--teal-600);
  --color-bg:             var(--grey-50);
  --color-bg-white:       #ffffff;
  --color-bg-dark:        var(--teal-700);
  --color-bg-darkest:     var(--teal-900);
  --color-text:           var(--grey-900);
  --color-text-secondary: var(--grey-400);
  --color-border:         var(--grey-100);
  --color-link:           var(--accent);

  /* ---- Fonts ---- */
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-head: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* ---- Corners (2px = near-square, intentional) ---- */
  --radius:    6px;
  --radius-sm: 4px;
  --radius-lg: 8px;
  --radius-xl: 12px;

  /* ---- Spacing ---- */
  --s-1:.25rem; --s-2:.5rem; --s-3:.75rem; --s-4:1rem; --s-5:1.25rem;
  --s-6:1.5rem; --s-8:2rem; --s-10:2.5rem; --s-12:3rem; --s-16:4rem;
  --s-20:5rem; --s-24:6rem; --s-32:8rem;

  /* ---- Layout ---- */
  --max-w:      1200px;
  --max-w-text: 760px;
  --pad-x:      clamp(1.25rem, 5vw, 3rem);
  --section-y:  clamp(5.5rem, 11vw, 10rem);

  /* ---- Legacy tokens ---- */
  --shadow-sm: 0 1px 3px rgba(26,26,26,0.07), 0 1px 2px rgba(26,26,26,0.05);
  --shadow:    0 4px 16px rgba(26,26,26,0.10), 0 2px 4px rgba(26,26,26,0.05);
  --shadow-lg: 0 12px 40px rgba(26,26,26,0.12), 0 4px 8px rgba(26,26,26,0.05);
  --t-fast: 150ms ease;
  --t-base: 200ms ease;
  --t-slow: 350ms ease;
  --text-xs:   0.75rem;
  --text-sm:   0.875rem;
  --text-base: 1rem;
  --text-md:   1.125rem;
  --text-lg:   1.25rem;
  --text-xl:   1.5rem;
  --text-2xl:  2rem;
  --text-3xl:  2.5rem;
  --text-4xl:  3rem;
  --text-5xl:  3.75rem;
  --z-nav: 100;
}

/* ---- Tweak: density ----------------------------------------------------- */
body[data-density="comfy"]   { --section-y: clamp(6.5rem, 13vw, 12rem); }
body[data-density="compact"] { --section-y: clamp(2rem, 4vw, 3.5rem); }

/* ---- Tweak: hero layout — stacked variant ------------------------------- */
body[data-hero="stacked"] .hero__grid { grid-template-columns:1fr; gap:0; align-items:start; }
body[data-hero="stacked"] .hero h1 { max-width:20ch; font-size:clamp(3rem,7.5vw,6rem); }
body[data-hero="stacked"] .hero__meta {
  display:flex; flex-direction:row; flex-wrap:wrap;
  margin-top:clamp(3rem,5vw,4.5rem); border-top:1px solid var(--hair-ink);
}
body[data-hero="stacked"] .hero__meta-item {
  flex:1 1 180px; min-width:160px; border-bottom:none;
  border-right:1px solid var(--hair-ink); padding:var(--s-5) var(--s-6) var(--s-5) 0;
}
body[data-hero="stacked"] .hero__meta-item:last-child { border-right:none; }

/* ── Testimonials ──────────────────────────────────────────────────────── */
.testimonial-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--s-7);
}
.testimonial {
  margin: 0;
  padding: var(--s-8) var(--s-7);
  background: var(--ink);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--s-7);
}
.testimonial__quote {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  font-style: italic;
  line-height: 1.65;
  color: var(--on-ink);
  margin: 0;
  flex: 1;
}
.testimonial__quote::before { content: "\201C"; }
.testimonial__quote::after  { content: "\201D"; }
.testimonial__attr {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  padding-top: var(--s-6);
  border-top: 1px solid var(--hair-ink);
}
.testimonial__name {
  font-weight: 700;
  font-size: .85rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--spark);
}
.testimonial__org {
  font-size: .85rem;
  color: var(--on-ink-muted);
}
.testimonial-single {
  max-width: 720px;
  margin-inline: auto;
}
.testimonial--solo {
  text-align: center;
}
.testimonial--solo .testimonial__attr {
  align-items: center;
}



/* ── Credential row (below hero) ────────────────────────────────────────── */
.credentials-row {
  background: var(--paper-sunk);
  border-bottom: 1px solid var(--hair-strong);
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex-wrap: wrap;
}
.credentials-row__item {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  padding: 1.1rem clamp(1.5rem, 4vw, 3.5rem);
  text-align: center;
  min-width: 200px;
  flex: 1;
}
.credentials-row__label {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-faint);
}
.credentials-row__value {
  font-size: .8rem;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: .01em;
}
.credentials-row__divider {
  width: 1px;
  background: var(--hair-strong);
  margin-block: .75rem;
  flex-shrink: 0;
}
@media (max-width: 640px) {
  .credentials-row { flex-direction: column; }
  .credentials-row__divider { width: auto; height: 1px; margin: 0 1.5rem; }
  .credentials-row__item { padding: .9rem 1.5rem; }
}

/* ── Client logo strip ─────────────────────────────────────────────────── */
.client-logos { padding-block: clamp(3rem, 5vw, 4.5rem); }
.client-logo__grid {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(1.5rem, 3vw, 3rem);
}
.client-logo__item {
  display: flex;
  align-items: center;
  justify-content: center;
}
.client-logo__item span {
  font-size: clamp(.65rem, 1vw, .78rem);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.35;
  transition: opacity .25s ease;
  white-space: nowrap;
}
.client-logo__item:hover span {
  opacity: 0.7;
}

.clients-title {
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 700;
  color: var(--ink);
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
  opacity: 0.75;
}

.section-head--center {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
}

@media (max-width:560px){
  body[data-hero="stacked"] .hero__meta { flex-direction:column; }
  body[data-hero="stacked"] .hero__meta-item { border-right:none; border-bottom:1px solid var(--hair-ink); padding:var(--s-4) 0; }
}

/* ---- Tweak: hero layout — banner variant -------------------------------- */
body[data-hero="banner"] .hero__grid { grid-template-columns:1fr; gap:0; align-items:start; }
body[data-hero="banner"] .hero h1 { max-width:20ch; }
body[data-hero="banner"] .hero__meta { display:none; }
body[data-hero="banner"] .hero {
  background-image:
    radial-gradient(ellipse at 78% 12%, color-mix(in srgb, var(--spark) 24%, transparent) 0%, transparent 56%),
    radial-gradient(ellipse at 12% 90%, rgba(0,0,0,0.30) 0%, transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='52' viewBox='0 0 60 52'%3E%3Cpath d='M30 2L58 17v18L30 50 2 35V17z' fill='none' stroke='rgba(255,255,255,0.05)' stroke-width='1'/%3E%3C/svg%3E");
  background-size: auto, auto, 60px 52px;
}
body[data-hero="banner"] .hero__label {
  background: color-mix(in srgb, var(--spark) 16%, transparent);
  color: var(--spark);
  padding: var(--s-1) var(--s-3);
  border-radius: var(--radius);
}

/* --------------------------------------------------------------------------
   RESET
   -------------------------------------------------------------------------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--text);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'cv02','cv03','cv04','cv11';
}
img,svg { display:block; max-width:100%; height:auto; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { font:inherit; cursor:pointer; border:none; background:none; }
p { text-wrap:pretty; }

/* --------------------------------------------------------------------------
   TYPE
   -------------------------------------------------------------------------- */
h1,h2,h3 {
  font-family: var(--font-head);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.028em;
  color: var(--text);
  text-wrap: balance;
  font-feature-settings: 'cv02','cv03','cv04','cv11';
}
h1 { font-size:clamp(2.9rem, 7vw, 5.6rem); }
h2 { font-size:clamp(2.1rem, 4.4vw, 3.5rem); }
h3 { font-size:clamp(1.4rem, 2.3vw, 1.95rem); line-height:1.15; }
h4 { font-family:var(--font-body); font-size:1.0625rem; font-weight:700; line-height:1.35; letter-spacing:-0.01em; font-feature-settings: 'cv02','cv03','cv04','cv11'; }
h5,h6 { font-family:var(--font-body); font-weight:600; font-feature-settings: 'cv02','cv03','cv04','cv11'; }

.kicker {
  display: inline-block;
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent);
}
.lead { font-size:clamp(1.1rem,1.6vw,1.3rem); line-height:1.6; color:var(--text-muted); }
.hero .lead { color:rgba(245,244,240,.88); }

/* --------------------------------------------------------------------------
   LAYOUT
   -------------------------------------------------------------------------- */
.container { max-width:var(--max-w); margin-inline:auto; padding-inline:var(--pad-x); }
.container--narrow { max-width:var(--max-w-text); margin-inline:auto; padding-inline:var(--pad-x); }
.section { padding-block:var(--section-y); }
.section--sm { padding-block:clamp(2.5rem, 5vw, 4.5rem); }
.section--paper { background:var(--paper); }
.section--sunk  { background:var(--paper-sunk); }
.section--ink   { background-color:var(--ink); color:var(--on-ink); }
.section--ink h1,.section--ink h2,.section--ink h3,.section--ink h4 { color:var(--on-ink); }

.section-head { max-width:760px; margin-bottom:clamp(1.5rem,2.5vw,2.25rem); }
.section-head .kicker { margin-bottom:var(--s-5); }
.section-head h2 { margin-bottom:var(--s-5); }
.section-head p { color:var(--text-muted); font-size:1.15rem; max-width:620px; }
.section--ink .section-head p { color:var(--on-ink-muted); }

/* Legacy section header class */
.section-header { margin-bottom:clamp(var(--s-8), 4vw, var(--s-16)); }
.section-header h2 { margin-bottom:var(--s-4); }
.section-header p  { max-width:640px; color:var(--text-muted); font-size:var(--text-md); }
.section-header--center { text-align:center; }
.section-header--center p { margin-inline:auto; }

/* Legacy section label */
.section-label {
  display:inline-block;
  font-size:.72rem; font-weight:600; text-transform:uppercase;
  letter-spacing:0.2em; color:var(--accent); margin-bottom:var(--s-3);
}

/* Grid helpers */
.grid-2 { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%, 460px), 1fr)); gap:var(--s-8); }
.grid-3 { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%, 300px), 1fr)); gap:var(--s-6); }
.grid-4 { display:grid; grid-template-columns:repeat(2, 1fr); gap:var(--s-6); }

.flex         { display:flex; }
.flex-center  { display:flex; align-items:center; justify-content:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }
.flex-col     { flex-direction:column; }
.text-center  { text-align:center; }

/* --------------------------------------------------------------------------
   BUTTONS / LINKS
   -------------------------------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-body); font-size:.9rem; font-weight:600;
  letter-spacing:0.01em;
  padding:.95rem 1.6rem;
  border-radius:var(--radius);
  border:1px solid transparent;
  transition:background .2s ease, color .2s ease, border-color .2s ease;
  text-decoration:none; white-space:nowrap; cursor:pointer;
}

/* Solid CTA button (bright teal fill) */
.btn--solid { background:var(--cta); color:var(--on-cta); }
.btn--solid:hover { background:var(--cta-deep); color:var(--on-cta); }

/* Outline button */
.btn--line { border-color:var(--hair-strong); color:var(--text); }
.btn--line:hover { border-color:var(--text); color:var(--text); }
.section--ink .btn--line, .hero .btn--line, .cta .btn--line { border-color:var(--on-ink-faint); color:var(--on-ink); }
.section--ink .btn--line:hover, .hero .btn--line:hover, .cta .btn--line:hover { border-color:var(--on-ink); background:rgba(255,255,255,.06); color:var(--on-ink); }

/* Ink-fill button (on dark sections) */
.btn--ink { background:var(--on-ink); color:var(--ink); }
.btn--ink:hover { background:#fff; color:var(--ink); }

/* Legacy button variants (for inner pages) */
.btn--primary { background:var(--teal-500); color:#fff; border-color:var(--teal-500); }
.btn--primary:hover { background:var(--teal-600); border-color:var(--teal-600); color:#fff; }
.btn--outline { background:transparent; color:var(--teal-500); border-color:var(--teal-500); }
.btn--outline:hover { background:var(--teal-500); color:#fff; }
.btn--outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,0.55); }
.btn--outline-white:hover { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.85); color:#fff; }
.btn--ghost { background:transparent; color:var(--text-muted); border-color:transparent; padding-inline:0; }
.btn--ghost:hover { color:var(--accent); }
.btn--outline-teal { background:transparent; color:var(--teal-600); border-color:var(--teal-300); }
.btn--outline-teal:hover { background:var(--teal-100); border-color:var(--teal-500); color:var(--teal-600); }
.btn--white { background:#fff; color:#0B2FC1; border-color:#fff; font-weight:700; }
.btn--white:hover { background:rgba(255,255,255,0.92); border-color:rgba(255,255,255,0.92); color:#0B2FC1; }
.btn--lg { padding:1rem 2rem; font-size:var(--text-base); }
.btn-group { display:flex; flex-wrap:wrap; gap:var(--s-4); align-items:center; }
.btn-row   { display:flex; flex-wrap:wrap; gap:var(--s-4); align-items:center; }

/* Arrow links */
.arrow-link {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-body); font-size:.9rem; font-weight:600;
  color:var(--accent);
  transition:gap .2s ease;
  text-decoration:none;
}
.arrow-link::after { content:'→'; transition:transform .2s ease; }
.arrow-link:hover { gap:.7rem; color:var(--accent); }
.section--ink .arrow-link { color:var(--spark); }
.section--ink .arrow-link:hover { color:var(--spark); }

/* Legacy card link */
.card__link {
  display:inline-flex; align-items:center; gap:var(--s-2);
  margin-top:var(--s-5); font-size:var(--text-sm); font-weight:700;
  color:var(--accent); transition:gap var(--t-fast);
  text-decoration:none;
}
.card__link:hover { gap:var(--s-3); color:var(--accent-deep); }
.card__link::after { content:'→'; }

/* --------------------------------------------------------------------------
   NAV
   -------------------------------------------------------------------------- */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease, background .25s ease;
}
.nav.is-scrolled { border-bottom-color:var(--hair); }
.nav__inner {
  max-width:var(--max-w); margin-inline:auto; padding-inline:var(--pad-x);
  height:112px; display:flex; align-items:center; justify-content:space-between; gap:var(--s-6);
}
.nav__logo { display:flex; align-items:center; gap:var(--s-3); text-decoration:none; flex-shrink:0; }
.nav__logo img { height:106px; width:auto; }
.nav__links { display:flex; align-items:center; gap:var(--s-1); flex:1; justify-content:center; }
.nav__link {
  position:relative; padding:.5rem .85rem;
  font-size:.875rem; font-weight:500; color:var(--text-muted);
  letter-spacing:0.005em; transition:color .2s ease;
  text-decoration:none;
}
.nav__link:hover, .nav__link.active { color:var(--text); }
.nav__link.active::after {
  content:''; position:absolute; left:.85rem; right:.85rem; bottom:.1rem;
  height:1px; background:var(--accent);
}
.nav__item { position:relative; }
.nav__dropdown {
  position:absolute; top:calc(100% + .4rem); left:0; min-width:250px;
  background:var(--paper-card); border:1px solid var(--hair);
  border-radius:var(--radius); padding:var(--s-2);
  opacity:0; visibility:hidden; transform:translateY(6px);
  transition:all .2s ease; box-shadow:0 18px 40px rgba(27,26,23,.10);
  z-index:101;
}
.nav__item:hover .nav__dropdown,
.nav__item--has-dropdown:hover .nav__dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.nav__link--has-dropdown::after { content:' ▾'; font-size:0.6em; vertical-align:1px; opacity:0.6; }
.nav__dropdown a { display:block; padding:.6rem .8rem; font-size:.875rem; color:var(--text-muted); border-radius:var(--radius); text-decoration:none; transition:color .2s ease, background .2s ease; border-left:2px solid transparent; }
.nav__dropdown a:hover { color:var(--text); background:var(--paper-sunk); border-left-color:var(--accent); }
.nav__actions { display:flex; align-items:center; gap:var(--s-4); flex-shrink:0; }
.nav__toggle { display:none; flex-direction:column; gap:5px; width:30px; padding:.4rem; cursor:pointer; background:none; border:none; }
.nav__toggle span { display:block; height:1.5px; background:var(--text); transition:all .2s ease; transform-origin:center; }
.nav.is-open .nav__toggle span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2) { opacity:0; }
.nav.is-open .nav__toggle span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.nav__cta-mobile { display:none !important; }

@media (max-width:1040px){
  .nav__links, .nav__actions { display:none; }
  .nav__toggle { display:flex; }
  .nav.is-open .nav__links {
    display:flex; flex-direction:column; align-items:flex-start;
    position:absolute; top:100px; left:0; right:0;
    background:var(--paper); border-bottom:1px solid var(--hair);
    padding:var(--s-4) var(--pad-x) var(--s-8); gap:var(--s-1);
    box-shadow:0 18px 40px rgba(27,26,23,.10);
  }
  .nav.is-open .nav__dropdown { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:none; padding-left:var(--s-4); }
  .nav__item--has-dropdown { flex-direction:column; align-items:flex-start; width:100%; }
  .nav__link { font-size:1rem; padding:.6rem 0; }
  .nav.is-open .nav__cta-mobile { display:block !important; margin-top:var(--s-2); padding-top:var(--s-3); border-top:1px solid var(--hair); }
  .nav.is-open .nav__cta-mobile .btn { width:100%; justify-content:center; }
}

/* --------------------------------------------------------------------------
   HERO
   -------------------------------------------------------------------------- */
.hero {
  background-color:var(--ink); color:var(--on-ink);
  padding-top:calc(100px + clamp(1.5rem,3vw,2.5rem));
  padding-bottom:clamp(3rem,6vw,5rem);
  position:relative; overflow:hidden;
}
.hero::before {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(245,244,240,0.20), rgba(13,59,68,0.70)),
    url('../abstractteal.jpg');
  background-size:cover;
  background-position:center;
  transform:scaleX(-1);
  z-index:0;
}
.hero__inner { max-width:var(--max-w); margin-inline:auto; padding-inline:var(--pad-x); position:relative; z-index:1; }
.hero__grid { display:grid; grid-template-columns:minmax(0,1fr) 280px; gap:clamp(2rem,6vw,5rem); align-items:end; }
.hero__label { color:var(--spark); margin-bottom:var(--s-8); }
.hero__stage { min-height:clamp(13rem, 26vw, 19rem); display:grid; }
.hero-slide {
  grid-area:1/1; align-self:start;
  opacity:0; transform:translateY(12px);
  transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
  pointer-events:none; visibility:hidden;
}
.hero-slide.is-active { opacity:1; transform:none; pointer-events:auto; visibility:visible; }
.hero h1 { color:var(--on-ink); max-width:16ch; }
.hero .hero-slide__heading {
  color:var(--on-ink);
  max-width:16ch;
  font-size:var(--text-5xl);
  font-weight:800;
  line-height:1.1;
  letter-spacing:-.02em;
  margin:0;
}
.hero-slide__sub { color:rgba(245,244,240,.88); font-size:clamp(1.05rem,1.5vw,1.25rem); margin-top:var(--s-6); max-width:46ch; line-height:1.55; }
.hero-slide__brand { color:var(--spark); font-family:var(--font-body); font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; margin-top:var(--s-6); }

.hero__cta { display:flex; flex-wrap:wrap; gap:var(--s-4); align-items:center; margin-top:clamp(2.5rem,4vw,3.5rem); }
.hero__nav { display:flex; align-items:center; gap:var(--s-4); margin-top:var(--s-10); }
.hero__dots { display:flex; gap:var(--s-2); }
.hero__dot { width:30px; height:2px; background:var(--on-ink-faint); transition:background .3s ease; padding:0; border-radius:0; }
.hero__dot.is-active { background:var(--spark); }
.hero__count { font-family:var(--font-body); font-size:.78rem; letter-spacing:.12em; color:var(--on-ink-faint); }

/* hero meta rail */
.hero__meta { display:flex; flex-direction:column; gap:0; border-top:1px solid var(--hair-ink); }
.hero__meta-item { padding:var(--s-4) 0; border-bottom:1px solid var(--hair-ink); }
.hero__meta-item .m-k { display:block; font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:rgba(245,244,240,.70); margin-bottom:.35rem; }
.hero__meta-item .m-v { font-size:.95rem; color:var(--on-ink); }

@media (max-width:900px){
  .hero__grid { grid-template-columns:1fr; gap:var(--s-12); }
  .hero__meta { display:grid; grid-template-columns:1fr 1fr; gap:0 var(--s-8); }
}
@media (max-width:520px){ .hero__meta { grid-template-columns:1fr; } }

/* Legacy hero variants (for inner pages) */
.hero--sm { padding-top:calc(100px + var(--s-6)); padding-bottom:var(--s-12); min-height:480px; display:flex; flex-direction:column; justify-content:flex-end; }
.hero--corridor {
  background-image:url('../abstractteal.jpg');
  background-size:cover; background-position:center;
}
.hero--corridor::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(rgba(245,244,240,0.20), rgba(13,59,68,0.70));
  pointer-events:none;
}
.hero--modernoffice {
  background-image:url('../modernoffice.jpg');
  background-size:cover; background-position:center;
}
.hero--modernoffice::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(rgba(245,244,240,0.20), rgba(13,59,68,0.70));
  pointer-events:none;
}
.hero--ims {
  background-color:#F4F6FF;
  background-image:
    radial-gradient(ellipse at 88% 0%, rgba(11,47,193,0.07) 0%, transparent 55%),
    radial-gradient(ellipse at 6% 100%, rgba(26,104,118,0.07) 0%, transparent 50%);
  color:var(--grey-900);
}
.hero--ims h1 { color:var(--teal-900); }
.hero--ims .lead { color:var(--grey-500); }
.hero--ims .hero__label { color:var(--teal-600); background:rgba(26,104,118,0.10); }

.hero__inner--split { display:flex; align-items:center; gap:clamp(var(--s-10), 6vw, var(--s-20)); }
.hero__body { flex:1; min-width:0; }
.hero__ims-aside { flex-shrink:0; display:flex; flex-direction:column; align-items:flex-end; gap:var(--s-4); }
.hero__ims-logo { height:clamp(72px, 9vw, 112px); width:auto; display:block; }
.hero__ims-caption { display:flex; flex-direction:column; align-items:flex-end; gap:var(--s-2); }
.hero__ims-pretext { font-size:var(--text-xs); font-weight:500; color:var(--grey-400); font-style:italic; }
.hero__ims-tag { font-size:var(--text-xs); font-weight:700; letter-spacing:0.11em; text-transform:uppercase; color:var(--grey-400); padding:var(--s-1) var(--s-3); border:1px solid var(--grey-100); border-radius:var(--radius-sm); }
@media (max-width:700px){
  .hero__inner--split { flex-direction:column; align-items:flex-start; }
  .hero__ims-aside { align-items:flex-start; border-top:1px solid rgba(11,47,193,0.12); padding-top:var(--s-6); width:100%; }
  .hero__ims-caption { align-items:flex-start; }
}

/* --------------------------------------------------------------------------
   PARTNER STRIP
   -------------------------------------------------------------------------- */
.partner-strip { background:var(--paper); border-bottom:1px solid var(--hair); padding-block:clamp(1.75rem,3vw,2.5rem); }
.partner-strip__inner { display:flex; align-items:center; gap:clamp(1.5rem,4vw,3rem); flex-wrap:wrap; }
.partner-strip .kicker { color:var(--text-faint); white-space:nowrap; }
.partner-strip__logo { height:46px; width:auto; flex-shrink:0; }
.partner-strip__copy { flex:1 1 320px; font-size:.95rem; color:var(--text-muted); max-width:56ch; }
.partner-strip__link { white-space:nowrap; }
@media (max-width:640px){ .partner-strip__inner { gap:var(--s-4); } }

/* IMS logo plate (on dark sections) */
.col-item__logo { display:inline-block; background:#fff; padding:.7rem .9rem; border-radius:var(--radius); margin-bottom:var(--s-4); }
.col-item__logo img { height:32px; width:auto; }

/* --------------------------------------------------------------------------
   THE GAP — editorial two-column
   -------------------------------------------------------------------------- */
.split { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,420px),1fr)); gap:clamp(2.5rem,6vw,5rem); align-items:start; }
.prose p { color:var(--text-muted); margin-top:var(--s-5); }
.prose p.lead { color:var(--text); }

.pullquote {
  font-family:var(--font-head); font-weight:500;
  font-size:clamp(1.3rem,2vw,1.7rem); line-height:1.3; color:var(--text);
  padding-left:var(--s-6); border-left:2px solid var(--accent);
  margin-top:var(--s-8); text-wrap:balance;
}
.section--ink .pullquote { color:var(--on-ink); border-left-color:var(--spark); }

/* Stacked notes (hairline, no fill) */
.notes { display:flex; flex-direction:column; }
.note { padding:var(--s-8) 0; border-top:1px solid var(--hair); }
.note:first-child { border-top:none; padding-top:0; }
.note .kicker { color:var(--text-faint); margin-bottom:var(--s-3); display:block; }
.note h4 { margin-bottom:var(--s-2); }
.note p { color:var(--text-muted); font-size:.98rem; }
.note--flag .kicker { color:#A8472F; }

/* --------------------------------------------------------------------------
   TWO LENSES
   -------------------------------------------------------------------------- */
.lenses { display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--hair-ink); }
.lens { padding:clamp(2.5rem,4vw,3.5rem) clamp(2rem,3.5vw,3rem); border-bottom:1px solid var(--hair-ink); }
.lens:first-child { border-right:1px solid var(--hair-ink); }
.lens__head { display:flex; align-items:center; gap:var(--s-5); margin-bottom:var(--s-8); }
.lens__photo { width:64px; height:64px; border-radius:50%; object-fit:cover; object-position:center top; flex-shrink:0; filter:grayscale(1) contrast(1.02); }
.lens__role { font-size:.68rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--spark); margin-bottom:.4rem; }
.lens__name { font-size:.98rem; font-weight:600; color:var(--on-ink); }
.lens__cred { font-size:.85rem; color:var(--on-ink-muted); }
.lens h3 { margin-bottom:var(--s-4); max-width:18ch; }
.lens p { color:var(--on-ink-muted); font-size:1rem; }
.lens ul { margin:var(--s-6) 0; display:flex; flex-direction:column; gap:var(--s-3); }
.lens li { display:flex; gap:var(--s-3); font-size:.95rem; color:var(--on-ink-muted); }
.lens li::before { content:'–'; color:var(--spark); }
@media (max-width:820px){
  .lenses { grid-template-columns:1fr; }
  .lens:first-child { border-right:none; }
}

/* --------------------------------------------------------------------------
   SERVICE PATHWAY — numbered editorial rows
   -------------------------------------------------------------------------- */
.pathway { border-top:1px solid var(--hair); }
.path-row {
  display:grid; grid-template-columns:auto 1fr auto;
  gap:clamp(1.5rem,4vw,4rem); align-items:baseline;
  padding:clamp(1.75rem,3vw,2.5rem) 0; border-bottom:1px solid var(--hair);
  transition:background .2s ease;
}
.path-row:hover { background:var(--paper-card); }
.path-row__num { font-family:var(--font-head); font-size:1.5rem; color:var(--text-faint); font-weight:400; }
.path-row__main { max-width:62ch; }
.path-row__tag { font-size:.68rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:var(--s-3); }
.path-row__main h3 { margin-bottom:var(--s-3); }
.path-row__main p { color:var(--text-muted); font-size:1rem; }
.path-row__link { align-self:center; white-space:nowrap; }
@media (max-width:820px){
  .path-row { grid-template-columns:auto 1fr; }
  .path-row__link { grid-column:2; align-self:start; margin-top:var(--s-3); }
}

/* --------------------------------------------------------------------------
   WHAT MAKES THE DIFFERENCE — hairline grid
   -------------------------------------------------------------------------- */
.feature-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr)); }
.feature {
  padding:clamp(2rem,3vw,2.75rem) clamp(1.5rem,2.5vw,2.5rem);
  border-top:1px solid var(--hair); border-left:1px solid var(--hair);
}
.feature h4 { margin-bottom:var(--s-3); color:var(--text); }
.feature h4 .q { color:var(--accent); }
.feature p { color:var(--text-muted); font-size:.98rem; }
.feature a { color:var(--accent); font-weight:600; }

/* --------------------------------------------------------------------------
   BUILT ON / ENGAGEMENT — column sets
   -------------------------------------------------------------------------- */
.cols { display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr)); gap:0; }
.col-item { padding:var(--s-8) clamp(1.25rem,2vw,2rem) var(--s-8) 0; border-top:1px solid var(--hair-ink); }
.section--paper .col-item, .section--sunk .col-item { border-top-color:var(--hair); }
.col-item__kic { font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:var(--s-4); display:block; }
.section--ink .col-item__kic { color:var(--spark); }
.col-item h3 { font-size:1.25rem; margin-bottom:var(--s-3); }
.col-item p { font-size:.96rem; color:var(--text-muted); }
.section--ink .col-item p { color:var(--on-ink-muted); }
.col-item__link { display:inline-block; margin-top:var(--s-4); font-size:.85rem; font-weight:600; color:var(--accent); text-decoration:none; }
.section--ink .col-item__link { color:var(--spark); }

/* --------------------------------------------------------------------------
   WHO WE WORK WITH — tags + region notes
   -------------------------------------------------------------------------- */
.tagset { display:flex; flex-wrap:wrap; gap:var(--s-3); margin-top:var(--s-8); }
.tag { font-size:.85rem; color:var(--text-muted); border:1px solid var(--hair-strong); border-radius:var(--radius); padding:.45rem .9rem; }
.tag--accent { color:var(--accent); border-color:color-mix(in srgb,var(--accent) 40%, transparent); }

/* Legacy tag styles */
.tag--teal { background:var(--teal-100); color:var(--teal-600); border-color:transparent; }
.tag--grey { background:var(--grey-100); color:var(--grey-500); border-color:transparent; }
.tag:hover { background:var(--cta); color:#fff; border-color:transparent; }

.region { padding:var(--s-8) 0; border-top:1px solid var(--hair); }
.region:first-child { padding-top:0; border-top:none; }
.region__loc-k { font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--text-faint); margin-bottom:var(--s-2); }
.region h4 { font-family:var(--font-head); font-size:1.25rem; color:var(--text); margin-bottom:var(--s-2); }
.region p { font-size:.95rem; color:var(--text-muted); }
.region a { color:var(--accent); font-weight:600; font-size:.85rem; display:inline-block; margin-top:var(--s-3); text-decoration:none; }

/* --------------------------------------------------------------------------
   CTA BAND
   -------------------------------------------------------------------------- */
.cta { background-color:var(--ink); color:var(--on-ink); text-align:center; }
.cta h2 { color:var(--on-ink); max-width:18ch; margin-inline:auto; margin-bottom:var(--s-5); }
.cta p { color:var(--on-ink-muted); margin-bottom:var(--s-8); font-size:1.15rem; }
.cta .btn-row { justify-content:center; }

/* Legacy CTA section class */
.cta-section {
  background:var(--ink); color:var(--on-ink);
  padding-block:clamp(var(--s-16), 8vw, var(--s-24));
  text-align:center; position:relative; overflow:hidden;
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(39,198,217,0.2) 0%, transparent 65%);
  pointer-events:none;
}
.cta-section__inner { position:relative; z-index:1; }
.cta-section h2 { color:var(--on-ink); margin-bottom:var(--s-4); }
.cta-section p { color:var(--on-ink-muted); max-width:560px; margin-inline:auto; margin-bottom:var(--s-8); font-size:var(--text-md); }

/* --------------------------------------------------------------------------
   FOOTER
   -------------------------------------------------------------------------- */
.footer { background:var(--ink); color:var(--on-ink); padding-block:clamp(3.5rem,6vw,5rem) var(--s-10); }
.footer__grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:var(--s-12) var(--s-8); }
.footer__brand img { height:68px; width:auto; margin-bottom:var(--s-5); }
.footer__logo { display:flex; align-items:center; gap:var(--s-3); text-decoration:none; margin-bottom:var(--s-4); }
.footer__logo img { height:68px; width:auto; }
.footer__tag, .footer__tagline { font-family:var(--font-head); font-size:1.05rem; color:var(--on-ink); margin-bottom:var(--s-4); max-width:30ch; }
.footer__brand > p { font-size:.9rem; color:rgba(245,244,240,.82); max-width:44ch; }
.footer__col h4, .footer__col h5 { font-size:.7rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:rgba(245,244,240,.65); margin-bottom:var(--s-5); }
.footer__col ul { display:flex; flex-direction:column; gap:var(--s-3); }
.footer__col a { font-size:.92rem; color:rgba(245,244,240,.85); transition:color .2s ease; text-decoration:none; }
.footer__col a:hover { color:var(--on-ink); }
.footer__bottom {
  margin-top:clamp(3rem,5vw,4rem); padding-top:var(--s-6);
  border-top:1px solid var(--hair-ink);
  display:flex; flex-wrap:wrap; gap:var(--s-4); justify-content:space-between;
  font-size:.82rem; color:rgba(245,244,240,.60);
}
.footer__copy { font-size:var(--text-xs); }
.footer__lp   { font-size:var(--text-xs); color:var(--on-ink-faint); font-style:italic; }
@media (max-width:820px){ .footer__grid { grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer__grid { grid-template-columns:1fr; } }

/* --------------------------------------------------------------------------
   SCROLL REVEAL
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion:no-preference){
  [data-animate] { opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease; }
  [data-animate].is-in { opacity:1; transform:none; }
  [data-animate][data-delay="1"] { transition-delay:0.1s; }
  [data-animate][data-delay="2"] { transition-delay:0.2s; }
  [data-animate][data-delay="3"] { transition-delay:0.3s; }
  [data-animate][data-delay="4"] { transition-delay:0.4s; }
}

/* ==========================================================================
   LEGACY / PAGE-SPECIFIC COMPONENTS
   Used on inner pages (investigations, about, rewireworks, etc.)
   ========================================================================== */

/* --------------------------------------------------------------------------
   CARDS
   -------------------------------------------------------------------------- */
.card {
  background:var(--paper-card);
  border:1px solid var(--hair);
  border-radius:var(--radius);
  padding:var(--s-8);
  transition:box-shadow var(--t-base);
}
.card:hover { box-shadow:var(--shadow); }
.card--teal   { background:var(--teal-100); border-color:var(--teal-200); }
.card--offwhite { background:var(--grey-50); }
.card--dark   { background:var(--teal-700); color:#fff; border-color:transparent; }
.card--dark h3, .card--dark h2 { color:#fff; }
.card--dark p, .card--dark .lead { color:rgba(255,255,255,0.72); }
.card h3 { margin-bottom:var(--s-3); }
.card p  { color:var(--text-muted); font-size:var(--text-sm); }

/* --------------------------------------------------------------------------
   SERVICE CARDS
   -------------------------------------------------------------------------- */
.service-card {
  background:var(--paper-card);
  border:1px solid var(--hair);
  border-radius:var(--radius);
  padding:var(--s-8);
  display:flex; flex-direction:column; position:relative;
  transition:all var(--t-base);
  border-top:3px solid var(--hair);
}
.service-card:hover { border-top-color:var(--cta); box-shadow:var(--shadow); }
.service-card__num { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:var(--accent); margin-bottom:var(--s-4); }
.service-card__tag { display:inline-block; background:var(--teal-100); color:var(--teal-600); font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.08em; padding:var(--s-1) var(--s-3); border-radius:var(--radius-sm); margin-bottom:var(--s-4); }
.service-card h3 { font-size:clamp(var(--text-base), 1.5vw, var(--text-lg)); margin-bottom:var(--s-3); color:var(--text); }
.service-card p { color:var(--text-muted); font-size:var(--text-sm); line-height:1.7; flex:1; }
.service-card__footer { margin-top:var(--s-6); padding-top:var(--s-5); border-top:1px solid var(--hair); }

/* --------------------------------------------------------------------------
   SERVICE DETAIL
   -------------------------------------------------------------------------- */
.service-detail { padding-block:clamp(var(--s-16), 8vw, var(--s-24)); }
.service-detail:nth-child(even) { background:var(--paper-card); }
.service-detail:nth-child(odd)  { background:var(--paper); }
.service-detail__num { font-size:var(--text-5xl); font-weight:700; color:var(--teal-100); line-height:1; margin-bottom:var(--s-4); }
.service-detail h2 { margin-bottom:var(--s-4); }
.service-detail__body { max-width:560px; }
.service-detail__body p { font-size:var(--text-md); color:var(--text-muted); }
.service-detail__features { margin-top:var(--s-6); display:flex; flex-direction:column; gap:var(--s-3); }
.service-detail__feature { display:flex; align-items:flex-start; gap:var(--s-3); font-size:var(--text-sm); color:var(--text-muted); }
.service-detail__feature::before { content:''; flex-shrink:0; width:6px; height:6px; background:var(--cta); border-radius:50%; margin-top:0.45rem; }
.service-detail__aside { background:var(--teal-100); border-radius:var(--radius); padding:var(--s-8); border-left:3px solid var(--cta); }
.service-detail__aside h4 { color:var(--teal-600); margin-bottom:var(--s-4); font-size:var(--text-sm); text-transform:uppercase; letter-spacing:0.1em; }
.service-detail__aside ul { display:flex; flex-direction:column; gap:var(--s-2); }
.service-detail__aside li { font-size:var(--text-sm); color:var(--text-muted); padding-left:var(--s-4); position:relative; }
.service-detail__aside li::before { content:'→'; position:absolute; left:0; color:var(--cta); font-size:var(--text-xs); }

/* --------------------------------------------------------------------------
   PROCESS STEPS
   -------------------------------------------------------------------------- */
.steps { display:flex; flex-direction:column; gap:0; }
.step { display:flex; gap:var(--s-6); padding-bottom:var(--s-8); position:relative; }
.step:not(:last-child)::after { content:''; position:absolute; left:24px; top:52px; bottom:0; width:1px; background:var(--hair); }
.step__num { flex-shrink:0; width:48px; height:48px; background:var(--cta); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:var(--text-sm); z-index:1; position:relative; }
.step__content h4 { margin-bottom:var(--s-2); color:var(--text); }
.step__content p  { color:var(--text-muted); font-size:var(--text-sm); margin:0; }

.steps-h { display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--s-6); position:relative; }
.steps-h::before { content:''; position:absolute; top:24px; left:16.66%; right:16.66%; height:1px; background:var(--hair); z-index:0; }
.step-h { text-align:center; position:relative; z-index:1; }
.step-h__num { width:48px; height:48px; background:var(--cta); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:var(--text-sm); margin:0 auto var(--s-5); }
.step-h h4 { color:var(--text); margin-bottom:var(--s-2); }
.step-h p  { font-size:var(--text-sm); color:var(--text-muted); margin:0; }
@media (max-width:640px){
  .steps-h { grid-template-columns:1fr; }
  .steps-h::before { display:none; }
  .step-h { text-align:left; display:flex; gap:var(--s-5); align-items:flex-start; }
  .step-h__num { margin:0; flex-shrink:0; }
}

/* --------------------------------------------------------------------------
   STAT BLOCKS
   -------------------------------------------------------------------------- */
.stat-row { display:grid; grid-template-columns:repeat(auto-fit, minmax(160px, 1fr)); gap:1px; background:var(--hair); border:1px solid var(--hair); border-radius:var(--radius); overflow:hidden; }
.stat-block { text-align:center; padding:var(--s-8) var(--s-6); background:var(--paper-card); }
.stat-block__num { font-size:clamp(var(--text-2xl), 3.5vw, var(--text-4xl)); font-weight:700; color:var(--cta); line-height:1; margin-bottom:var(--s-2); }
.stat-block__label { font-size:var(--text-sm); color:var(--text-muted); }

/* --------------------------------------------------------------------------
   TESTIMONIAL
   -------------------------------------------------------------------------- */
.testimonial { background:var(--paper-card); border:1px solid var(--hair); border-radius:var(--radius); padding:var(--s-8); }
.testimonial__quote { font-size:var(--text-md); color:var(--text); font-style:italic; margin-bottom:var(--s-5); line-height:1.7; position:relative; padding-left:var(--s-6); }
.testimonial__quote::before { content:'\201C'; position:absolute; left:0; top:-4px; font-size:var(--text-2xl); color:var(--cta); font-style:normal; line-height:1; }
.testimonial__author { font-size:var(--text-sm); font-weight:700; color:var(--text); }
.testimonial__role   { font-size:var(--text-xs); color:var(--text-muted); }

/* --------------------------------------------------------------------------
   BLOG / EVENT CARDS
   -------------------------------------------------------------------------- */
.post-card { background:var(--paper-card); border:1px solid var(--hair); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:all var(--t-base); }
.post-card:hover { box-shadow:var(--shadow); }
.post-card__img { aspect-ratio:16/9; background:linear-gradient(135deg, var(--teal-100) 0%, var(--teal-200) 100%); display:flex; align-items:center; justify-content:center; font-size:var(--text-3xl); font-weight:700; color:var(--cta); overflow:hidden; }
.post-card__img img { width:100%; height:100%; object-fit:cover; }
.post-card__body { padding:var(--s-6); flex:1; display:flex; flex-direction:column; }
.post-card__meta { display:flex; align-items:center; gap:var(--s-3); margin-bottom:var(--s-3); font-size:var(--text-xs); color:var(--text-muted); }
.post-card__tag { background:var(--teal-100); color:var(--teal-600); padding:2px var(--s-2); border-radius:var(--radius-sm); font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.06em; }
.post-card h3 { font-size:var(--text-lg); margin-bottom:var(--s-3); }
.post-card h3 a { color:var(--text); }
.post-card h3 a:hover { color:var(--accent); }
.post-card p { color:var(--text-muted); font-size:var(--text-sm); flex:1; }

.event-card { background:var(--paper-card); border:1px solid var(--hair); border-radius:var(--radius); padding:var(--s-6); display:flex; gap:var(--s-5); transition:all var(--t-base); }
.event-card:hover { box-shadow:var(--shadow); }
.event-card__date { flex-shrink:0; width:56px; height:64px; background:var(--teal-100); border-radius:var(--radius); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:var(--s-1); }
.event-card__day   { font-size:var(--text-xl); font-weight:700; color:var(--teal-600); line-height:1; }
.event-card__month { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--cta); }
.event-card__body h3 { font-size:var(--text-md); margin-bottom:var(--s-2); }
.event-card__body h3 a { color:var(--text); }
.event-card__body h3 a:hover { color:var(--accent); }
.event-card__meta { font-size:var(--text-xs); color:var(--text-muted); display:flex; gap:var(--s-4); }

/* --------------------------------------------------------------------------
   PRINCIPAL / TEAM CARDS
   -------------------------------------------------------------------------- */
.principal-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%, 420px), 1fr)); gap:var(--s-8); }
.principal-card { background:var(--paper-card); border:1px solid var(--hair); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; }
.principal-card__img { aspect-ratio:4/3; overflow:hidden; background:var(--teal-100); }
.principal-card__img img { width:100%; height:100%; object-fit:cover; object-position:center top; display:block; transition:transform 0.4s ease; }
.principal-card:hover .principal-card__img img { transform:scale(1.02); }
.principal-card__body { padding:var(--s-8); flex:1; }
.principal-card__title { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:var(--cta); margin-bottom:var(--s-2); }
.principal-card__name { font-size:var(--text-xl); color:var(--text); margin-bottom:var(--s-4); }
.principal-card__creds { display:flex; flex-wrap:wrap; gap:var(--s-2); margin-bottom:var(--s-5); }
.principal-card__cred { background:var(--teal-100); color:var(--teal-600); font-size:var(--text-xs); font-weight:600; padding:3px var(--s-3); border-radius:var(--radius-sm); }
.principal-card p { color:var(--text-muted); font-size:var(--text-sm); line-height:1.75; }

/* --------------------------------------------------------------------------
   NEWSLETTER
   -------------------------------------------------------------------------- */
.newsletter { background:var(--teal-900); border-radius:var(--radius); padding:var(--s-10) var(--s-12); display:flex; align-items:center; justify-content:space-between; gap:var(--s-8); flex-wrap:wrap; }
.newsletter__text h3 { color:#fff; margin-bottom:var(--s-2); }
.newsletter__text p  { color:rgba(255,255,255,0.65); font-size:var(--text-sm); margin:0; }
.newsletter__form { display:flex; gap:var(--s-3); flex-wrap:wrap; }
.newsletter__form .form-input { min-width:240px; background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.2); color:#fff; }
.newsletter__form .form-input::placeholder { color:rgba(255,255,255,0.4); }
.newsletter__form .form-input:focus { border-color:var(--cta); background:rgba(255,255,255,0.12); }
@media (max-width:640px){
  .newsletter { padding:var(--s-8); }
  .newsletter__form .form-input { min-width:100%; }
  .newsletter__form { flex-direction:column; width:100%; }
  .newsletter__form .btn { width:100%; justify-content:center; }
}

/* --------------------------------------------------------------------------
   ECOSYSTEM
   -------------------------------------------------------------------------- */
.ecosystem-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--s-5); }
.ecosystem-card { border:1.5px solid var(--hair); border-radius:var(--radius); padding:var(--s-8); background:var(--paper-card); transition:box-shadow var(--t-base); }
.ecosystem-card:hover { box-shadow:var(--shadow-sm); }
.ecosystem-card--primary { border-color:var(--cta); background:var(--teal-100); }
.ecosystem-card__badge { display:inline-block; font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); margin-bottom:var(--s-3); }
.ecosystem-card--primary .ecosystem-card__badge { color:var(--cta); }
.ecosystem-card h3 { font-size:var(--text-lg); margin-bottom:var(--s-3); color:var(--text); }
.ecosystem-card--primary h3 { color:var(--teal-600); }
.ecosystem-card p { font-size:var(--text-sm); color:var(--text-muted); margin:0; }
@media (max-width:640px) { .ecosystem-grid { grid-template-columns:1fr; } }

/* --------------------------------------------------------------------------
   LOCATION CARDS
   -------------------------------------------------------------------------- */
.location-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:var(--s-4); }
.location-card { background:var(--teal-100); border-radius:var(--radius); padding:var(--s-6); }
.location-card__flag    { font-size:1.75rem; margin-bottom:var(--s-3); }
.location-card__country { font-weight:700; color:var(--teal-600); margin-bottom:var(--s-1); font-size:var(--text-base); }
.location-card p { font-size:var(--text-sm); color:var(--grey-500); margin:0; }

/* --------------------------------------------------------------------------
   PRINCIPLES (about page)
   -------------------------------------------------------------------------- */
.principle { display:flex; gap:var(--s-5); padding:var(--s-6) 0; border-bottom:1px solid var(--hair); }
.principle:last-child { border-bottom:none; }
.principle__marker { flex-shrink:0; width:8px; height:8px; background:var(--cta); border-radius:50%; margin-top:0.55rem; }
.principle h4   { margin-bottom:var(--s-2); }
.principle p    { font-size:var(--text-sm); color:var(--text-muted); margin:0; }
.principle__word { color:var(--cta); }

/* --------------------------------------------------------------------------
   REBRAND NOTICE
   -------------------------------------------------------------------------- */
.rebrand-notice { background:var(--teal-100); border:1px solid var(--teal-200); border-radius:var(--radius); padding:var(--s-6) var(--s-8); display:flex; align-items:flex-start; gap:var(--s-4); }
.rebrand-notice__icon { flex-shrink:0; width:36px; height:36px; background:var(--cta); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:var(--text-sm); font-weight:700; }
.rebrand-notice__text h4 { color:var(--teal-600); margin-bottom:var(--s-2); font-size:var(--text-sm); }
.rebrand-notice__text p  { color:var(--text-muted); font-size:var(--text-sm); margin:0; }

/* --------------------------------------------------------------------------
   GLOBAL STANDARDS BAND (inner pages)
   -------------------------------------------------------------------------- */
.standards-band { background:var(--teal-900); padding-block:clamp(var(--s-12), 6vw, var(--s-20)); position:relative; overflow:hidden; }
.standards-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(39,198,217,0.12) 0%, transparent 65%); pointer-events:none; }
.standards-band__inner { position:relative; z-index:1; max-width:var(--max-w); margin-inline:auto; padding-inline:var(--pad-x); }
.standards-band__header { text-align:center; margin-bottom:clamp(var(--s-8), 4vw, var(--s-12)); }
.standards-band__header h2 { color:#fff; margin-bottom:var(--s-3); }
.standards-band__header p { color:rgba(255,255,255,0.60); font-size:var(--text-md); max-width:600px; margin-inline:auto; margin-bottom:0; }
.standards-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%, 240px), 1fr)); gap:var(--s-4); }
.standards-pillar { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); border-radius:var(--radius); padding:var(--s-6); border-top:2px solid var(--cta); }
.standards-pillar__num { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:var(--cta); margin-bottom:var(--s-4); }
.standards-pillar h3 { color:#fff; font-size:var(--text-base); font-weight:700; margin-bottom:var(--s-3); }
.standards-pillar p { color:rgba(255,255,255,0.60); font-size:var(--text-sm); margin:0; line-height:1.7; }
.standards-pillar__link { display:inline-block; color:var(--cta); font-size:var(--text-xs); font-weight:700; margin-top:var(--s-3); text-decoration:underline; text-underline-offset:3px; transition:color var(--t-base); }
.standards-pillar__link:hover { color:var(--teal-300); }

/* --------------------------------------------------------------------------
   IMS PARTNERSHIP CALLOUT
   -------------------------------------------------------------------------- */
.ims-callout { background:var(--paper-card); border:1.5px solid var(--teal-200); border-radius:var(--radius); padding:var(--s-6); margin-top:var(--s-5); }
.ims-callout__header { display:flex; align-items:center; gap:var(--s-4); margin-bottom:var(--s-4); padding-bottom:var(--s-4); border-bottom:1px solid var(--hair); flex-wrap:wrap; }
.ims-callout__logo { height:36px; width:auto; }
.ims-callout__tag { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--cta); margin-bottom:var(--s-1); }
.ims-callout__name { font-size:var(--text-sm); font-weight:700; color:var(--text); }
.ims-callout p { font-size:var(--text-sm); color:var(--text-muted); margin-bottom:var(--s-3); }
.ims-callout p:last-of-type { margin-bottom:0; }
.ims-callout__link { display:inline-block; font-size:var(--text-xs); font-weight:700; color:var(--accent); margin-top:var(--s-3); text-decoration:underline; text-underline-offset:3px; transition:color var(--t-base); }
.ims-callout__link:hover { color:var(--accent-deep); }

/* --------------------------------------------------------------------------
   TILES SYSTEM® SECTION (IMS partnership page)
   -------------------------------------------------------------------------- */
.tiles-section { background:#0B2FC1; background-image:radial-gradient(ellipse at 88% 0%, rgba(255,255,255,0.11) 0%, transparent 52%), radial-gradient(ellipse at 12% 100%, rgba(0,0,0,0.11) 0%, transparent 50%); padding-block:clamp(var(--s-16), 9vw, 7rem); }
.tiles-section__partner { margin-bottom:var(--s-10); }
.tiles-section__pill { display:inline-flex; align-items:center; gap:var(--s-3); background:rgba(255,255,255,0.97); border-radius:100px; padding:0.55rem var(--s-5); box-shadow:0 2px 12px rgba(0,0,0,0.15); }
.tiles-section__pill img { display:block; }
.tiles-section__pill span { font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:#0B2FC1; white-space:nowrap; padding-left:var(--s-3); border-left:1px solid rgba(11,47,193,0.20); }
.tiles-section__intro { max-width:740px; }
.tiles-section__badge { display:inline-block; font-size:var(--text-xs); font-weight:700; text-transform:uppercase; letter-spacing:0.14em; color:rgba(255,255,255,0.92); background:rgba(255,255,255,0.13); border:1px solid rgba(255,255,255,0.24); padding:var(--s-1) var(--s-3); border-radius:var(--radius-sm); margin-bottom:var(--s-5); }
.tiles-section h2 { color:#fff; font-size:clamp(var(--text-3xl), 5.5vw, var(--text-5xl)); letter-spacing:-0.02em; line-height:1.1; margin-bottom:var(--s-3); }
.tiles-section__tagline { color:rgba(255,255,255,0.72); font-size:clamp(var(--text-lg), 2vw, var(--text-2xl)); font-weight:500; margin-bottom:var(--s-6); }
.tiles-section__sub { color:rgba(255,255,255,0.65); font-size:var(--text-md); line-height:1.78; margin-bottom:0; }
.tiles-section__stages { display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--s-6); margin-top:clamp(var(--s-12), 5vw, var(--s-16)); padding-top:clamp(var(--s-12), 5vw, var(--s-16)); border-top:1px solid rgba(255,255,255,0.13); margin-bottom:var(--s-12); }
.tiles-section__stage { background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.13); border-top:2px solid rgba(255,255,255,0.32); border-radius:var(--radius); padding:var(--s-8) var(--s-7) var(--s-8); transition:background 0.22s ease; }
.tiles-section__stage:hover { background:rgba(255,255,255,0.11); }
.tiles-section__stage-icon { display:block; color:rgba(255,255,255,0.62); width:26px; height:26px; margin-bottom:var(--s-5); flex-shrink:0; }
.tiles-section__stage-num { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.22em; color:rgba(255,255,255,0.30); margin-bottom:var(--s-3); }
.tiles-section__stage h4 { color:#fff; font-size:var(--text-xl); font-weight:700; margin-bottom:var(--s-1); line-height:1.2; }
.tiles-section__stage-sub { color:rgba(255,255,255,0.45); font-size:var(--text-sm); font-weight:400; font-style:italic; margin-bottom:var(--s-5); padding-bottom:var(--s-5); border-bottom:1px solid rgba(255,255,255,0.09); }
.tiles-section__stage p:last-child { color:rgba(255,255,255,0.66); font-size:var(--text-sm); line-height:1.78; margin:0; }
.tiles-section__specs { display:flex; flex-wrap:wrap; gap:var(--s-3); padding-block:var(--s-8); border-top:1px solid rgba(255,255,255,0.11); border-bottom:1px solid rgba(255,255,255,0.11); margin-bottom:var(--s-12); }
.tiles-section__specs span { font-size:var(--text-xs); font-weight:600; color:rgba(255,255,255,0.70); background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.13); padding:var(--s-2) var(--s-4); border-radius:var(--radius-sm); white-space:nowrap; }
.tiles-section .btn { font-weight:700; }
.tiles-section .btn--lg { padding:1.1rem 2.5rem; }
.tiles-section .btn-group { gap:var(--s-4); }
@media (max-width:720px){
  .tiles-section__stages { grid-template-columns:1fr; gap:var(--s-5); }
  .tiles-section .btn-group { flex-direction:column; }
  .tiles-section .btn { width:100%; justify-content:center; }
}

/* --------------------------------------------------------------------------
   FORMS
   -------------------------------------------------------------------------- */
.form-group { margin-bottom:var(--s-6); }
.form-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:0 var(--s-6); }
.form-label { display:block; font-size:var(--text-sm); font-weight:700; color:var(--text); margin-bottom:var(--s-2); }
.form-input,
.form-select,
.form-textarea {
  width:100%; padding:0.75rem 1rem;
  background:var(--paper-card); border:1.5px solid var(--hair);
  border-radius:var(--radius); color:var(--text);
  font-family:var(--font-body); font-size:var(--text-base);
  transition:border-color var(--t-base), box-shadow var(--t-base);
  -webkit-appearance:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline:none; border-color:var(--cta);
  box-shadow:0 0 0 3px rgba(39,198,217,0.12);
}
.form-input::placeholder, .form-textarea::placeholder { color:var(--text-faint); }
.form-textarea { resize:vertical; min-height:140px; }
.form-select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%238B9099' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.5rem;
}
.form-hint { font-size:var(--text-xs); color:var(--text-muted); margin-top:var(--s-2); }
@media (max-width:640px){ .form-grid-2 { grid-template-columns:1fr; } }

/* --------------------------------------------------------------------------
   INVESTIGATIONS PAGE
   -------------------------------------------------------------------------- */
.when-to-call-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%, 280px), 1fr)); gap:var(--s-4); }
.when-to-call-item { background:var(--teal-100); border-radius:var(--radius); padding:var(--s-6); border-left:3px solid var(--cta); }
.when-to-call-item h4 { color:var(--teal-600); margin-bottom:var(--s-2); font-size:var(--text-sm); }
.when-to-call-item p  { color:var(--text-muted); font-size:var(--text-sm); margin:0; }

/* --------------------------------------------------------------------------
   REWIREWORKS PAGE
   -------------------------------------------------------------------------- */
.rw-pillar { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:var(--radius); padding:var(--s-6); }
.rw-pillar h4 { color:var(--teal-300); margin-bottom:var(--s-2); font-size:var(--text-sm); }
.rw-pillar p  { color:rgba(255,255,255,0.65); font-size:var(--text-sm); margin:0; }

/* --------------------------------------------------------------------------
   SKILL BUILDING PAGE
   -------------------------------------------------------------------------- */
.skill-section { scroll-margin-top:100px; }

/* --------------------------------------------------------------------------
   SERVICE PHOTO BACKGROUNDS (services page)
   -------------------------------------------------------------------------- */
#capability-boost, #system-diagnostic, #system-intervention {
  position:relative; overflow:hidden;
  background-size:cover; background-position:center;
}
#capability-boost { background-image:url('../TealChairs.jpg'); }
#system-diagnostic, #system-intervention { background-image:url('../corridor.jpg'); }
#capability-boost::before, #system-diagnostic::before, #system-intervention::before {
  content:''; position:absolute; inset:0;
  background:rgba(245, 244, 240, 0.88); pointer-events:none;
}
#capability-boost > *, #system-diagnostic > *, #system-intervention > * { position:relative; z-index:1; }

/* --------------------------------------------------------------------------
   UTILITIES
   -------------------------------------------------------------------------- */
.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; }
.divider { height:1px; background:var(--hair); margin-block:var(--s-8); }
.mt-4  { margin-top:var(--s-4); }
.mt-6  { margin-top:var(--s-6); }
.mt-8  { margin-top:var(--s-8); }
.mt-12 { margin-top:var(--s-12); }
.mb-4  { margin-bottom:var(--s-4); }
.mb-8  { margin-bottom:var(--s-8); }

/* --------------------------------------------------------------------------
   PRINT
   -------------------------------------------------------------------------- */
@media print {
  .nav, .footer, .cta, .cta-section { display:none !important; }
  body { background:white; color:black; font-size:12pt; }
  h1 { color:var(--ink) !important; }
  h2 { color:var(--accent) !important; }
}

/* ==========================================================================
   NEW LAYOUT COMPONENTS (2026 rewrite)
   ========================================================================== */

/* ---- Hero "split" variant: hexagon mesh + visible meta rail -------------- */
body[data-hero="split"] .hero {
  background-image:
    radial-gradient(ellipse at 78% 12%, color-mix(in srgb, var(--spark) 24%, transparent) 0%, transparent 56%),
    radial-gradient(ellipse at 12% 90%, rgba(0,0,0,0.30) 0%, transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='52' viewBox='0 0 60 52'%3E%3Cpath d='M30 2L58 17v18L30 50 2 35V17z' fill='none' stroke='rgba(255,255,255,0.05)' stroke-width='1'/%3E%3C/svg%3E");
  background-size: auto, auto, 60px 52px;
}
body[data-hero="split"] .hero__label {
  background: color-mix(in srgb, var(--spark) 16%, transparent);
  color: var(--spark);
  padding: var(--s-1) var(--s-3);
  border-radius: var(--radius);
}

/* --------------------------------------------------------------------------
   WHAT WE PROVIDE — editorial numbered list
   -------------------------------------------------------------------------- */
.provide-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
  border-top: 1px solid var(--hair);
  border-right: 1px solid var(--hair);
}
.provide-item {
  padding: clamp(2rem, 3.5vw, 3rem) clamp(1.5rem, 2.5vw, 2.5rem);
  border-bottom: 1px solid var(--hair);
  border-left: 1px solid var(--hair);
}
.provide-item__num {
  display: block;
  font-size: .68rem; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--s-5);
}
.provide-item h3 { font-size: 1.2rem; margin-bottom: var(--s-3); }
.provide-item p { color: var(--text-muted); font-size: .95rem; line-height: 1.65; }

/* --------------------------------------------------------------------------
   REWIREWORKS SERVICES — definition list (dark section)
   -------------------------------------------------------------------------- */
.rw-services { border-top: 1px solid var(--hair-ink); }
.rw-service {
  padding: var(--s-6) 0;
  border-bottom: 1px solid var(--hair-ink);
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--s-8);
  align-items: baseline;
}
.rw-service__name { font-size: .95rem; font-weight: 600; color: var(--on-ink); }
.rw-service p { color: var(--on-ink-muted); font-size: .93rem; margin: 0; }
@media (max-width: 600px) {
  .rw-service { grid-template-columns: 1fr; gap: var(--s-2); }
}

/* --------------------------------------------------------------------------
   SKILL PROGRAMME CARDS — 3-column
   -------------------------------------------------------------------------- */
.skill-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
}
@media (max-width: 860px) { .skill-cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .skill-cards { grid-template-columns: 1fr; } }

.skill-card {
  background: var(--paper-card);
  border: 1px solid var(--hair);
  border-top: 3px solid var(--accent);
  padding: var(--s-8);
  display: flex; flex-direction: column; gap: var(--s-4);
  scroll-margin-top: 80px;
}
.skill-card:hover { box-shadow: var(--shadow); }
.skill-card__tag {
  display: block;
  font-size: .68rem; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--accent);
}
.skill-card h3 { font-size: 1.2rem; margin: 0; }
.skill-card p { color: var(--text-muted); font-size: .95rem; flex: 1; }

/* --------------------------------------------------------------------------
   CONTACT LAYOUT
   -------------------------------------------------------------------------- */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: start;
}
@media (max-width: 860px) { .contact-layout { grid-template-columns: 1fr; } }
.contact-aside { display: flex; flex-direction: column; gap: 0; }
.contact-detail { padding: var(--s-5) 0; border-bottom: 1px solid var(--hair); }
.contact-detail:last-child { border-bottom: none; }
.contact-detail__label {
  display: block;
  font-size: .65rem; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: var(--s-2);
}
.contact-detail a, .contact-detail p { font-size: .95rem; color: var(--text-muted); display: block; margin: 0; }
.contact-detail a:hover { color: var(--accent); }

/* ── AWI Explainer box ──────────────────────────────────────────────────── */
.awi-explainer__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: start;
}
.awi-explainer__abbr {
  color: var(--cta);
}
.awi-explainer__why {
  border-left: 1px solid var(--hair-ink);
  padding-left: clamp(1.5rem, 4vw, 3rem);
}
.awi-explainer__list {
  list-style: none;
  padding: 0;
  margin: var(--s-6) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-7);
}
.awi-explainer__list li {
  display: flex;
  gap: var(--s-4);
  align-items: flex-start;
}
.awi-explainer__icon {
  color: var(--cta);
  font-size: 1.1rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: .15rem;
}
.awi-explainer__list strong {
  display: block;
  color: var(--on-ink);
  font-size: .95rem;
  font-weight: 700;
  margin-bottom: var(--s-2);
}
.awi-explainer__list p {
  color: var(--on-ink-muted);
  font-size: .875rem;
  line-height: 1.7;
  margin: 0;
}
@media (max-width: 768px) {
  .awi-explainer__grid { grid-template-columns: 1fr; }
  .awi-explainer__why {
    border-left: none;
    border-top: 1px solid var(--hair-ink);
    padding-left: 0;
    padding-top: var(--s-7);
  }
}

/* ── INDUSTRIES GRID ─────────────────────────────────────────── */
.industries-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  margin-top: var(--s-8);
}
.industry-card {
  border: 1px solid var(--hair-strong);
  border-radius: var(--radius);
  padding: 1.25rem 1rem;
  text-align: center;
  background: var(--paper-sunk);
  transition: border-color 0.2s, background 0.2s;
}
.industry-card:hover {
  border-color: var(--cta);
  background: #fff;
}
.industry-card__label {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ink);
}

/* ── 3-COLUMN FEATURE GRID ───────────────────────────────────── */
.feature-grid--three {
  grid-template-columns: repeat(3, 1fr);
  border: none;
  gap: clamp(1.5rem, 4vw, 3rem);
}
.feature-grid--three .feature {
  border: 1px solid var(--hair-strong);
  border-radius: var(--radius);
  padding: 2rem;
  background: var(--paper-sunk);
}
.feature-grid--three .feature h4 {
  margin-bottom: var(--s-5);
}
.feature-grid--three .feature .q {
  color: var(--text-muted);
  font-weight: 400;
}
@media (max-width: 768px) {
  .feature-grid--three {
    grid-template-columns: 1fr;
  }
  .industries-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ── TILES FEATURES GRID ─────────────────────────────────────── */
.tiles-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  margin-top: var(--s-10);
}
.tiles-feature-item {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.tiles-feature-item__icon {
  font-size: 1.4rem;
  flex-shrink: 0;
  margin-top: .1rem;
}
.tiles-feature-item strong {
  display: block;
  font-weight: 700;
  margin-bottom: .35rem;
  color: var(--ink);
}
.tiles-feature-item p {
  margin: 0;
  font-size: .9rem;
  color: var(--text-muted);
}

/* ── TILES PRICING GRID ──────────────────────────────────────── */
.tiles-pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: var(--s-10);
  align-items: stretch;
}
.tiles-plan {
  border: 1px solid var(--hair-strong);
  border-radius: var(--radius);
  padding: 2rem;
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  position: relative;
}
.tiles-plan--featured {
  border-color: var(--cta);
  box-shadow: 0 0 0 2px var(--cta);
}
.tiles-plan__badge {
  position: absolute;
  top: -0.65rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--cta);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .2rem .75rem;
  border-radius: 99px;
  white-space: nowrap;
}
.tiles-plan__tier {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-faint);
}
.tiles-plan__price {
  font-size: 2rem;
  font-weight: 800;
  color: var(--ink);
  line-height: 1;
}
.tiles-plan__price span {
  font-size: 1rem;
  font-weight: 400;
  color: var(--text-muted);
}
.tiles-plan__desc {
  font-size: .875rem;
  color: var(--text-muted);
  line-height: 1.5;
}
.tiles-plan__features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  flex: 1;
}
.tiles-plan__features li {
  font-size: .85rem;
  padding-left: 1.25rem;
  position: relative;
  color: var(--ink);
}
.tiles-plan__features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--cta);
  font-weight: 700;
}
@media (max-width: 900px) {
  .tiles-pricing-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }
  .tiles-features-grid {
    grid-template-columns: 1fr;
  }
}

