/* Counteroffer — shared styles */

:root {
  --color-bg: #ffffff;
  --color-bg-soft: #f8f8f6;
  --color-bg-dark: #0a0a0a;
  --color-ink: #0a0a0a;
  --color-ink-soft: #525252;
  --color-ink-mute: #8a8a8a;
  --color-border: #e8e6e1;
  --color-accent: #0f1e3d;
  --color-accent-soft: #1a2b4a;
  --color-flag-red: #b91c1c;
  --color-flag-yellow: #b45309;
  --color-flag-green: #15803d;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--color-ink);
  background: var(--color-bg);
}

.font-serif {
  font-family: 'Source Serif 4', Georgia, serif;
  font-feature-settings: normal;
  letter-spacing: -0.01em;
}

.headline {
  font-family: 'Source Serif 4', Georgia, serif;
  font-feature-settings: normal;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.headline-md {
  font-family: 'Source Serif 4', Georgia, serif;
  font-feature-settings: normal;
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.1;
}

.eyebrow {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--color-ink);
  color: #fff;
  padding: 14px 26px;
  font-size: 15px;
  font-weight: 500;
  border-radius: 999px;
  transition: background 0.15s ease, transform 0.15s ease;
  border: 1px solid var(--color-ink);
}

.btn-primary:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent;
  color: var(--color-ink);
  padding: 14px 26px;
  font-size: 15px;
  font-weight: 500;
  border-radius: 999px;
  border: 1px solid var(--color-border);
  transition: border-color 0.15s ease, background 0.15s ease;
}

.btn-secondary:hover {
  border-color: var(--color-ink);
  background: var(--color-bg-soft);
}

.card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 28px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.card:hover {
  border-color: #d4d2cc;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02), 0 8px 24px rgba(10, 10, 10, 0.04);
}

.card-flag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
}

.flag-red { background: #fef2f2; color: var(--color-flag-red); }
.flag-yellow { background: #fffbeb; color: var(--color-flag-yellow); }
.flag-green { background: #f0fdf4; color: var(--color-flag-green); }

.clause-excerpt {
  font-family: 'JetBrains Mono', 'Menlo', monospace;
  font-size: 13px;
  line-height: 1.55;
  color: var(--color-ink-soft);
  background: var(--color-bg-soft);
  border-left: 3px solid var(--color-border);
  padding: 14px 16px;
  border-radius: 4px;
  margin: 14px 0;
}

.divider {
  height: 1px;
  background: var(--color-border);
  width: 100%;
}

.section {
  padding: 96px 0;
}

@media (max-width: 768px) {
  .section { padding: 64px 0; }
}

.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 24px; }
.container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

.faq-item {
  border-bottom: 1px solid var(--color-border);
  padding: 24px 0;
}

.faq-item:last-child { border-bottom: none; }

.faq-question {
  font-size: 17px;
  font-weight: 500;
  color: var(--color-ink);
}

.faq-answer {
  font-size: 16px;
  color: var(--color-ink-soft);
  margin-top: 10px;
  line-height: 1.6;
}

.nav-link {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-ink-soft);
  transition: color 0.15s ease;
}

.nav-link:hover { color: var(--color-ink); }
.nav-link.active { color: var(--color-ink); }

.trust-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--color-ink-soft);
}

.trust-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-flag-green);
}

/* subtle grid background for hero */
.hero-bg {
  background-color: #fff;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(10,10,10,0.04) 1px, transparent 0);
  background-size: 32px 32px;
}

.tag-list { display: flex; flex-wrap: wrap; gap: 8px; }

.tag {
  font-size: 12px;
  font-weight: 500;
  padding: 5px 11px;
  border-radius: 999px;
  background: var(--color-bg-soft);
  color: var(--color-ink-soft);
  border: 1px solid var(--color-border);
}

footer a { color: var(--color-ink-soft); }
footer a:hover { color: var(--color-ink); }
