/* =============================================================================
   W4.5 SELF-HOSTED FONTS — Bai Jamjuree + Work Sans, Latin/Latin-Ext only
   ============================================================================ */
/* latin-ext */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-700-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Bai Jamjuree';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/assets/fonts/bai-jamjuree-700-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('/assets/fonts/work-sans-300-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('/assets/fonts/work-sans-300-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/assets/fonts/work-sans-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/assets/fonts/work-sans-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/assets/fonts/work-sans-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/assets/fonts/work-sans-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/assets/fonts/work-sans-600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/assets/fonts/work-sans-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/assets/fonts/work-sans-700-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/assets/fonts/work-sans-700-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ACT Cyber — main stylesheet, extracted from editorial-mockup-v18.html */

:root {
  --pine: #001719;       /* Shadow Pine */
  --green: #004344;      /* Fortress Green */
  --teal: #007474;       /* Quantum Teal */
  --teal-bright: #5cbdbd;
  --teal-light: #2D9595;
  --teal-edge: rgba(0,116,116,0.32);
  --teal-soft: rgba(0,116,116,0.10);
  --white: #FFFFFF;
  --ink: #F1F4F4;
  --ink-muted: #9DB2B3;
  --ink-dim: #849A9B;  /* WCAG AA: 6.4:1 vs --pine (was #6A8081, 4.43:1 - failed AA) */
  --rule: #00343A;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Work Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--pine);
  color: var(--ink);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: 'Bai Jamjuree', sans-serif; font-weight: 500; letter-spacing: -0.005em; line-height: 1.15; }
a { color: inherit; text-decoration: none; }

/* ============ LOGO ============ */
.logo {
  display: inline-flex; align-items: center; cursor: pointer;
}
.logo svg { height: 30px; width: auto; display: block; }
.footer .logo svg { height: 32px; }

/* ============ NAV ============ */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(0,23,25,0.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
  padding: 22px 48px;
}
.nav-inner {
  max-width: 1480px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center; gap: 40px;
}
.nav-links { display: flex; gap: 36px; align-items: center; }
.nav-links a {
  font-family: 'Work Sans', sans-serif; font-size: 0.93rem;
  color: var(--ink-muted); cursor: pointer;
  padding: 4px 0; border-bottom: 1px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}
.nav-links a:hover { color: var(--white); }
.nav-links a.active { color: var(--teal-bright); border-bottom-color: var(--teal-bright); }
.nav-cta {
  padding: 12px 22px; background: var(--teal); color: var(--white);
  border: none; cursor: pointer;
  font-family: 'Work Sans', sans-serif; font-weight: 500; font-size: 0.92rem;
  transition: background 0.2s;
}
.nav-cta:hover { background: var(--teal-light); }

/* ============ PAGE SHELL ============ */
.page { display: none; }
.page.active { display: block; }

/* ============ HERO ============ */
.hero {
  position: relative; overflow: hidden;
  max-width: 1480px; margin: 0 auto;
  padding: 100px 48px 120px;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 80px;
  align-items: center;
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
.hero-bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.32; display: block; }
.hero-bg::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(90deg, var(--pine) 0%, rgba(0,23,25,0.85) 40%, rgba(0,23,25,0.55) 100%),
    radial-gradient(ellipse at 75% 50%, rgba(0,116,116,0.20) 0%, transparent 60%);
}
.hero > *:not(.hero-bg) { position: relative; z-index: 1; }

.hero-meta {
  font-family: 'Work Sans', sans-serif; font-size: 0.76rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 28px;
  display: flex; align-items: center; gap: 14px;
}
.hero-meta::before { content: ''; width: 32px; height: 1px; background: var(--teal-bright); }
.hero h1 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  line-height: 1.06; letter-spacing: -0.02em;
  margin-bottom: 30px; color: var(--white);
}
.hero h1 .em { color: var(--teal-bright); font-weight: 600; }
.hero h1 .light { font-weight: 400; color: var(--ink-muted); }
.hero p {
  font-size: 1.16rem; line-height: 1.65; color: var(--ink-muted);
  max-width: 540px; margin-bottom: 36px; font-weight: 300;
}
.hero p strong { color: var(--white); font-weight: 500; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px; background: var(--teal); color: var(--white);
  font-family: 'Work Sans', sans-serif; font-weight: 500; font-size: 0.94rem;
  cursor: pointer; border: none; transition: background 0.2s;
  letter-spacing: 0.01em;
}
.btn:hover { background: var(--teal-light); }
.btn.ghost { background: transparent; color: var(--white); border: 1px solid var(--rule); }
.btn.ghost:hover { border-color: var(--teal-bright); color: var(--teal-bright); }
.actions { display: flex; gap: 16px; flex-wrap: wrap; }

/* Hero card */
.hero-card {
  position: relative; z-index: 2;
  background: var(--green); border: 1px solid var(--teal-edge);
  padding: 44px 40px;
}
.hero-card-label {
  font-family: 'Work Sans', sans-serif; font-size: 0.72rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 22px;
}
.hero-card h3 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.4rem; margin-bottom: 18px; line-height: 1.3;
}
.hero-card .stat-list { list-style: none; }
.hero-card .stat-list li {
  display: grid; grid-template-columns: 100px 1fr; gap: 18px;
  padding: 14px 0; border-top: 1px solid var(--teal-edge);
  font-family: 'Work Sans', sans-serif; align-items: baseline;
}
.hero-card .stat-list li .k {
  font-family: 'Bai Jamjuree', sans-serif; font-size: 1.5rem; font-weight: 600;
  color: var(--teal-bright); letter-spacing: -0.02em;
}
.hero-card .stat-list li .v { font-size: 0.86rem; color: var(--ink-muted); line-height: 1.5; font-weight: 300; }

/* ============ BANDS / SECTIONS ============ */
.band { padding: 100px 0; }
.band.green { background: var(--green); }
.band-inner { max-width: 1100px; margin: 0 auto; padding: 0 48px; }
.band-label {
  font-family: 'Work Sans', sans-serif; font-size: 0.78rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 22px;
  display: flex; gap: 14px; align-items: center;
}
.band-label::before { content: ''; width: 32px; height: 1px; background: var(--teal-bright); }
.band h2 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  font-size: clamp(2rem, 3.6vw, 3rem); line-height: 1.15;
  letter-spacing: -0.015em; color: var(--white);
  margin-bottom: 36px; max-width: 820px;
}
.band h2 .em { color: var(--teal-bright); }
.band .lede {
  font-family: 'Work Sans', sans-serif; font-weight: 300;
  font-size: 1.45rem; line-height: 1.55;
  color: var(--white); max-width: 800px; margin-bottom: 36px;
}
.band .lede em { font-style: italic; color: var(--teal-bright); }
.band p {
  color: var(--ink-muted); font-size: 1.05rem; line-height: 1.78;
  max-width: 760px; margin-bottom: 18px; font-weight: 300;
}
.band p strong { color: var(--white); font-weight: 500; }

/* Split image-text */
.band.split .band-inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 70px;
  max-width: 1240px; align-items: center;
}
.band.split .band-img {
  aspect-ratio: 4/3; overflow: hidden;
  border: 1px solid var(--teal-edge); position: relative;
}
.band.split .band-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.band.split .band-img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,116,116,0.18), rgba(0,23,25,0.30));
  pointer-events: none;
}
.band.split .band-img .badge {
  position: absolute; left: 18px; top: 18px;
  background: var(--teal); color: var(--white);
  padding: 6px 12px; font-family: 'Work Sans', sans-serif;
  font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase;
  z-index: 2;
}

/* Frameworks panel */
.fw-grid {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 1px; background: var(--rule); margin-top: 40px;
}
.fw-cell { background: var(--pine); padding: 32px 24px; }
.band.green .fw-cell { background: var(--green); }
.fw-cell h3, .fw-cell h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 600;
  color: var(--teal-bright); font-size: 1.4rem;
  margin-bottom: 14px; letter-spacing: 0.02em;
}
.fw-cell p { font-size: 0.88rem; color: var(--ink-muted); line-height: 1.6; font-weight: 300; }

/* Pillars */
.pillar-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 30px; margin-top: 40px;
}
.pillar {
  background: var(--pine); border: 1px solid var(--rule);
  padding: 36px 32px; transition: border-color 0.2s;
}
.band.green .pillar { background: var(--pine); }
.pillar:hover { border-color: var(--teal-edge); }
.pillar-num {
  font-family: 'Work Sans', sans-serif; font-size: 0.72rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 16px;
}
.pillar h3, .pillar h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 600;
  color: var(--white); font-size: 1.35rem; margin-bottom: 14px;
}
.pillar p { color: var(--ink-muted); font-size: 0.97rem; line-height: 1.7; font-weight: 300; }
.pillar p em { color: var(--teal-bright); font-style: normal; }

/* Tech tags */
.tech-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 28px; }
.tech-tags span {
  padding: 8px 14px; border: 1px solid var(--teal-edge);
  color: var(--teal-bright); font-family: 'Work Sans', sans-serif;
  font-size: 0.78rem; letter-spacing: 0.06em;
}

/* Image divider */
.img-divider {
  width: 100%; height: 280px; overflow: hidden; position: relative;
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
}
.img-divider img { width: 100%; height: 100%; object-fit: cover; display: block; }
.img-divider::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(0deg, var(--pine) 0%, transparent 35%, transparent 65%, var(--pine) 100%),
    linear-gradient(135deg, rgba(0,116,116,0.25), rgba(0,23,25,0.4));
  pointer-events: none;
}
.img-divider .cap {
  position: absolute; left: 48px; bottom: 28px; z-index: 2;
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal-bright);
  display: flex; align-items: center; gap: 12px;
}
.img-divider .cap::before { content: ''; width: 28px; height: 1px; background: var(--teal-bright); }

/* CTA */
.cta {
  position: relative; overflow: hidden;
  padding: 80px 48px;
}
.cta-img { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.cta-img img { width: 100%; height: 100%; object-fit: cover; opacity: 0.28; display: block; }
.cta-img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,116,116,0.85) 0%, rgba(0,67,68,0.92) 100%);
  mix-blend-mode: multiply;
}
.cta-inner {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr auto;
  gap: 60px; align-items: center;
}
.cta h3 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 1.2; margin-bottom: 12px;
}
.cta h3 .em { color: var(--teal-bright); }
.cta p { color: rgba(255,255,255,0.85); font-size: 1.05rem; max-width: 600px; font-weight: 300; }
.cta .btn { background: var(--white); color: var(--pine); }
.cta .btn:hover { background: var(--ink); }

/* ============ SCHEDULE (Services page) ============ */
.schedule {
  max-width: 1240px; margin: 0 auto; padding: 0 48px;
}
.schedule-row {
  display: grid; grid-template-columns: 80px 240px 1fr;
  gap: 30px; padding: 36px 0;
  border-bottom: 1px solid var(--rule); align-items: start;
}
.schedule-row .code {
  font-family: 'Work Sans', sans-serif; font-size: 0.78rem;
  color: var(--teal-bright); letter-spacing: 0.16em;
  font-weight: 500; padding-top: 6px;
}
.schedule-row .title {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  font-size: 1.32rem; color: var(--white);
  letter-spacing: -0.01em; line-height: 1.3;
}
.schedule-row .title .sub {
  display: block; font-family: 'Work Sans', sans-serif;
  font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-dim); margin-top: 6px;
}
.schedule-row .desc { color: var(--ink-muted); font-size: 0.97rem; line-height: 1.7; font-weight: 300; }
.schedule-row .desc em { color: var(--ink-dim); font-style: italic; }
.schedule-row .desc .tags {
  display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px;
  font-family: 'Work Sans', sans-serif; font-size: 0.72rem;
  letter-spacing: 0.06em;
}
.schedule-row .desc .tags span {
  padding: 5px 10px; border: 1px solid var(--teal-edge); color: var(--teal-bright);
}

.schedule-row.featured {
  background: linear-gradient(90deg, rgba(0,116,116,0.15) 0%, transparent 80%);
  border-top: 1px solid var(--teal-edge);
  padding-left: 24px; padding-right: 24px;
}

/* ============ METHOD PHASES ============ */
.method-flow {
  max-width: 1100px; margin: 40px auto 0;
}
.method-step {
  display: grid; grid-template-columns: 100px 240px 1fr;
  gap: 32px; padding: 32px 0;
  border-top: 1px solid var(--rule); align-items: start;
}
.method-step:last-child { border-bottom: 1px solid var(--rule); }
.method-step .phase {
  font-family: 'Work Sans', sans-serif; font-size: 0.78rem;
  color: var(--teal-bright); letter-spacing: 0.18em;
  text-transform: uppercase; padding-top: 6px;
}
.method-step .name {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  font-size: 1.35rem; color: var(--white);
  letter-spacing: -0.01em;
}
.method-step .detail { color: var(--ink-muted); font-size: 0.98rem; line-height: 1.75; font-weight: 300; }
.method-step .detail .arte {
  display: block; margin-top: 12px;
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  color: var(--ink-dim); letter-spacing: 0.06em;
}
.method-step .detail .arte span { color: var(--teal-bright); margin-right: 8px; }

/* ============ ARCHITECTURE DIAGRAM ============ */
.arch-canvas {
  max-width: 1240px; margin: 40px auto 0;
  background: var(--green); padding: 36px;
  border: 1px solid var(--teal-bright);
}
.arch-canvas-hdr {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  color: var(--ink-muted); letter-spacing: 0.18em; text-transform: uppercase;
  margin-bottom: 24px; padding-bottom: 18px; border-bottom: 1px solid var(--teal-light);
}
.arch-canvas-hdr .l { color: var(--teal-bright); display: flex; align-items: center; gap: 8px; }
.arch-canvas-hdr .l::before { content: ''; width: 8px; height: 8px; background: var(--teal-bright); border-radius: 50%; animation: pulse 2.4s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }
.arch-canvas svg { width: 100%; height: auto; display: block; }
.arch-annotation-row {
  max-width: 1240px; margin: 30px auto 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.arch-anno {
  background: rgba(0,116,116,0.10);
  border-left: 3px solid var(--teal-bright);
  padding: 20px 22px;
}
.arch-anno .key {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  color: var(--teal-bright); letter-spacing: 0.16em;
  margin-bottom: 8px;
}
.arch-anno h3, .arch-anno h4 { font-family: 'Bai Jamjuree', sans-serif; font-weight: 500; color: var(--white); font-size: 1rem; margin-bottom: 8px; }
.arch-anno p { color: var(--ink-muted); font-size: 0.84rem; line-height: 1.55; font-weight: 300; }

/* ============ TIMELINE COMPARISON ============ */
.cmp { margin-top: 30px; max-width: 1100px; }
.cmp-header {
  display: grid; grid-template-columns: 200px repeat(12, 1fr);
  gap: 2px; padding-bottom: 10px; border-bottom: 1px solid var(--rule);
  font-family: 'Work Sans', sans-serif; font-size: 0.66rem;
  color: var(--ink-dim); letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase;
}
.cmp-header .scale { grid-column: 2 / span 12; display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
.cmp-header .scale span { text-align: right; padding-right: 4px; }
.cmp-row {
  display: grid; grid-template-columns: 200px repeat(12, 1fr);
  gap: 2px; padding: 6px 0; align-items: center;
}
.cmp-row .label {
  color: var(--ink-muted); font-size: 0.84rem;
  font-family: 'Work Sans', sans-serif; padding-right: 14px;
}
.cmp-row .label.head {
  color: var(--white); font-family: 'Bai Jamjuree', sans-serif;
  font-size: 1.05rem; font-weight: 500;
  border-top: 1px solid var(--rule); padding-top: 14px; margin-top: 10px;
}
.cmp-row.head { padding-top: 16px; }
.cmp-bar { background: var(--rule); height: 10px; }
.cmp-bar.act { background: var(--teal-bright); }
.cmp-bar.weak { background: rgba(229,107,92,0.6); }
.cmp-bar.concurrent { background: repeating-linear-gradient(90deg, var(--teal-bright) 0 6px, transparent 6px 10px); }

/* ============ CREDENTIALS TABLE ============ */
.creds { max-width: 1100px; margin-top: 30px; }
.cred-row {
  display: grid; grid-template-columns: 240px 1fr;
  gap: 32px; padding: 22px 0;
  border-top: 1px solid var(--rule); align-items: baseline;
}
.cred-row:last-child { border-bottom: 1px solid var(--rule); }
.cred-row .k {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-dim);
}
.cred-row .v { color: var(--white); font-size: 1rem; font-weight: 400; }
.cred-row .v .note { display: block; color: var(--ink-muted); font-size: 0.9rem; margin-top: 4px; font-weight: 300; }

/* ============ CONTACT FORM ============ */
.form-wrap {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px;
  max-width: 1100px;
}
.form { display: grid; gap: 24px; }
.form label {
  display: block; font-family: 'Work Sans', sans-serif;
  font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-dim); margin-bottom: 8px;
}
.form input, .form select, .form textarea {
  width: 100%; background: transparent; border: none;
  border-bottom: 1px solid var(--rule); color: var(--white);
  padding: 10px 0; font-family: 'Work Sans', sans-serif;
  font-size: 1rem; outline: none; transition: border-color 0.2s;
}
.form input:focus, .form select:focus, .form textarea:focus { border-color: var(--teal-bright); }
.form select { color: var(--white); appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--teal-bright) 50%), linear-gradient(135deg, var(--teal-bright) 50%, transparent 50%); background-position: calc(100% - 14px) 1.2em, calc(100% - 8px) 1.2em; background-size: 6px 6px; background-repeat: no-repeat; }
.form select option { background: var(--pine); color: var(--white); }
.form textarea { min-height: 110px; resize: vertical; }

.contact-meta .block {
  padding: 22px 0; border-top: 1px solid var(--rule);
}
.contact-meta .block:last-child { border-bottom: 1px solid var(--rule); }
.contact-meta .k {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-dim); margin-bottom: 8px;
}
.contact-meta .v { font-size: 1.05rem; }
.contact-meta .v a:hover { color: var(--teal-bright); }
.contact-meta .v.muted { color: var(--ink-muted); font-size: 0.95rem; line-height: 1.65; font-weight: 300; }

/* ============ FOOTER ============ */
.footer {
  background: var(--pine); padding: 70px 48px 30px;
  border-top: 1px solid var(--rule);
}
.footer-inner {
  max-width: 1480px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 48px; margin-bottom: 48px;
}
.footer-about p {
  color: var(--ink-muted); font-size: 0.92rem; line-height: 1.7;
  margin-top: 18px; max-width: 320px; font-weight: 300;
}
.footer-col h5 {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal-bright); font-weight: 500; margin-bottom: 18px;
}
.footer-col li {
  list-style: none; margin-bottom: 10px;
  font-size: 0.92rem; color: var(--ink-muted); cursor: pointer;
}
.footer-col li:hover { color: var(--white); }
.footer-meta {
  max-width: 1480px; margin: 0 auto; padding-top: 24px;
  border-top: 1px solid var(--rule);
  display: flex; justify-content: space-between;
  font-family: 'Work Sans', sans-serif; font-size: 0.78rem;
  color: var(--ink-dim); flex-wrap: wrap; gap: 16px;
}

/* ============ SUB-PAGE HERO (Smaller) ============ */
.hero.sub {
  display: block; padding: 80px 48px 80px;
  max-width: 1480px;
}
.hero.sub h1 {
  font-size: clamp(2.2rem, 4.4vw, 3.6rem);
  margin-bottom: 26px; max-width: 940px;
}
.hero.sub p { max-width: 720px; }
.hero.sub .breadcrumb {
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-dim); margin-bottom: 28px;
  display: flex; gap: 14px; align-items: center;
}
.hero.sub .breadcrumb .ref { color: var(--teal-bright); }

/* ============ CREDENTIALS — cert cards + assurance ============ */
.cert-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 40px;
}
.cert-grid.two { grid-template-columns: repeat(2, 1fr); }
.cert {
  background: var(--pine); border: 1px solid var(--rule);
  padding: 32px 30px; transition: border-color 0.2s, transform 0.2s;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.band.green .cert { background: var(--pine); }
.cert:hover { border-color: var(--teal-edge); }
.cert::after {
  content: '▸ ACTIVE';
  position: absolute; top: 18px; right: 22px;
  font-family: 'Work Sans', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.18em; color: var(--teal-bright);
  font-weight: 500; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 6px;
}
.cert-symbol {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 700;
  font-size: 2.2rem; color: var(--teal-bright);
  letter-spacing: -0.02em; line-height: 1;
}
.cert-name {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.05rem; line-height: 1.35;
}
.cert-issuer {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-dim);
}
.cert-desc {
  color: var(--ink-muted); font-size: 0.92rem; line-height: 1.7;
  font-weight: 300; margin-top: 4px;
}

.assure-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px; margin-top: 40px;
}
.assure {
  background: var(--green); border: 1px solid var(--teal-edge);
  padding: 30px 32px;
}
.band.green .assure { background: var(--pine); border-color: var(--rule); }
.assure-label {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 14px;
}
.assure-key {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 600;
  color: var(--white); font-size: 1.8rem; line-height: 1.1;
  margin-bottom: 10px; letter-spacing: -0.01em;
}
.assure-detail { color: var(--ink-muted); font-size: 0.88rem; line-height: 1.6; font-weight: 300; }

/* ============ PARTNERING — value cards, pack, case studies, process ============ */
.value-stack { display: flex; flex-direction: column; gap: 14px; }
.value-card {
  background: var(--pine); border: 1px solid var(--rule);
  padding: 22px 26px; transition: border-color 0.2s;
}
.band.green .value-card { background: var(--pine); }
.value-card:hover { border-color: var(--teal-edge); }
.value-card h3, .value-card h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  font-size: 1.05rem; color: var(--white);
  margin-bottom: 8px; letter-spacing: -0.005em;
}
.value-card p {
  color: var(--ink-muted); font-size: 0.92rem;
  line-height: 1.6; font-weight: 300; margin-bottom: 0;
  max-width: 100%;
}

.callout-band {
  border-top: 1px solid var(--teal-edge);
  border-bottom: 1px solid var(--teal-edge);
  background: rgba(0,116,116,0.08);
  padding: 50px 48px;
}
.callout-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 30px 1fr;
  gap: 30px; align-items: start;
}
.callout-mark {
  font-size: 1.6rem; color: var(--teal-bright);
  line-height: 1;
}
.callout-inner h3 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.5rem;
  line-height: 1.25; margin-bottom: 12px;
  letter-spacing: -0.005em;
}
.callout-inner h3 .em { color: var(--teal-bright); font-style: italic; font-weight: 400; }
.callout-inner p {
  color: var(--ink-muted); font-size: 1rem; line-height: 1.7;
  font-weight: 300; max-width: 820px;
}

.pack-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--rule); margin-top: 40px;
}
.pack-card {
  background: var(--pine); padding: 30px 28px;
}
.band.green .pack-card { background: var(--green); }
.pack-type {
  display: inline-block; padding: 4px 10px;
  border: 1px solid var(--teal-edge); color: var(--teal-bright);
  font-family: 'Work Sans', sans-serif; font-size: 0.66rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  margin-bottom: 16px;
}
.pack-card h3, .pack-card h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.15rem;
  margin-bottom: 10px;
}
.pack-card > p {
  color: var(--ink-muted); font-size: 0.92rem;
  line-height: 1.6; font-weight: 300;
  margin-bottom: 14px; max-width: 100%;
}
.pack-card ul {
  list-style: none; font-family: 'Work Sans', sans-serif;
  font-size: 0.84rem; color: var(--ink-muted); font-weight: 300;
}
.pack-card li { padding: 4px 0; }
.pack-card li::before {
  content: '— '; color: var(--teal-bright);
}

.case-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 40px;
}
.case-card {
  background: var(--pine); border: 1px solid var(--rule);
  padding: 30px 28px;
}
.band.green .case-card { background: var(--pine); }
.case-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 20px; padding-bottom: 14px;
  border-bottom: 1px solid var(--rule); gap: 10px;
}
.case-org {
  font-family: 'Work Sans', sans-serif; font-size: 0.78rem;
  color: var(--ink-muted); letter-spacing: 0.06em;
}
.case-tag {
  font-family: 'Work Sans', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.18em; color: var(--teal-bright);
  border: 1px solid var(--teal-edge);
  padding: 4px 9px; text-transform: uppercase; flex-shrink: 0;
}
.case-card h3, .case-card h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.15rem;
  margin-bottom: 12px; letter-spacing: -0.005em;
}
.case-card > p {
  color: var(--ink-muted); font-size: 0.92rem;
  line-height: 1.6; font-weight: 300;
  margin-bottom: 22px; max-width: 100%;
}
.case-metrics {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 14px; padding-top: 18px;
  border-top: 1px solid var(--rule);
}
.case-metrics > div {
  display: flex; flex-direction: column; gap: 4px;
}
.case-metrics .m-key {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 600;
  color: var(--teal-bright); font-size: 1.4rem;
  letter-spacing: -0.01em; line-height: 1;
}
.case-metrics .m-cap {
  font-family: 'Work Sans', sans-serif; font-size: 0.66rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim);
}

.process-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 24px; margin-top: 40px;
  border-top: 1px solid var(--teal-edge); padding-top: 30px;
}
.process-step {
  border-right: 1px solid var(--rule); padding-right: 24px;
}
.process-step:last-child { border-right: none; }
.process-step .step-num {
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  letter-spacing: 0.18em; color: var(--teal-bright);
  margin-bottom: 14px;
}
.process-step h3, .process-step h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.15rem; margin-bottom: 10px;
}
.process-step p {
  color: var(--ink-muted); font-size: 0.92rem;
  line-height: 1.6; font-weight: 300;
}

/* ============ INLINE LINKS ============ */
a.inline-link, a.inline-link:visited {
  color: var(--teal-bright);
  text-decoration: underline;
  text-decoration-color: rgba(79,179,179,0.45);
  text-underline-offset: 3px;
  transition: text-decoration-color 0.2s, color 0.2s;
}
a.inline-link:hover { text-decoration-color: var(--teal-bright); color: var(--white); }
.arch-canvas svg a text { cursor: pointer; transition: fill 0.2s; }
.arch-canvas svg a:hover text { fill: #FFFFFF; }

/* ============ ENGAGEMENT MODELS — three operating options ============ */
.model-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 40px;
}
.model-card {
  background: var(--pine); border: 1px solid var(--rule);
  padding: 32px 30px;
  display: flex; flex-direction: column;
  transition: border-color 0.2s, transform 0.2s;
}
.band.green .model-card { background: var(--pine); }
.model-card:hover { border-color: var(--teal-edge); transform: translateY(-2px); }
.model-num {
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  letter-spacing: 0.18em; color: var(--teal-bright);
  margin-bottom: 14px; text-transform: uppercase;
}
.model-card h3, .model-card h4 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.3rem;
  margin-bottom: 14px; letter-spacing: -0.005em;
}
.model-card p {
  color: var(--ink-muted); font-size: 0.95rem;
  line-height: 1.65; font-weight: 300;
  margin-bottom: 18px; max-width: 100%;
  flex-grow: 1;
}
.model-best {
  font-family: 'Work Sans', sans-serif; font-size: 0.78rem;
  letter-spacing: 0.02em; color: var(--ink-muted);
  border-top: 1px solid var(--rule); padding-top: 14px;
  font-style: italic; line-height: 1.5;
}
.model-best strong { color: var(--teal-bright); font-style: normal; font-weight: 500; }

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px) {
  .hero { grid-template-columns: 1fr; gap: 60px; padding: 60px 32px; }
  .band.split .band-inner { grid-template-columns: 1fr; gap: 40px; }
  .fw-grid { grid-template-columns: repeat(2, 1fr); }
  .pillar-grid { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 40px; }
  .cta-inner { grid-template-columns: 1fr; gap: 30px; }
  .form-wrap { grid-template-columns: 1fr; gap: 40px; }
  .schedule-row { grid-template-columns: 1fr; gap: 12px; }
  .method-step { grid-template-columns: 1fr; gap: 10px; }
  .arch-annotation-row { grid-template-columns: repeat(2, 1fr); }
  .nav-links { display: none; }
  .cred-row { grid-template-columns: 1fr; gap: 8px; }
  .cmp-header, .cmp-row { grid-template-columns: 1fr; }
  .cmp-header .scale, .cmp-bar { display: none; }
  .cert-grid, .cert-grid.two { grid-template-columns: 1fr; }
  .assure-grid { grid-template-columns: 1fr; }
  .pack-grid { grid-template-columns: repeat(2, 1fr); }
  .case-grid { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .model-grid { grid-template-columns: 1fr; }
  .process-step { border-right: none; border-bottom: 1px solid var(--rule); padding-bottom: 18px; padding-right: 0; }
  .callout-inner { grid-template-columns: 1fr; gap: 16px; }
  .callout-band { padding: 40px 24px; }
}
@media (max-width: 640px) {
  .pack-grid, .process-grid { grid-template-columns: 1fr; }
  .case-metrics { grid-template-columns: 1fr; }
  .nav, .hero, .band-inner, .cta, .footer { padding-left: 22px; padding-right: 22px; }
  .schedule, .arch-canvas, .arch-annotation-row { padding-left: 22px; padding-right: 22px; }
  .footer-inner { grid-template-columns: 1fr; }
  .arch-annotation-row { grid-template-columns: 1fr; }
  .img-divider .cap { left: 22px; bottom: 18px; font-size: 0.66rem; }
  .img-divider { height: 200px; }
}

/* ============ LEGAL PAGES ============ */
.legal-hero {
  max-width: 1100px; margin: 0 auto;
  padding: 80px 48px 0;
}
.legal-eyebrow {
  font-family: 'Work Sans', sans-serif; font-size: 0.74rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 22px;
  display: flex; align-items: center; gap: 14px;
}
.legal-eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--teal-bright); }
.legal-hero h1 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  font-size: clamp(2.2rem, 4.4vw, 3.4rem);
  line-height: 1.1; letter-spacing: -0.02em;
  color: var(--white); margin-bottom: 20px;
}
.legal-meta {
  font-family: 'Work Sans', sans-serif; font-size: 0.86rem;
  color: var(--ink-muted); margin-bottom: 24px; font-weight: 300;
}
.legal-rule {
  border: none; border-top: 1px solid var(--rule);
  margin: 0;
}
.legal-body {
  max-width: 820px; margin: 0 auto;
  padding: 60px 48px 0;
  font-family: 'Work Sans', sans-serif; font-weight: 300;
  color: var(--ink); font-size: 1rem; line-height: 1.75;
}
.legal-body h2 {
  font-family: 'Bai Jamjuree', sans-serif; font-weight: 500;
  color: var(--white); font-size: 1.15rem;
  letter-spacing: 0.06em; text-transform: uppercase;
  margin: 44px 0 18px; padding-top: 24px;
  border-top: 1px solid var(--rule);
}
.legal-body h2:first-child { border-top: none; padding-top: 0; margin-top: 0; }
.legal-body p { color: var(--ink); margin-bottom: 16px; font-weight: 300; }
.legal-body p strong { color: var(--white); font-weight: 500; }
.legal-body ul {
  list-style: none; margin: 4px 0 18px; padding-left: 0;
}
.legal-body ul li {
  padding-left: 28px; position: relative;
  margin-bottom: 10px; color: var(--ink);
}
.legal-body ul li::before {
  content: '—'; position: absolute; left: 0; top: 0;
  color: var(--teal-bright);
}
.legal-body ol.clauses {
  list-style: none; padding-left: 0; counter-reset: clause;
  margin: 4px 0 18px;
}
.legal-body ol.clauses > li {
  counter-increment: clause;
  padding-left: 40px; position: relative;
  margin-bottom: 12px; color: var(--ink);
}
.legal-body ol.clauses > li::before {
  content: '(' counter(clause, lower-alpha) ')';
  position: absolute; left: 0; top: 0;
  color: var(--teal-bright); font-weight: 500;
  font-family: 'Work Sans', sans-serif; font-size: 0.92rem;
}
.legal-body a {
  color: var(--teal-bright); text-decoration: underline;
  text-decoration-color: rgba(79,179,179,0.45);
  text-underline-offset: 3px;
}
.legal-body a:hover { color: var(--white); }
.legal-contact {
  margin-top: 12px; padding: 22px 26px;
  background: rgba(0,116,116,0.10);
  border-left: 3px solid var(--teal-bright);
}
.legal-contact p { margin-bottom: 4px; color: var(--ink); }
.legal-contact p:last-child { margin-bottom: 0; }
.form-privacy {
  margin-top: 14px; font-family: 'Work Sans', sans-serif;
  font-size: 0.82rem; color: var(--ink-muted); font-weight: 300;
}
.form-privacy a { color: var(--teal-bright); }
.form-privacy a:hover { color: var(--white); }
@media (max-width: 1024px) {
  .legal-hero { padding: 60px 22px 0; }
  .legal-body { padding: 40px 22px 0; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
}

/* ============ PARTNER STRIP (Credentials hero) ============ */
.partner-strip {
  margin-top: 40px; padding-top: 28px;
  border-top: 1px solid var(--rule);
  max-width: 720px;
}
.partner-strip .label {
  font-family: 'Work Sans', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--teal-bright); margin-bottom: 18px;
}
.partner-strip .logos {
  display: flex; align-items: center; gap: 36px;
}
.partner-strip .logos > .partner {
  display: inline-flex; align-items: center;
  height: 36px;
}
.partner-strip .logos > .partner.fortinet {
  height: 30px;
}
.partner-strip .logos > .partner svg {
  height: 100%; width: auto; display: block;
}
.partner-strip .logos > .divider {
  width: 1px; height: 26px; background: var(--rule);
}
@media (max-width: 640px) {
  .partner-strip .logos { gap: 20px; }
  .partner-strip .logos > .partner { height: 28px; }
}

/* ============ CONTACT FORM SUBMIT STATES ============ */
.contact-success {
  padding: 30px 32px;
  background: var(--green);
  border: 1px solid var(--teal-bright);
  margin-top: 20px;
  max-width: 600px;
}
.contact-success h3 {
  color: var(--teal-bright);
  margin-bottom: 14px;
  font-family: 'Bai Jamjuree', sans-serif;
  font-size: 1.4rem;
  font-weight: 500;
}
.contact-success p {
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.65;
  font-weight: 300;
  margin-bottom: 8px;
}
.contact-success p:last-child { margin-bottom: 0; }
.contact-success a { color: var(--teal-bright); text-decoration: underline; text-underline-offset: 3px; }
.contact-success a:hover { color: var(--white); }
.contact-error {
  margin-top: 14px;
  padding: 12px 16px;
  background: rgba(229, 107, 92, 0.10);
  border-left: 3px solid #e56b5c;
  color: var(--white);
  font-family: 'Work Sans', sans-serif;
  font-size: 0.92rem;
  font-weight: 400;
  line-height: 1.5;
}


/* ============================================================================
   Utility classes — replaces inline style="..." for CSP compliance.
   Added during W3 inline-style refactor (task #51).
   ============================================================================ */

/* --- Visibility --- */
.is-hidden { display: none; }

/* --- Positioning --- */
.is-relative { position: relative; }

/* --- Honeypot (off-screen accessible field) --- */
.honeypot {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* --- Spacing modifiers --- */
.mb-14 { margin-bottom: 14px; }
.mt-24 { margin-top: 24px; }
.mt-28 { margin-top: 28px; }
.mt-32 { margin-top: 32px; }
.mt-36 { margin-top: 36px; }
.mt-40 { margin-top: 40px; }

/* --- Band-inner width variants --- */
.band-inner.is-wide   { max-width: 1240px; }
.band-inner.is-medium { max-width: 1200px; }

/* --- Text colour + style modifiers --- */
.text-white-normal { color: var(--white); font-style: normal; }
.text-white-medium { color: var(--white); font-weight: 500; }
.text-teal-italic  { color: var(--teal-bright); font-style: italic; }
.text-dim-italic   { color: var(--ink-dim); font-style: italic; }
.text-tiny-dim-italic { color: var(--ink-dim); font-style: italic; font-size: 0.7rem; }

/* --- Inline meta-stamp (used near track-record numbers) --- */
.subtle-meta {
  margin-top: 24px;
  font-family: 'Work Sans', sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: var(--ink-dim);
}

/* --- Editorial callout (quote-style block, left-rule) --- */
.callout {
  margin-top: 36px;
  font-size: 0.92rem;
  color: var(--ink-dim);
  border-left: 2px solid var(--teal-bright);
  padding: 4px 0 4px 16px;
  font-style: italic;
  max-width: 760px;
}
.callout.is-sm   { margin-top: 28px; font-size: 0.88rem; }
.callout.mt-28   { margin-top: 28px; }

/* --- 3-column grid override (used on metrics rows) --- */
.grid-3 {
  grid-template-columns: repeat(3, 1fr);
  margin-top: 40px;
}

/* --- Grid-column placement (page-specific schematics) --- */
.col-2-2  { grid-column: 2 / span 2; }
.col-3-2  { grid-column: 3 / span 2; }
.col-3-4  { grid-column: 3 / span 4; }
.col-4-1  { grid-column: 4 / span 1; }
.col-5-2  { grid-column: 5 / span 2; }
.col-6-4  { grid-column: 6 / span 4; }
.col-9-3  { grid-column: 9 / span 3; }
.col-11-3 { grid-column: 11 / span 3; }
