/* === SELF-HOSTED FONTS (generated 2026-05-31) === */
@font-face {
  font-family: 'Archivo';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/archivo-italic-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/archivo-italic-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/archivo-italic-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/archivo-italic-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('../fonts/archivo-normal-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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/inter-normal-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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/inter-normal-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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/inter-normal-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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/inter-normal-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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/inter-normal-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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/inter-normal-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;
}
/* === END SELF-HOSTED FONTS === */

/* ============================================================
   J.A. FIELDEN — concept site
   Brand: JAF blue #184098 · safety yellow #FFC629 · black · warm neutrals
   Direction: bold / straight-shooter, "every seat at the table"
   ============================================================ */

:root {
  --blue:      #184098;
  --blue-700:  #112F70;
  --blue-900:  #0B1F4D;
  --blue-300:  #5C84DD;
  --yellow:    #FFC629;
  --yellow-600:#E5A800;
  --ink:       #0C0D12;
  --charcoal:  #16171D;
  --paper:     #F6F5F1;
  --smoke:     #ECEAE3;
  --line:      #D9D6CC;
  --gray:      #6A6E78;
  --white:     #FFFFFF;

  --maxw: 1240px;
  --gap: clamp(16px, 4vw, 40px);
  --radius: 4px;

  --display: "Archivo", system-ui, sans-serif;
  --body: "Inter", system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }

.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 200;
  background: var(--yellow); color: #000; padding: 10px 16px; font-weight: 700;
}
.skip-link:focus { left: 12px; top: 12px; }

/* ---------- keyboard focus (WCAG 2.4.7) ---------- */
:focus-visible { outline: 3px solid var(--blue); outline-offset: 3px; border-radius: 3px; }
.header :focus-visible, .hero :focus-visible, .footer :focus-visible, .section--dark :focus-visible, .section--blue :focus-visible { outline-color: var(--yellow); }

/* ---------- layout helpers ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 56px); }
.section { padding-block: clamp(64px, 9vw, 132px); position: relative; }
.section--dark  { background: var(--ink); color: #EEF0F4; }
.section--blue  { background: var(--blue); color: #fff; }
.section--paper { background: var(--paper); }
.section--smoke { background: var(--smoke); }

.eyebrow {
  font-family: var(--display);
  font-weight: 700; font-size: .8rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--blue); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 22px;
}
.section--dark .eyebrow, .section--blue .eyebrow { color: var(--yellow); }
.eyebrow::before { content: ""; width: 34px; height: 3px; background: var(--yellow); display: inline-block; }

.section__title {
  font-family: var(--display); font-weight: 800; letter-spacing: -.02em; line-height: 1.02;
  font-size: clamp(2rem, 5vw, 3.6rem); text-transform: uppercase; max-width: 16ch;
}
.lead { font-size: clamp(1.05rem, 1.6vw, 1.3rem); color: var(--gray); max-width: 60ch; margin-top: 20px; }
.section--dark .lead, .section--blue .lead { color: rgba(255,255,255,.78); }
.accent { color: var(--yellow); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--display); font-weight: 700; font-size: .95rem; letter-spacing: .04em; text-transform: uppercase;
  padding: 16px 26px; border-radius: var(--radius); transition: transform .2s var(--ease), background .2s, color .2s;
  border: 2px solid transparent; white-space: nowrap;
}
.btn svg { width: 16px; height: 16px; }
.btn--yellow { background: var(--yellow); color: #111; }
.btn--yellow:hover { background: #fff; transform: translateY(-2px); }
.btn--blue { background: var(--blue); color: #fff; }
.btn--blue:hover { background: var(--blue-700); transform: translateY(-2px); }
.btn--ghost { border-color: rgba(255,255,255,.35); color: #fff; }
.btn--ghost:hover { border-color: var(--yellow); color: var(--yellow); transform: translateY(-2px); }
.btn--dark { background: var(--ink); color:#fff; }
.btn--dark:hover { background: var(--blue); transform: translateY(-2px); }

/* ---------- header ---------- */
.header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(12,13,18,.92); backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.header__inner { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.brand { display: inline-flex; align-items: center; }
.brand__badge {
  font-family: var(--display); background: var(--blue); color: #fff;
  padding: 8px 12px 8px 12px; border-radius: 3px; letter-spacing: -.01em; font-size: 1.18rem;
  display: inline-flex; align-items: baseline; line-height: 1;
}
.brand__badge b { font-weight: 800; }
.brand__badge span { font-weight: 600; font-style: italic; }
.nav { display: flex; align-items: center; gap: clamp(14px, 2vw, 30px); }
.nav__link {
  font-family: var(--display); font-weight: 600; font-size: .9rem; letter-spacing: .03em; text-transform: uppercase;
  color: #C9CCD4; transition: color .15s; position: relative; padding: 6px 0;
}
.nav__link:hover { color: #fff; }
.nav__link::after { content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--yellow); transition:width .2s var(--ease); }
.nav__link:hover::after { width: 100%; }
.nav__cta { margin-left: 6px; }
.nav-toggle { display: none; width: 44px; height: 44px; flex-direction: column; gap: 5px; justify-content: center; align-items: center; }
.nav-toggle span { width: 24px; height: 2px; background: #fff; transition: .25s var(--ease); }

/* ---------- hero ---------- */
.hero { position: relative; background: var(--ink); color: #fff; overflow: hidden; }
.hero__bg {
  position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(120% 100% at 75% 0%, #000 40%, transparent 100%);
}
.hero__glow { position:absolute; right:-10%; top:-30%; width: 60vw; height: 60vw; background: radial-gradient(circle, rgba(24,64,152,.55), transparent 60%); filter: blur(20px); pointer-events:none; }
.hero__slash { position:absolute; left:0; right:0; bottom:0; height:8px; background: var(--yellow); }
.hero__inner { position: relative; padding-block: clamp(72px, 13vw, 168px); }
.hero__kicker {
  font-family: var(--display); font-weight: 600; font-size: clamp(.7rem,1.3vw,.82rem);
  letter-spacing: .26em; text-transform: uppercase; color: var(--blue-300); margin-bottom: 26px;
}
.hero__title {
  font-family: var(--display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(3.1rem, 11vw, 8.4rem); line-height: .9; letter-spacing: -.03em;
}
.hero__title .dot { color: var(--yellow); }
.hero__title .u-blue { color: var(--blue-300); }
.hero__sub { margin-top: 30px; font-size: clamp(1.1rem, 2vw, 1.5rem); max-width: 46ch; color: rgba(255,255,255,.82); }
.hero__meta { margin-top: 18px; font-family: var(--display); font-weight: 600; letter-spacing: .05em; text-transform: uppercase; font-size: .9rem; color: var(--yellow); }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 40px; }

.hero__stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; margin-top: clamp(48px,7vw,84px); background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.1); }
.stat { background: var(--ink); padding: 26px clamp(14px,2vw,28px); }
.stat__num { font-family: var(--display); font-weight: 800; font-size: clamp(1.8rem,4vw,2.8rem); color: #fff; line-height: 1; }
.stat__num small { color: var(--yellow); }
.stat__label { margin-top: 10px; font-size: .82rem; letter-spacing: .04em; text-transform: uppercase; color: rgba(255,255,255,.6); }

/* ---------- marquee ---------- */
.marquee { background: var(--charcoal); color:#fff; border-block: 1px solid rgba(255,255,255,.08); overflow: hidden; padding-block: 22px; }
.marquee__row { display: flex; align-items: center; gap: 54px; white-space: nowrap; }
.marquee__label { font-family: var(--display); font-weight:700; letter-spacing:.18em; text-transform:uppercase; font-size:.72rem; color: var(--gray); flex: none; }
.marquee__track { display: inline-flex; align-items:center; gap: 54px; animation: scroll 32s linear infinite; }
.marquee__item { font-family: var(--display); font-weight: 700; font-size: clamp(1rem,2vw,1.4rem); letter-spacing:.02em; color: rgba(255,255,255,.62); text-transform: uppercase; }
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes scroll { to { transform: translateX(-50%); } }

/* ---------- moat / two-col ---------- */
.split { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(30px,6vw,80px); align-items: center; }
.moat__big { font-family: var(--display); font-weight: 800; text-transform: uppercase; letter-spacing: -.02em; line-height: .98; font-size: clamp(2.4rem,6vw,4.6rem); }
.moat__big .u-blue { color: var(--blue); }
.section--dark .moat__big .u-blue, .section--blue .moat__big .u-blue { color: var(--yellow); }
.moat__panel { background: var(--charcoal); color:#fff; border-radius: 6px; padding: clamp(26px,4vw,44px); border-left: 6px solid var(--yellow); }
.moat__panel h3 { font-family: var(--display); text-transform: uppercase; letter-spacing: .04em; font-size: 1.1rem; margin-bottom: 8px; color: var(--yellow); }
.moat__panel p + h3 { margin-top: 22px; }
.moat__panel p { color: rgba(255,255,255,.78); }

/* ---------- what we build ---------- */
.builds-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(250px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 52px; }
.build-card { background: var(--white); padding: clamp(26px,3vw,38px); transition: background .25s, color .25s; position: relative; }
.build-card:hover { background: var(--ink); color: #fff; }
.build-card__no { font-family: var(--display); font-weight: 800; font-size: 2.4rem; color: var(--line); line-height: 1; }
.build-card:hover .build-card__no { color: var(--yellow); }
.build-card__title { font-family: var(--display); font-weight: 800; text-transform: uppercase; letter-spacing: -.01em; font-size: 1.35rem; margin: 14px 0 12px; }
.build-card__desc { font-size: .98rem; color: var(--gray); }
.build-card:hover .build-card__desc { color: rgba(255,255,255,.7); }
.build-card__list { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 8px; }
.build-card__list li { font-family: var(--display); font-weight:600; font-size: .72rem; letter-spacing: .04em; text-transform: uppercase; color: var(--blue); border: 1px solid var(--line); padding: 5px 9px; border-radius: 40px; }
.build-card:hover .build-card__list li { color: var(--yellow); border-color: rgba(255,255,255,.2); }

/* ---------- featured work ---------- */
.work-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: clamp(16px,2vw,24px); margin-top: 52px; }
.work-card { position: relative; border-radius: 6px; overflow: hidden; min-height: 340px; display: flex; flex-direction: column; justify-content: flex-end; color: #fff; isolation: isolate; }
.work-card__media { position: absolute; inset: 0; z-index: -2; background:
    linear-gradient(135deg, var(--blue-900), var(--blue)); }
.work-card:nth-child(2) .work-card__media { background: linear-gradient(135deg,#1b1c22,#3a3d4a); }
.work-card:nth-child(3) .work-card__media { background: linear-gradient(135deg, var(--blue-700), #2b50a8); }
.work-card:nth-child(4) .work-card__media { background: linear-gradient(135deg,#202126,#454956); }
.work-card__media::after { content:""; position:absolute; inset:0;
  background-image: linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px), linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size: 34px 34px; }
.work-card::before { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(to top, rgba(8,9,14,.92) 8%, rgba(8,9,14,.15) 60%, transparent); }
.work-card__body { padding: clamp(20px,2.4vw,30px); }
.work-card__tag { font-family: var(--display); font-weight:700; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color: var(--yellow); }
.work-card__title { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size: 1.5rem; margin: 8px 0 6px; line-height: 1.04; }
.work-card__line { font-size:.92rem; color: rgba(255,255,255,.74); }
.work-card__cta { margin-top: 16px; font-family: var(--display); font-weight:700; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:#fff; display:inline-flex; gap:8px; align-items:center; }
.work-card__cta span { transition: transform .2s var(--ease); }
.work-card:hover .work-card__cta span { transform: translateX(5px); color: var(--yellow); }
.work-note { margin-top: 22px; font-size:.85rem; color: var(--gray); }

/* ---------- fielden five ---------- */
.five-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: clamp(16px,2vw,26px); margin-top: 52px; }
.five-item { border-top: 3px solid var(--yellow); padding-top: 20px; }
.five-item__no { font-family: var(--display); font-weight:800; color: var(--blue-300); font-size:.85rem; letter-spacing:.1em; }
.section--blue .five-item__no { color: var(--yellow); }
.five-item__title { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:1.15rem; margin:10px 0 8px; }
.five-item__desc { font-size:.92rem; color: rgba(255,255,255,.74); }

/* ---------- why / values ---------- */
.why-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); gap: clamp(16px,2vw,24px); margin-top: 52px; }
.value { background:#fff; border:1px solid var(--line); border-radius:6px; padding: clamp(24px,3vw,34px); transition: transform .2s var(--ease), box-shadow .2s; }
.value:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(16,23,55,.1); }
.value__quote { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:1.25rem; line-height:1.1; }
.value__quote .accent { color: var(--blue); }
.value__label { margin-top: 14px; color: var(--gray); font-size:.95rem; }

/* ---------- safety strip ---------- */
.safety__inner { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:24px; }
.safety__title { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size: clamp(1.5rem,3.4vw,2.6rem); max-width: 22ch; }

/* ---------- CTA band ---------- */
.cta-band { background: var(--yellow); color: #111; }
.cta-band__inner { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap: 28px; padding-block: clamp(48px,7vw,90px); }
.cta-band__title { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.02em; line-height:.98; font-size: clamp(2rem,5.5vw,4rem); max-width: 18ch; }
.cta-band__aside { display:flex; flex-direction:column; gap:14px; }
.cta-band__phone { font-family: var(--display); font-weight:700; font-size:1.2rem; }

/* ---------- footer ---------- */
.footer { background: var(--ink); color: #B9BDC7; padding-block: clamp(56px,7vw,86px) 32px; }
.footer__grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: clamp(28px,4vw,52px); }
.footer__logo { background:#fff; border-radius:4px; padding:14px; width: 150px; }
.footer__brand p { margin-top: 18px; font-size:.92rem; max-width: 32ch; color: #8E93A0; }
.footer__col h4 { font-family: var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; color:#fff; margin-bottom: 16px; }
.footer__col a { display:block; padding:6px 0; font-size:.95rem; color:#B9BDC7; transition: color .15s; }
.footer__col a:hover { color: var(--yellow); }
.footer__contact a { color:#fff; font-weight:600; }
.footer__legal { margin-top: clamp(40px,5vw,64px); padding-top: 24px; border-top:1px solid rgba(255,255,255,.1); display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; font-size:.82rem; color:#71757F; }
.footer__legal a:hover { color: var(--yellow); }

/* ---------- reveal animation ---------- */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none;} .marquee__track{animation:none;} html{scroll-behavior:auto;} }

/* ---------- responsive ---------- */
@media (max-width: 940px){
  .split { grid-template-columns: 1fr; }
  .hero__stats { grid-template-columns: repeat(2,1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px){
  .nav-toggle { display:flex; }
  .nav {
    position: fixed; inset: 76px 0 auto 0; background: var(--ink);
    flex-direction: column; align-items: flex-start; gap: 4px; padding: 20px clamp(20px,5vw,56px) 30px;
    border-bottom: 1px solid rgba(255,255,255,.1);
    transform: translateY(-130%); transition: transform .3s var(--ease); height: auto;
  }
  .nav--open { transform: translateY(0); }
  .nav__link { font-size: 1.1rem; padding: 12px 0; width:100%; }
  .nav__cta { margin: 10px 0 0; width:100%; justify-content:center; }
  .nav--open ~ .nav-toggle span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
  .header__inner:has(.nav--open) .nav-toggle span:nth-child(2){ opacity:0; }
  .header__inner:has(.nav--open) .nav-toggle span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }
}
@media (max-width: 480px){
  .hero__stats { grid-template-columns: 1fr 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .cta-band__inner { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   INNER PAGES (added 2026-05-30) — Company, Projects, Services,
   Safety, Careers, Team, Contact, 404. Reuses the homepage system.
   ============================================================ */

/* compact dark hero for inner pages */
.page-hero { position: relative; background: var(--ink); color:#fff; overflow:hidden; }
.page-hero__bg { position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:56px 56px; mask-image: radial-gradient(120% 100% at 80% 0%, #000 40%, transparent 100%); }
.page-hero__glow { position:absolute; right:-12%; top:-40%; width:55vw; height:55vw; pointer-events:none;
  background: radial-gradient(circle, rgba(24,64,152,.5), transparent 60%); filter: blur(20px); }
.page-hero__slash { position:absolute; left:0; right:0; bottom:0; height:6px; background: var(--yellow); }
.page-hero__inner { position:relative; padding-block: clamp(56px,9vw,116px); }
.crumbs { font-family: var(--display); font-weight:600; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color: var(--blue-300); margin-bottom:18px; display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.crumbs a:hover { color: var(--yellow); }
.crumbs span { color: rgba(255,255,255,.4); }
.page-hero__title { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.025em; line-height:.96; font-size: clamp(2.4rem,7vw,5rem); }
.page-hero__title .u-blue { color: var(--blue-300); }
.page-hero__title .dot { color: var(--yellow); }
.page-hero__sub { margin-top:22px; font-size: clamp(1.05rem,1.8vw,1.35rem); color: rgba(255,255,255,.8); max-width: 58ch; }

/* readable prose column */
.prose { max-width: 70ch; }
.prose p { font-size: clamp(1.02rem,1.5vw,1.16rem); color: #2C2E36; margin-bottom: 22px; }
.section--dark .prose p, .section--blue .prose p { color: rgba(255,255,255,.84); }
.prose h3 { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:1.4rem; margin: 36px 0 12px; }
.prose strong { color: var(--blue); }
.section--dark .prose strong, .section--blue .prose strong { color: var(--yellow); }

/* light fact bar */
.factbar { display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background: var(--line); border:1px solid var(--line); margin-top: 48px; }
.factbar .stat { background:#fff; }
.factbar .stat__num { color: var(--blue); }
.factbar .stat__num small { color: var(--yellow-600); }
.factbar .stat__label { color: var(--gray); }

/* projects, grouped */
.proj-group { margin-top: 48px; }
.proj-group__head { display:flex; align-items:baseline; gap:14px; border-bottom:2px solid var(--blue); padding-bottom:12px; margin-bottom: 22px; }
.proj-group__head h3 { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size: clamp(1.3rem,2.6vw,1.9rem); }
.proj-group__count { font-family: var(--display); font-weight:700; color: var(--gray); font-size:.78rem; letter-spacing:.1em; }
.proj-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(258px,1fr)); gap: 14px; }
.proj-card { background:#fff; border:1px solid var(--line); border-radius:6px; padding: 22px 24px; transition: transform .2s var(--ease), box-shadow .2s, border-color .2s; }
.proj-card:hover { transform: translateY(-3px); box-shadow: 0 16px 36px rgba(16,23,55,.1); border-color: var(--blue-300); }
.proj-card__name { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:1.08rem; line-height:1.12; }
.proj-card__meta { margin-top:8px; font-size:.86rem; color: var(--gray); }
.proj-card__tag { display:inline-block; margin-top:14px; font-family: var(--display); font-weight:600; font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color: var(--blue); border:1px solid var(--line); padding:4px 10px; border-radius:40px; }

/* team grid */
.team-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: clamp(16px,2vw,22px); margin-top: 48px; }
.team-card { background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.team-card__photo { aspect-ratio: 4/3; background: linear-gradient(135deg,var(--blue-900),var(--blue)); display:flex; align-items:flex-end; }
.team-card__photo span { font-family: var(--display); font-weight:800; font-size:3rem; color: rgba(255,255,255,.2); padding: 0 0 10px 18px; text-transform:uppercase; line-height:1; }
.team-card__body { padding: 18px 20px 22px; }
.team-card__name { font-family: var(--display); font-weight:800; text-transform:uppercase; font-size:1.05rem; }
.team-card__role { margin-top:6px; color: var(--blue); font-weight:600; font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; }

/* feature tiles (services / safety / careers) */
.tile-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(244px,1fr)); gap: clamp(16px,2vw,22px); margin-top: 44px; }
.tile { background:#fff; border:1px solid var(--line); border-radius:8px; padding: clamp(24px,3vw,32px); border-top: 4px solid var(--yellow); }
.section--dark .tile, .section--blue .tile { background: var(--charcoal); border-color: rgba(255,255,255,.1); }
.tile__no { font-family: var(--display); font-weight:800; color: var(--blue-300); font-size:.82rem; letter-spacing:.1em; }
.tile h3 { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:1.18rem; margin:8px 0 10px; }
.tile p { color: var(--gray); font-size:.96rem; }
.section--dark .tile p, .section--blue .tile p { color: rgba(255,255,255,.76); }
.tile ul { margin-top: 14px; }
.tile ul li { position:relative; padding-left:18px; margin-bottom:7px; font-size:.92rem; color: var(--gray); }
.section--dark .tile ul li { color: rgba(255,255,255,.72); }
.tile ul li::before { content:""; position:absolute; left:0; top:9px; width:8px; height:8px; background: var(--yellow); }

/* contact */
.contact-split { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(30px,5vw,64px); align-items:start; }
.form { background:#fff; border:1px solid var(--line); border-radius:10px; padding: clamp(24px,3vw,40px); }
.field { margin-bottom: 20px; position: relative; }
.field > label { display:block; font-family: var(--display); font-weight:600; font-size:.76rem; letter-spacing:.06em; text-transform:uppercase; color: var(--ink); margin-bottom:8px; }
.field .req { color: var(--yellow-600); }
.field input, .field select, .field textarea {
  width:100%; font: inherit; color: var(--ink); background: var(--paper);
  border:1.5px solid var(--line); border-radius:6px; padding: 13px 14px; transition: border-color .15s, box-shadow .15s;
}
.field textarea { min-height: 132px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(24,64,152,.16); }
.field--error input, .field--error textarea, .field--error select { border-color: #C0392B; background:#FDF3F2; }
.field__err { display:none; color:#C0392B; font-size:.82rem; margin-top:6px; font-weight:600; }
.field--error .field__err { display:block; }
.form__row { display:grid; grid-template-columns:1fr 1fr; gap: 18px; }
.hp { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-success { display:none; background: var(--blue); color:#fff; border-radius:10px; padding: clamp(28px,4vw,46px); }
.form-success.is-on { display:block; }
.form-success h3 { font-family: var(--display); font-weight:800; text-transform:uppercase; font-size:1.6rem; margin-bottom:10px; }
.form-success p { color: rgba(255,255,255,.85); }
.contact-block { margin-bottom: 30px; }
.contact-block h3 { font-family: var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:1.1rem; margin: 0 0 8px; }
.contact-block a.big { font-family: var(--display); font-weight:800; font-size: clamp(1.25rem,2.4vw,1.7rem); color: var(--blue); display:inline-block; }
.contact-block a.big:hover { color: var(--blue-700); }
.contact-block .muted { color: var(--gray); font-size:.95rem; }

/* concept credit banner */
.concept-note { background: var(--smoke); border-top:1px solid var(--line); }
.concept-note .container { padding-block: 16px; font-size:.8rem; color: var(--gray); text-align:center; }

@media (max-width: 860px){ .contact-split { grid-template-columns: 1fr; } }
@media (max-width: 640px){ .form__row { grid-template-columns: 1fr; } .factbar { grid-template-columns: 1fr 1fr; } }
