/* ─── RESET & VARIABLES ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --black:        #0b0c0c;
  --white:        #ffffff;
  --grey-1:       #f3f2f1;
  --grey-2:       #b1b4b6;
  --grey-3:       #505a5f;
  --link:         #1d70b8;
  --link-hover:   #003078;
  --link-visited: #4c2c92;
  --focus:        #ffdd00;
  --focus-text:   #0b0c0c;
  --green:        #00703c;
  --green-dark:   #005a30;
  --red:          #d4351c;
  --border:       #b1b4b6;
  --font-body:    'Source Sans 3', Arial, sans-serif;
  --font-head:    'Source Serif 4', Georgia, serif;
}

html { font-size: 16px; }

body {
  font-family: var(--font-body);
  color: var(--black);
  background: var(--white);
  line-height: 1.5;
}

/* ─── BASE ─── */
a { color: var(--link); text-decoration: underline; }
a:hover  { color: var(--link-hover); }
a:visited { color: var(--link-visited); }
a:focus { outline: none; }
a:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 0;
  background: var(--focus);
  color: var(--focus-text);
  text-decoration: none;
}

/* ─── SKIP LINK ─── */
.skip-link {
  position: absolute;
  top: -9999px; left: 0;
  background: var(--focus);
  color: var(--black);
  padding: 8px 16px;
  font-weight: 600;
  z-index: 9999;
}
.skip-link:focus { top: 0; }

/* ─── HEADER ─── */
.site-header {
  background: var(--white);
  border-bottom: 4px solid var(--green);
}
.header-inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 20px 20px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.logo-block {
  display: flex;
  align-items: center;
  gap: 16px;
  text-decoration: none;
}
.logo-block:focus { outline: none; }
.logo-block:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
  background: none;
}
.logo-mark { flex-shrink: 0; width: 28px; height: 36px; }
.logo-text { display: flex; flex-direction: column; gap: 3px; }
.logo-name {
  font-family: var(--font-body);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--black);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  line-height: 1;
}
.logo-sub {
  font-family: var(--font-body);
  font-size: 0.68rem;
  font-weight: 400;
  color: var(--grey-3);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  line-height: 1;
}
.header-contact { color: var(--black); font-size: 0.875rem; text-align: right; }
.header-contact a {
  color: var(--black);
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
  display: block;
}
.header-contact a:hover   { color: var(--green); }
.header-contact a:visited { color: var(--black); }
.header-contact-label {
  font-size: 0.75rem;
  color: var(--grey-3);
  letter-spacing: 0.04em;
  margin-bottom: 3px;
}

/* ─── NAV ─── */
.site-nav { background: var(--white); border-bottom: 2px solid var(--black); }
.nav-inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-wrap: wrap;
}
.nav-inner a {
  display: block;
  padding: 13px 16px;
  color: var(--black);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: border-color 0.15s;
}
.nav-inner a:hover   { border-bottom-color: var(--green); color: var(--black); }
.nav-inner a.active  { border-bottom-color: var(--black); }
.nav-inner a:visited { color: var(--black); }

/* ─── BUTTONS ─── */
.btn {
  display: inline-block;
  padding: 12px 22px;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background 0.15s, color 0.15s;
  font-family: var(--font-body);
}
.btn-primary { background: var(--green); color: var(--white); border-color: var(--green); }
.btn-primary:hover   { background: var(--green-dark); border-color: var(--green-dark); color: var(--white); }
.btn-primary:visited { color: var(--white); }
.btn-secondary { background: var(--white); color: var(--black); border-color: var(--black); }
.btn-secondary:hover   { background: var(--grey-1); color: var(--black); }
.btn-secondary:visited { color: var(--black); }

/* ─── INSET PANELS ─── */
.inset-panel {
  background: var(--grey-1);
  border-left: 5px solid var(--green);
  padding: 20px 24px;
  margin-bottom: 28px;
}
.inset-panel h3 {
  font-family: var(--font-head);
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 8px;
}
.inset-panel p { font-size: 0.9rem; color: var(--grey-3); line-height: 1.55; }
.inset-panel.inset-warning { border-left-color: var(--red); background: #fff4f3; }
.inset-panel.inset-warning h3 { color: var(--red); }

/* inner page inset (lighter, used in legal/discretion/careers) */
.inset {
  background: var(--grey-1);
  border-left: 5px solid var(--green);
  padding: 16px 20px;
  margin: 20px 0 24px;
  max-width: 640px;
}
.inset p { font-size: 0.9rem; line-height: 1.6; color: var(--grey-3); margin-bottom: 6px; max-width: none; }
.inset p:last-child { margin-bottom: 0; }
.inset strong { color: var(--black); }
.inset.inset-blue  { border-left-color: var(--link); background: #f0f4fb; }
.inset.inset-blue p { color: var(--black); }
.inset.inset-warning { border-left-color: var(--red); }
.inset.inset-warning p { color: var(--black); }

/* ─── TAGS ─── */
.tag {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 8px;
  margin-right: 4px;
}
.tag-public   { background: #e8f4ef; color: #00503a; }
.tag-business { background: #e8f0fb; color: #003078; }
.tag-cyber    { background: #f4e8e8; color: #6b0000; }

/* ─── TRUST BAR (home) ─── */
.trust-bar {
  background: var(--grey-1);
  border-bottom: 1px solid var(--border);
  padding: 14px 20px;
}
.trust-inner {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  align-items: center;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 0.875rem;
  color: var(--grey-3);
}
.trust-icon { width: 20px; height: 20px; flex-shrink: 0; }
.trust-item strong { color: var(--black); }

/* ─── HERO (home) ─── */
.hero {
  background: var(--grey-1);
  border-bottom: 1px solid var(--border);
  padding: 40px 20px 48px;
}
.hero-inner { max-width: 960px; margin: 0 auto; }
.breadcrumb { font-size: 0.875rem; color: var(--grey-3); margin-bottom: 20px; }
.breadcrumb a { color: var(--link); }
.breadcrumb span { margin: 0 6px; color: var(--grey-2); }
.hero h1 {
  font-family: var(--font-head);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.2;
  max-width: 680px;
  margin-bottom: 16px;
}
.hero-lead {
  font-size: 1.15rem;
  color: var(--grey-3);
  max-width: 620px;
  line-height: 1.6;
  margin-bottom: 28px;
}
.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* ─── MAIN CONTENT (home) ─── */
.main-content {
  max-width: 1000px;
  margin: 0 auto;
  padding: 48px 20px 80px;
}
.main-content > section { padding-bottom: 24px; }
.main-content > section:last-child { padding-bottom: 0; }
.section-heading {
  font-family: var(--font-head);
  font-size: 1.75rem;
  font-weight: 700;
  margin-bottom: 8px;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 2px solid var(--black);
}
.section-heading:first-child { margin-top: 0; }
.section-intro {
  font-size: 1rem;
  color: var(--grey-3);
  max-width: 620px;
  margin-bottom: 28px;
}

/* ─── SERVICES GRID (home) ─── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-bottom: 40px;
}
.service-card { background: var(--white); padding: 24px 24px 28px; }
.service-card-icon { width: 36px; height: 36px; margin-bottom: 14px; }
.service-card h3 { font-family: var(--font-head); font-size: 1.15rem; font-weight: 700; margin-bottom: 8px; }
.service-card h3 a { color: var(--black); text-decoration: none; }
.service-card h3 a:hover { color: var(--link); text-decoration: underline; }
.service-card p { font-size: 0.9rem; color: var(--grey-3); line-height: 1.55; margin-bottom: 14px; }

/* ─── TWO COL (home) ─── */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
}

/* ─── SECTOR PILLS (home) ─── */
.sector-list { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 32px; list-style: none; padding: 0; }
.sector-pill {
  padding: 8px 16px;
  background: var(--grey-1);
  border: 1px solid var(--border);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--black);
  text-decoration: none;
}

/* ─── ACCORDION (home) ─── */
details { border-top: 1px solid var(--border); }
details:last-of-type { border-bottom: 1px solid var(--border); }
summary {
  padding: 16px 4px;
  font-weight: 600;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1rem;
}
summary::-webkit-details-marker { display: none; }
summary::after { content: '+'; font-size: 1.2rem; color: var(--green); font-weight: 700; }
details[open] summary::after { content: '−'; }
details p { padding: 0 4px 20px; font-size: 0.9rem; color: var(--grey-3); line-height: 1.6; max-width: 660px; }

/* ─── PROCESS STEPS (home) ─── */
.steps { list-style: none; margin-bottom: 32px; }
.steps li { display: flex; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--border); }
.steps li:first-child { border-top: 1px solid var(--border); }
.step-num {
  font-family: var(--font-head);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--green);
  min-width: 36px;
  line-height: 1;
  padding-top: 2px;
}
.step-body h4 { font-weight: 700; font-size: 1rem; margin-bottom: 4px; }
.step-body p  { font-size: 0.9rem; color: var(--grey-3); line-height: 1.5; }

/* ─── TESTIMONIALS (home) ─── */
.testimonial-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  margin-bottom: 40px;
}
blockquote.testimonial {
  background: var(--white);
  border: 1px solid var(--border);
  padding: 22px 24px;
}
blockquote.testimonial p { font-style: italic; font-size: 0.925rem; line-height: 1.6; margin-bottom: 12px; }
blockquote.testimonial footer { font-size: 0.8rem; font-weight: 700; color: var(--grey-3); }
blockquote.testimonial footer span { display: block; font-weight: 400; font-style: normal; color: var(--grey-2); }

/* ─── CONTACT FORM (home) ─── */
.contact-section {
  background: var(--grey-1);
  border: 1px solid var(--border);
  padding: 32px;
  margin-bottom: 40px;
}
.contact-section h2 { font-family: var(--font-head); font-size: 1.5rem; margin-bottom: 8px; }
.contact-section p.lead { font-size: 0.95rem; color: var(--grey-3); margin-bottom: 28px; }
.form-group { margin-bottom: 20px; display: flex; flex-direction: column; }
.form-group label { display: block; font-weight: 700; font-size: 0.95rem; margin-bottom: 6px; }
.form-hint { display: block; font-size: 0.85rem; color: var(--grey-3); margin-bottom: 6px; }
.form-group input,
.form-group select,
.form-group textarea {
  display: block;
  width: 100%;
  max-width: 480px;
  margin-top: auto;
  padding: 10px 12px;
  border: 2px solid var(--black);
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--black);
  background: var(--white);
  border-radius: 0;
  outline: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: 3px solid var(--focus);
  outline-offset: 0;
}
.form-group textarea { min-height: 120px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-privacy { font-size: 0.8rem; color: var(--grey-3); margin-top: 12px; }
.form-privacy a { color: var(--link); }

.sensitive-toggle { margin: 0 0 20px; }
.sensitive-toggle .checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-weight: 400;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--grey-3);
  margin: 0;
}
.sensitive-toggle .checkbox-row input[type="checkbox"] {
  margin-top: 4px;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  cursor: pointer;
}
.sensitive-toggle .checkbox-text strong {
  display: block;
  color: var(--black);
  font-weight: 700;
  margin-bottom: 4px;
}

/* ─── PAGE HEADER (inner pages) ─── */
.page-header {
  background: var(--grey-1);
  border-bottom: 1px solid var(--border);
  padding: 36px 20px 44px;
}
.page-header-inner { max-width: 960px; margin: 0 auto; }
.page-header h1 {
  font-family: var(--font-head);
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.2;
  max-width: 720px;
  margin-bottom: 14px;
}
.page-header-lead { font-size: 1.05rem; color: var(--grey-3); max-width: 640px; line-height: 1.65; }
.last-updated { font-size: 0.8rem; color: var(--grey-3); margin-top: 16px; }
.last-updated strong { color: var(--black); }

/* ─── PAGE LAYOUT WITH SIDEBAR (inner pages) ─── */
.page-layout {
  max-width: 1000px;
  margin: 0 auto;
  padding: 48px 20px 80px;
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 60px;
  align-items: start;
}

/* ─── MAIN COLUMN (inner pages) ─── */
.main-col h2 {
  font-family: var(--font-head);
  font-size: 1.6rem;
  font-weight: 700;
  margin-top: 48px;
  margin-bottom: 12px;
  padding-top: 24px;
  border-top: 2px solid var(--black);
}
.main-col h2:first-child { margin-top: 0; border-top: none; padding-top: 0; }
.main-col h3 { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; margin-top: 28px; margin-bottom: 8px; }
.main-col p { font-size: 0.95rem; line-height: 1.7; color: var(--black); margin-bottom: 14px; max-width: 640px; }
.main-col p:last-child { margin-bottom: 0; }
.main-col ul,
.main-col ol { margin: 0 0 16px 0; padding-left: 22px; max-width: 620px; }
.main-col ul li,
.main-col ol li { font-size: 0.95rem; line-height: 1.65; margin-bottom: 7px; }

/* ─── LAW CARDS (legal page) ─── */
.law-card { border: 1px solid var(--border); margin-bottom: 28px; }
.law-card-head {
  background: var(--grey-1);
  padding: 16px 20px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid var(--border);
}
.law-card-title { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; line-height: 1.2; }
.law-card-title span { display: block; font-family: var(--font-body); font-size: 0.75rem; font-weight: 400; color: var(--grey-3); letter-spacing: 0.04em; margin-top: 3px; }
.law-badge { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 9px; white-space: nowrap; flex-shrink: 0; }
.badge-primary   { background: #e8f4ef; color: #00503a; }
.badge-secondary { background: #e8f0fb; color: #003078; }
.badge-caution   { background: #fff4e5; color: #6e3a00; }
.law-card-body { padding: 18px 20px; }
.law-card-body p { font-size: 0.9rem; line-height: 1.65; color: var(--grey-3); margin-bottom: 10px; max-width: none; }
.law-card-body p:last-child { margin-bottom: 0; }
.law-card-body strong { color: var(--black); }
.law-card-footer { padding: 10px 20px; border-top: 1px solid var(--border); font-size: 0.8rem; color: var(--grey-3); }
.law-card-footer a { color: var(--link); font-size: 0.8rem; }

/* ─── ROLE CARDS (careers page) ─── */
.role-card { border: 1px solid var(--border); margin-bottom: 28px; }
.role-card-head {
  padding: 20px 24px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.role-title { font-family: var(--font-head); font-size: 1.25rem; font-weight: 700; margin-bottom: 6px; }
.role-meta  { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.role-tag   { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 9px; }
.tag-field    { background: #e8f4ef; color: #00503a; }
.tag-client   { background: #e8f0fb; color: #003078; }
.tag-fulltime { background: var(--grey-1); color: var(--grey-3); border: 1px solid var(--border); }
.tag-contract { background: #fff8e5; color: #6e4a00; }
.tag-hybrid   { background: var(--grey-1); color: var(--grey-3); border: 1px solid var(--border); }
.role-status {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--green);
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  padding-top: 2px;
}
.role-status::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
}
.role-body { padding: 20px 24px; }
.role-body p { font-size: 0.9rem; line-height: 1.65; color: var(--grey-3); margin-bottom: 14px; max-width: none; }
.role-body p:last-child { margin-bottom: 0; }
.role-body strong { color: var(--black); }
.role-section-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--grey-3);
  margin-bottom: 8px;
  margin-top: 18px;
}
.role-body ul { list-style: none; padding: 0; margin: 0 0 14px; }
.role-body ul li {
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--black);
  padding: 6px 0 6px 16px;
  border-bottom: 1px solid var(--grey-1);
  position: relative;
}
.role-body ul li:last-child { border-bottom: none; }
.role-body ul li::before { content: '—'; position: absolute; left: 0; color: var(--grey-2); font-size: 0.8rem; }
.role-footer {
  padding: 14px 24px;
  border-top: 1px solid var(--border);
  background: var(--grey-1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.role-footer p { font-size: 0.82rem; color: var(--grey-3); margin: 0; }
.role-footer .btn { padding: 10px 20px; font-size: 0.9rem; }

/* ─── TAKEDOWN TEMPLATE BLOCK ─── */
.takedown-template-wrap { margin: 12px 0 28px; }
.takedown-template-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--grey-3);
}
.takedown-template {
  background: var(--grey-1);
  border-left: 4px solid var(--border);
  padding: 16px 18px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--black);
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow-x: auto;
  margin: 0;
}

/* ─── STATEMENT PREVIEW (discretion page) ─── */
.statement-preview { border: 1px solid var(--border); margin: 20px 0 28px; max-width: 560px; font-size: 0.875rem; }
.statement-preview-head { background: var(--black); color: var(--white); padding: 10px 16px; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.statement-row { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; padding: 11px 16px; border-bottom: 1px solid var(--grey-1); align-items: center; }
.statement-row:last-child { border-bottom: none; }
.statement-row.highlight { background: #f0f4fb; }
.statement-desc { color: var(--black); font-weight: 600; }
.statement-desc span { display: block; font-size: 0.78rem; font-weight: 400; color: var(--grey-3); margin-top: 2px; }
.statement-date { color: var(--grey-3); white-space: nowrap; font-size: 0.82rem; }
.statement-amount { font-weight: 700; white-space: nowrap; }
.statement-amount.debit   { color: var(--red); }
.statement-amount.neutral { color: var(--grey-3); }

/* ─── STEP LIST WITH ICONS (discretion page) ─── */
.step-list { list-style: none; padding: 0; margin: 0 0 24px 0; max-width: 640px; }
.step-list li { display: flex; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--border); }
.step-list li:first-child { border-top: 1px solid var(--border); }
.step-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background: var(--grey-1);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.step-icon-body h4 { font-weight: 700; font-size: 0.95rem; margin-bottom: 4px; }
.step-icon-body p  { font-size: 0.875rem; color: var(--grey-3); line-height: 1.55; margin-bottom: 0; max-width: none; }

/* ─── DO / DON'T (discretion page) ─── */
.do-dont {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin: 20px 0 28px;
  max-width: 640px;
}
.do-col, .dont-col { background: var(--white); padding: 18px 20px; }
.do-col h4, .dont-col h4 {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.do-col h4   { color: var(--green); }
.dont-col h4 { color: var(--red); }
.do-col ul, .dont-col ul { list-style: none; padding: 0; margin: 0; }
.do-col ul li, .dont-col ul li {
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--black);
  margin-bottom: 8px;
  padding-left: 18px;
  position: relative;
}
.do-col ul li::before   { content: '✓'; position: absolute; left: 0; color: var(--green); font-weight: 700; }
.dont-col ul li::before { content: '✗'; position: absolute; left: 0; color: var(--red); font-weight: 700; }

/* ─── SIDEBAR (inner pages) ─── */
.sidebar { position: sticky; top: 24px; }
.sidebar-card { border: 1px solid var(--border); margin-bottom: 20px; }
.sidebar-card-head { background: var(--black); padding: 12px 16px; }
.sidebar-card-head h3 { color: var(--white); font-size: 0.875rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
.sidebar-card-body { padding: 4px 0; }
.sidebar-nav-link {
  display: block;
  padding: 10px 16px;
  font-size: 0.875rem;
  color: var(--black);
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: border-color 0.1s, background 0.1s;
}
.sidebar-nav-link:hover   { border-left-color: var(--green); background: var(--grey-1); color: var(--black); }
.sidebar-nav-link:visited { color: var(--black); }
.sidebar-nav-link + .sidebar-nav-link { border-top: 1px solid var(--grey-1); }

.sidebar-contact { background: var(--grey-1); border: 1px solid var(--border); padding: 16px; margin-bottom: 20px; }
.sidebar-contact h3 { font-size: 0.875rem; font-weight: 700; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.04em; }
.sidebar-contact p { font-size: 0.85rem; color: var(--grey-3); line-height: 1.55; margin-bottom: 10px; }
.sidebar-contact a.btn { display: block; text-align: center; padding: 10px; font-size: 0.875rem; }

.sidebar-note { border: 1px solid var(--border); padding: 16px; background: var(--white); font-size: 0.82rem; color: var(--grey-3); line-height: 1.6; }
.sidebar-note strong { color: var(--black); font-size: 0.875rem; display: block; margin-bottom: 6px; }

/* ─── FOOTER ─── */
.site-footer { background: var(--black); color: var(--grey-2); padding: 40px 20px; }
.footer-inner { max-width: 960px; margin: 0 auto; }
.footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 32px;
  margin-bottom: 32px;
  padding-bottom: 32px;
  border-bottom: 1px solid #333;
}
.footer-col h4 { color: var(--white); font-size: 0.875rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 14px; }
.footer-col ul  { list-style: none; }
.footer-col ul li { margin-bottom: 8px; }
.footer-col ul li a { color: var(--grey-2); font-size: 0.875rem; text-decoration: none; }
.footer-col ul li a:hover   { color: var(--white); text-decoration: underline; }
.footer-col ul li a:visited { color: var(--grey-2); }
.footer-bottom { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 16px; }
.footer-logo { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; color: var(--white); }
.footer-logo span { color: var(--green); }
.footer-legal { font-size: 0.8rem; line-height: 1.6; color: #666; }
.footer-legal a { color: #888; }

/* ─── RESPONSIVE ─── */
@media (max-width: 720px) {
  .page-layout { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .two-col { grid-template-columns: 1fr; }
  .do-dont { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .nav-inner { padding: 0 12px; }
  .nav-inner a { padding: 11px 12px; font-size: 0.825rem; }
  .law-card-head { flex-direction: column; gap: 10px; }
  .role-card-head { flex-direction: column; gap: 12px; }
  .testimonial-grid { gap: 16px; }
  .statement-row { grid-template-columns: 1fr auto; column-gap: 10px; }
  .statement-row .statement-date { display: none; }
  .takedown-template { font-size: 0.8rem; padding: 14px 14px; }
  .main-col { overflow-wrap: break-word; }
}
@media (max-width: 640px) {
  .hero h1 { font-size: 1.75rem; }
  .hero-lead { font-size: 1rem; }
  .page-header h1 { font-size: 1.65rem; }
  .page-header-lead { font-size: 0.95rem; }
  .section-heading { font-size: 1.35rem; }
  .header-inner { gap: 12px; padding: 16px 16px 14px; }
  .contact-section { padding: 20px; }
  .hero { padding: 32px 16px 36px; }
  .page-header { padding: 28px 16px 32px; }
  .main-content { padding: 36px 16px 64px; }
  .page-layout { padding: 36px 16px 64px; }
  .site-footer { padding: 32px 16px; }
  .footer-grid { gap: 24px; padding-bottom: 24px; margin-bottom: 24px; }
  .hero-ctas .btn { width: 100%; }
  .btn { padding: 11px 18px; font-size: 0.95rem; }
  .takedown-template { font-size: 0.76rem; padding: 12px 12px; line-height: 1.55; }
}
@media (max-width: 380px) {
  .law-card-title, .role-title { font-size: 1rem; }
  .step-num { font-size: 1.25rem; min-width: 36px; }
  .steps li { gap: 12px; padding: 14px 0; }
}
