/* ============================================================
   GLOBALBRIDGE — Global stylesheet
   v1.0 — Boutique institutional design system
   ============================================================ */

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.7;
  color: #1A2332;
  background: #F8F6F1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* TYPOGRAPHY */
.serif { font-family: 'Cormorant Garamond', Georgia, serif; }
h1, h2, h3, h4 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500; color: #1A2332; line-height: 1.15; }
h1 { font-size: clamp(36px, 5vw, 64px); letter-spacing: -0.01em; }
h2 { font-size: clamp(28px, 3.5vw, 48px); }
h3 { font-size: clamp(22px, 2.5vw, 32px); }
h4 { font-size: clamp(18px, 2vw, 22px); }
p { font-size: 16px; line-height: 1.8; color: #1A2332; }

/* TAGS — small gold uppercase labels */
.tag {
  display: inline-block;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #C9A96E;
  margin-bottom: 24px;
}
.tag-dark { color: #C9A96E; }

/* CONTAINER */
.container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: 820px; margin: 0 auto; padding: 0 24px; }
.container-tight { max-width: 720px; margin: 0 auto; padding: 0 24px; }

/* SECTIONS */
section { padding: 100px 0; }
.section-dark { background: #0F1B2D; color: #F0EBE0; }
.section-dark h1, .section-dark h2, .section-dark h3 { color: #F0EBE0; }
.section-dark p { color: #C8D0DA; }
.section-dark .tag { color: #C9A96E; }
.section-ivory { background: #F8F6F1; }

/* LINKS — text style with gold underline */
.link-gold {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #C9A96E;
  border-bottom: 1px solid #C9A96E;
  padding-bottom: 2px;
  transition: border-bottom-width 0.2s ease, padding-bottom 0.2s ease;
  display: inline-block;
}
.link-gold:hover { border-bottom-width: 2px; padding-bottom: 1px; }
.section-dark .link-gold { color: #C9A96E; }

/* ============================================================
   HEADER
   ============================================================ */
header.site-header {
  position: sticky;
  top: 0;
  background: #F8F6F1;
  border-bottom: 0.5px solid #D4C9B0;
  z-index: 100;
  padding: 18px 0;
}
header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

/* Logo lockup */
.logo-lockup { display: flex; align-items: center; gap: 12px; }
.logo-symbol {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}
.logo-wordmark {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: 0.16em;
  color: #0F1B2D;
}

/* Nav */
nav.site-nav { display: flex; align-items: center; gap: 28px; }
nav.site-nav a {
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: #1A2332;
  transition: color 0.2s ease;
  position: relative;
}
nav.site-nav a:hover { color: #C9A96E; }
nav.site-nav a.active { color: #C9A96E; }

/* Language switcher */
.lang-switcher { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 500; letter-spacing: 0.15em; text-transform: uppercase; }
.lang-switcher a { color: #6B6155; transition: color 0.2s ease; }
.lang-switcher a:hover { color: #C9A96E; }
.lang-switcher a.active { color: #C9A96E; }
.lang-sep { color: #D4C9B0; }

/* Mobile menu toggle */
.menu-toggle { display: none; font-size: 24px; color: #1A2332; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  background: #0F1B2D;
  color: #F0EBE0;
  min-height: 80vh;
  display: flex;
  align-items: center;
  padding: 120px 0 100px;
}
.hero .container { width: 100%; }
.hero .tag { color: #C9A96E; }
.hero h1 { color: #F0EBE0; max-width: 900px; margin-bottom: 32px; }
.hero p.subhead {
  font-size: clamp(16px, 1.5vw, 19px);
  color: #C8D0DA;
  font-weight: 300;
  max-width: 640px;
  margin-bottom: 48px;
  line-height: 1.7;
}
.hero-links { display: flex; flex-wrap: wrap; gap: 32px; align-items: center; }
.hero-links .link-gold { color: #C9A96E; }

/* ============================================================
   STATEMENT — large serif quote
   ============================================================ */
.statement {
  background: #F8F6F1;
  padding: 120px 0;
  text-align: center;
}
.statement p {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 400;
  line-height: 1.5;
  color: #1A2332;
  max-width: 760px;
  margin: 0 auto;
}

/* ============================================================
   CAPABILITIES — 4 column grid with hairlines
   ============================================================ */
.capabilities { background: #F8F6F1; padding: 100px 0; }
.capabilities-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.capability {
  padding: 0 28px;
  border-right: 0.5px solid #D4C9B0;
}
.capability:last-child { border-right: none; }
.capability .num {
  font-size: 13px;
  font-weight: 400;
  color: #C9A96E;
  letter-spacing: 0.1em;
  margin-bottom: 16px;
  display: block;
}
.capability h3 {
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 16px;
  line-height: 1.25;
}
.capability p {
  font-size: 14px;
  line-height: 1.7;
  color: #6B6155;
  font-weight: 300;
}

/* ============================================================
   APPROACH SECTION — dark, two columns + steps
   ============================================================ */
.approach { background: #0F1B2D; color: #F0EBE0; padding: 120px 0; }
.approach-grid {
  display: grid;
  grid-template-columns: 40% 60%;
  gap: 64px;
  align-items: start;
}
.approach h2 { color: #F0EBE0; max-width: 380px; }
.approach p { color: #C8D0DA; font-size: 16px; line-height: 1.8; margin-bottom: 40px; }
.approach-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 18px;
  color: #F0EBE0;
}
.approach-steps .step { display: inline-flex; align-items: center; gap: 8px; }
.approach-steps .step .num { color: #C9A96E; font-family: 'Manrope', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 0.05em; }
.approach-steps .arrow { color: #C9A96E; opacity: 0.7; margin: 0 8px; }

/* ============================================================
   JURISDICTIONS — 3 columns
   ============================================================ */
.jurisdictions { background: #F8F6F1; padding: 100px 0; }
.jurisdictions-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
}
.jurisdiction { padding-top: 24px; border-top: 1px solid #C9A96E; max-width: 280px; }
.jurisdiction h3 {
  font-size: 28px;
  font-weight: 500;
  margin-bottom: 16px;
}
.jurisdiction p {
  font-size: 14px;
  color: #6B6155;
  line-height: 1.7;
}

/* ============================================================
   PERIMETER — centered narrow disclaimer
   ============================================================ */
.perimeter { background: #F8F6F1; padding: 100px 0; }
.perimeter .container { max-width: 880px; }
.perimeter h2 { margin-bottom: 32px; }
.perimeter p {
  font-size: 15px;
  line-height: 1.8;
  color: #6B6155;
  font-weight: 300;
}

/* ============================================================
   FIRM PAGE - PAGE HEADER
   ============================================================ */
.page-header {
  background: #F8F6F1;
  padding: 140px 0 80px;
}
.page-header h1 { margin-bottom: 32px; max-width: 880px; }
.page-header p.lead {
  font-size: clamp(17px, 1.5vw, 20px);
  font-weight: 300;
  color: #6B6155;
  line-height: 1.6;
  max-width: 720px;
}

/* TWO COLUMN SECTION (Origin, Position, Senior coordination) */
.two-col { padding: 100px 0; }
.two-col .grid { display: grid; grid-template-columns: 40% 60%; gap: 64px; align-items: start; }
.two-col h2 { font-size: clamp(26px, 3vw, 36px); margin-bottom: 0; }
.two-col p + p { margin-top: 24px; }

/* PROFESSIONAL NETWORK */
.network { background: #F8F6F1; padding: 100px 0; }
.network h2 { margin-bottom: 24px; text-align: left; }
.network .intro { max-width: 720px; margin-bottom: 64px; font-size: 16px; color: #6B6155; line-height: 1.7; }
.network-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
.partner-card {
  padding-top: 24px;
  border-top: 1px solid #C9A96E;
}
.partner-card .country {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: #C9A96E;
  text-transform: uppercase;
  margin-bottom: 4px;
  display: block;
}
.partner-card .role {
  font-family: 'Manrope', sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.15em;
  color: #6B6155;
  text-transform: uppercase;
  margin-bottom: 14px;
  display: block;
}
.partner-card .firm {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-weight: 500;
  color: #1A2332;
  line-height: 1.25;
  margin-bottom: 14px;
}
.partner-card p {
  font-size: 13px;
  font-weight: 300;
  color: #6B6155;
  line-height: 1.7;
}

/* PRINCIPLES — 3 columns with roman numerals */
.principles { background: #F8F6F1; padding: 100px 0; }
.principles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 64px;
}
.principle { padding: 0 32px; border-right: 0.5px solid #D4C9B0; }
.principle:last-child { border-right: none; }
.principle .roman {
  font-family: 'Cormorant Garamond', serif;
  font-size: 40px;
  font-weight: 500;
  color: #C9A96E;
  margin-bottom: 16px;
  display: block;
}
.principle h3 { font-size: 22px; margin-bottom: 16px; }
.principle p { font-size: 14px; color: #6B6155; line-height: 1.7; }

/* CLOSING CTA */
.cta-closing {
  background: #0F1B2D;
  color: #F0EBE0;
  padding: 100px 0;
  text-align: center;
}
.cta-closing h2 { color: #F0EBE0; margin-bottom: 24px; max-width: 720px; margin-left: auto; margin-right: auto; }
.cta-closing p { color: #C8D0DA; max-width: 640px; margin: 0 auto 32px; font-size: 15px; }

/* ============================================================
   SERVICES PAGE
   ============================================================ */
.service-block { padding: 80px 0; }
.service-block.dark { background: #0F1B2D; color: #F0EBE0; }
.service-block.dark h2 { color: #F0EBE0; }
.service-block.dark p { color: #C8D0DA; }
.service-block .grid { display: grid; grid-template-columns: 40% 60%; gap: 64px; align-items: start; }
.service-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(72px, 8vw, 96px);
  font-weight: 500;
  color: #C9A96E;
  line-height: 1;
  margin-bottom: 24px;
}
.service-block h2 { font-size: clamp(24px, 3vw, 32px); margin-bottom: 24px; }
.service-block .tag { font-size: 11px; }
.service-block .includes-title {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #C9A96E;
  margin: 32px 0 16px;
  display: block;
}
.service-block ul { list-style: none; padding: 0; }
.service-block ul li {
  font-size: 14px;
  line-height: 1.7;
  padding: 14px 0;
  border-top: 0.5px solid #D4C9B0;
  display: flex;
  gap: 12px;
}
.service-block.dark ul li { border-top-color: rgba(212, 201, 176, 0.2); color: #C8D0DA; }
.service-block ul li::before { content: "—"; color: #C9A96E; flex-shrink: 0; }
.service-block ul li:last-child { border-bottom: 0.5px solid #D4C9B0; }
.service-block.dark ul li:last-child { border-bottom-color: rgba(212, 201, 176, 0.2); }

/* ENGAGEMENT MODEL — 3 columns */
.engagement { background: #F8F6F1; padding: 100px 0; }
.engagement-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 56px;
}
.engagement-phase { padding: 0 28px; border-right: 0.5px solid #D4C9B0; }
.engagement-phase:last-child { border-right: none; }
.engagement-phase .phase-tag {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: #C9A96E;
  text-transform: uppercase;
  margin-bottom: 16px;
  display: block;
}
.engagement-phase h3 { font-size: 22px; margin-bottom: 16px; }
.engagement-phase p { font-size: 14px; color: #6B6155; line-height: 1.7; }

/* ============================================================
   METHOD PAGE — stages
   ============================================================ */
.stage { padding: 100px 0; }
.stage.dark { background: #0F1B2D; color: #F0EBE0; }
.stage.dark h2 { color: #F0EBE0; }
.stage.dark p { color: #C8D0DA; }
.stage .grid {
  display: grid;
  grid-template-columns: 30% 70%;
  gap: 56px;
  align-items: start;
}
.stage .stage-left { border-right: 0.5px solid #D4C9B0; padding-right: 32px; }
.stage.dark .stage-left { border-right-color: rgba(212, 201, 176, 0.2); }
.stage .stage-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 96px;
  font-weight: 500;
  color: #C9A96E;
  line-height: 1;
  margin-bottom: 16px;
}
.stage .stage-label {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.2em;
  color: #C9A96E;
  text-transform: uppercase;
}
.stage h2 { font-size: clamp(24px, 3vw, 32px); margin-bottom: 24px; }
.outputs-title {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #C9A96E;
  margin: 32px 0 16px;
  display: block;
}
.outputs-list { list-style: none; padding: 0; }
.outputs-list li {
  font-size: 14px;
  line-height: 1.7;
  padding: 12px 0;
  border-top: 0.5px solid #D4C9B0;
  display: flex;
  gap: 12px;
}
.stage.dark .outputs-list li { border-top-color: rgba(212, 201, 176, 0.2); color: #C8D0DA; }
.outputs-list li::before { content: "•"; color: #C9A96E; flex-shrink: 0; font-weight: bold; }
.outputs-list li:last-child { border-bottom: 0.5px solid #D4C9B0; }
.stage.dark .outputs-list li:last-child { border-bottom-color: rgba(212, 201, 176, 0.2); }

/* WILL NOT DO list */
.wont-do { background: #F8F6F1; padding: 100px 0; }
.wont-do .grid { display: grid; grid-template-columns: 40% 60%; gap: 48px; }
.wont-do-list { list-style: none; padding: 0; }
.wont-do-list li {
  font-size: 14px;
  line-height: 1.7;
  padding: 16px 0;
  border-top: 0.5px solid #D4C9B0;
  display: flex;
  gap: 12px;
  color: #1A2332;
}
.wont-do-list li::before { content: "—"; color: #C9A96E; flex-shrink: 0; }
.wont-do-list li:last-child { border-bottom: 0.5px solid #D4C9B0; }

/* ============================================================
   COMPLIANCE STANDARDS — roman numeral grid
   ============================================================ */
.standards { padding: 120px 0; background: #0F1B2D; color: #F0EBE0; }
.standards h2 { color: #F0EBE0; }
.standards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 48px;
  margin-top: 56px;
}
.standard-item .roman {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  font-weight: 500;
  color: #C9A96E;
  margin-bottom: 8px;
  display: block;
}
.standard-item h3 { font-size: 18px; color: #F0EBE0; margin-bottom: 12px; }
.standard-item p { font-size: 14px; color: #C8D0DA; line-height: 1.7; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-details { background: #F8F6F1; padding: 100px 0; }
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.contact-col {
  padding: 0 32px;
  border-right: 0.5px solid #D4C9B0;
}
.contact-col:first-child { padding-left: 0; }
.contact-col:last-child { border-right: none; padding-right: 0; }
.contact-col .tag { font-size: 11px; margin-bottom: 12px; }
.contact-col h3 {
  font-size: 22px;
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #C9A96E;
  width: 40px;
  border-bottom-width: 1px;
  position: relative;
}
.contact-col h3::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 40px;
  height: 1px;
  background: #C9A96E;
}
.contact-col .lines { font-size: 15px; line-height: 1.9; color: #1A2332; }

/* FORM */
.form-section { background: #0F1B2D; color: #F0EBE0; padding: 120px 0; }
.form-section .container-narrow { max-width: 800px; }
.form-section h2 { color: #F0EBE0; }
.form-section .intro {
  color: #C8D0DA;
  margin-bottom: 48px;
  font-size: 15px;
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.form-grid .form-row-full { grid-column: 1 / -1; }
.form-field { display: flex; flex-direction: column; }
.form-field label {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.15em;
  color: #C9A96E;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.form-field label .req { color: #C9A96E; }
.form-field input,
.form-field select,
.form-field textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(201, 169, 110, 0.4);
  color: #F0EBE0;
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  font-weight: 400;
  padding: 8px 0 12px;
  outline: none;
  transition: border-color 0.2s ease;
}
.form-field input::placeholder,
.form-field textarea::placeholder { color: #6B7A8A; font-weight: 300; font-size: 15px; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus { border-bottom-color: #C9A96E; }
.form-field textarea { resize: vertical; min-height: 100px; line-height: 1.7; }
.form-field select { -webkit-appearance: none; -moz-appearance: none; appearance: none; background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A96E' fill='none' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 4px center; padding-right: 24px; }
.form-field select option { background: #0F1B2D; color: #F0EBE0; }
.form-check { display: flex; gap: 12px; align-items: flex-start; }
.form-check input[type="checkbox"] { width: 16px; height: 16px; margin-top: 4px; accent-color: #C9A96E; flex-shrink: 0; }
.form-check label { font-family: 'Manrope', sans-serif; font-size: 13px; color: #C8D0DA; font-weight: 300; line-height: 1.6; letter-spacing: 0; text-transform: none; }
.form-error { color: #E89A8A; font-size: 12px; margin-top: 6px; display: none; }
.form-error.show { display: block; }
.form-submit {
  margin-top: 32px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #C9A96E;
  border-bottom: 1px solid #C9A96E;
  padding-bottom: 4px;
  background: none;
  cursor: pointer;
  align-self: flex-start;
  transition: border-bottom-width 0.2s ease;
}
.form-submit:hover { border-bottom-width: 2px; }
.form-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.gdpr-line {
  font-size: 12px;
  color: #8AA0B8;
  font-weight: 300;
  margin-top: 32px;
  line-height: 1.6;
}
.gdpr-line a { color: #C9A96E; border-bottom: 1px solid rgba(201,169,110,0.4); }

/* Confirmation panel */
.form-confirmation { display: none; padding: 60px 0; text-align: center; }
.form-confirmation.show { display: block; }
.form-confirmation h3 { color: #F0EBE0; font-size: 32px; margin-bottom: 16px; }
.form-confirmation p { color: #C8D0DA; font-size: 16px; max-width: 600px; margin: 0 auto; }

/* WHAT TO EXPECT — 3 cols */
.expect { padding: 100px 0; background: #F8F6F1; }
.expect-grid { display: grid; grid-template-columns: repeat(3, 1fr); margin-top: 56px; }
.expect-item { padding: 0 28px; border-right: 0.5px solid #D4C9B0; }
.expect-item:last-child { border-right: none; }
.expect-item .num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 40px;
  font-weight: 500;
  color: #C9A96E;
  display: block;
  margin-bottom: 12px;
  line-height: 1;
}
.expect-item h3 { font-size: 18px; margin-bottom: 12px; }
.expect-item p { font-size: 14px; color: #6B6155; line-height: 1.7; }

/* ============================================================
   LEGAL PAGES — narrow column
   ============================================================ */
.legal-page { padding: 140px 0 100px; background: #F8F6F1; }
.legal-page h1 { margin-bottom: 16px; }
.legal-page .last-updated {
  font-size: 13px;
  color: #6B6155;
  font-style: italic;
  margin-bottom: 80px;
}
.legal-section { margin-bottom: 64px; padding-bottom: 64px; border-bottom: 0.5px solid #D4C9B0; }
.legal-section:last-of-type { border-bottom: none; }
.legal-section h2 {
  font-size: 22px;
  margin-bottom: 24px;
  display: flex;
  gap: 16px;
  align-items: baseline;
}
.legal-section .legal-num {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.15em;
  color: #C9A96E;
  text-transform: uppercase;
}
.legal-section .legal-em { color: #C9A96E; }
.legal-section p {
  font-size: 15px;
  line-height: 1.8;
  margin-bottom: 16px;
  color: #1A2332;
}
.legal-section ul.legal-list { list-style: none; padding: 0; margin: 16px 0; }
.legal-section ul.legal-list li {
  font-size: 15px;
  line-height: 1.7;
  padding: 12px 0;
  border-top: 0.5px solid #D4C9B0;
  display: flex;
  gap: 12px;
}
.legal-section ul.legal-list li::before { content: "—"; color: #C9A96E; flex-shrink: 0; }
.legal-section ul.legal-list li:last-child { border-bottom: 0.5px solid #D4C9B0; }
.continuous-review {
  font-size: 13px;
  font-style: italic;
  color: #6B6155;
  font-weight: 300;
  margin-top: 80px;
  line-height: 1.7;
}

/* Compliance specific - table for cookies */
.legal-table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 13px; }
.legal-table th {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.15em;
  color: #C9A96E;
  text-transform: uppercase;
  text-align: left;
  padding: 16px 12px;
  border-bottom: 1px solid #D4C9B0;
}
.legal-table td { padding: 14px 12px; border-bottom: 0.5px solid #D4C9B0; vertical-align: top; line-height: 1.6; color: #1A2332; }

/* ============================================================
   FOOTER
   ============================================================ */
footer.site-footer {
  background: #0F1B2D;
  color: #C8D0DA;
  padding: 80px 0 32px;
  font-size: 13px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 56px;
  padding-bottom: 48px;
  border-bottom: 0.5px solid rgba(212, 201, 176, 0.2);
  margin-bottom: 32px;
}
.footer-brand .logo-wordmark { color: #F0EBE0; margin-bottom: 16px; display: block; }
.footer-brand p { font-size: 13px; color: #8AA0B8; line-height: 1.6; max-width: 320px; }
.footer-col h4 {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #C9A96E;
  margin-bottom: 20px;
}
.footer-col ul { list-style: none; padding: 0; }
.footer-col ul li { margin-bottom: 8px; }
.footer-col ul a { color: #C8D0DA; font-size: 13px; transition: color 0.2s ease; }
.footer-col ul a:hover { color: #C9A96E; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 12px;
  color: #6B7A8A;
}
.footer-bottom .cookie-link { color: #8AA0B8; cursor: pointer; border: none; background: none; font-size: 12px; }
.footer-bottom .cookie-link:hover { color: #C9A96E; }

/* ============================================================
   COOKIE BANNER
   ============================================================ */
#cookie-banner {
  position: fixed;
  bottom: 24px;
  left: 24px;
  right: 24px;
  max-width: 560px;
  background: #0F1B2D;
  color: #F0EBE0;
  padding: 24px 28px;
  border: 1px solid rgba(201, 169, 110, 0.3);
  border-radius: 2px;
  z-index: 1000;
  font-size: 13px;
  line-height: 1.6;
  display: none;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
#cookie-banner.show { display: block; }
#cookie-banner p { color: #C8D0DA; font-size: 13px; margin-bottom: 16px; }
#cookie-banner a { color: #C9A96E; border-bottom: 1px solid rgba(201,169,110,0.4); }
#cookie-banner .cookie-actions { display: flex; gap: 16px; flex-wrap: wrap; }
#cookie-banner button {
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: 10px 18px;
  cursor: pointer;
  border: 1px solid #C9A96E;
  background: transparent;
  color: #C9A96E;
  transition: all 0.2s ease;
}
#cookie-banner button:hover { background: #C9A96E; color: #0F1B2D; }
#cookie-banner button.primary { background: #C9A96E; color: #0F1B2D; }
#cookie-banner button.primary:hover { background: #B89858; border-color: #B89858; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .capabilities-grid, .network-grid { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
  .capability:nth-child(2), .partner-card:nth-child(2) { border-right: none; }
  .principles-grid, .engagement-grid, .expect-grid { grid-template-columns: 1fr; }
  .principle, .engagement-phase, .expect-item { border-right: none; border-bottom: 0.5px solid #D4C9B0; padding-bottom: 40px; margin-bottom: 40px; }
  .principle:last-child, .engagement-phase:last-child, .expect-item:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; padding: 0; }
  .standards-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .contact-col { padding: 0 0 32px; border-right: none; border-bottom: 0.5px solid #D4C9B0; }
  .contact-col:last-child { border-bottom: none; padding-bottom: 0; }
}

@media (max-width: 768px) {
  section, .two-col, .service-block, .stage, .wont-do, .network, .principles, .engagement, .expect, .form-section, .contact-details, .approach, .jurisdictions, .perimeter, .statement, .standards { padding: 64px 0; }
  .hero { padding: 100px 0 64px; min-height: 60vh; }
  .container { padding: 0 20px; }
  .approach-grid, .two-col .grid, .service-block .grid, .stage .grid, .wont-do .grid { grid-template-columns: 1fr; gap: 32px; }
  .jurisdictions-grid { grid-template-columns: 1fr; gap: 32px; }
  .capabilities-grid, .network-grid { grid-template-columns: 1fr; gap: 0; }
  .capability, .partner-card { border-right: none; border-bottom: 0.5px solid #D4C9B0; padding: 32px 0; }
  .capability:last-child, .partner-card:last-child { border-bottom: none; }
  .form-grid { grid-template-columns: 1fr; gap: 28px; }
  nav.site-nav { display: none; }
  nav.site-nav.open { display: flex; position: absolute; top: 100%; left: 0; right: 0; background: #F8F6F1; flex-direction: column; gap: 0; padding: 16px 24px; border-bottom: 0.5px solid #D4C9B0; }
  nav.site-nav.open a { padding: 14px 0; border-bottom: 0.5px solid #D4C9B0; width: 100%; }
  nav.site-nav.open a:last-child { border-bottom: none; }
  .menu-toggle { display: block; }
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  #cookie-banner { left: 16px; right: 16px; bottom: 16px; padding: 20px; }
  .stage .grid { grid-template-columns: 1fr; }
  .stage .stage-left { border-right: none; border-bottom: 0.5px solid #D4C9B0; padding-right: 0; padding-bottom: 32px; }
}

/* PRINT */
@media print {
  header, footer, #cookie-banner { display: none; }
  section { padding: 32px 0; page-break-inside: avoid; }
}
