html {
  scroll-behavior: smooth;
}

body {
  font-family: "Inter", sans-serif;
  background: #ffffff;
  color: #0f172a;
}

:root {
  --brn-primary: #0f172a;
  --brn-secondary: #334155;
  --brn-muted: #64748b;
  --brn-line: #e2e8f0;
  --brn-soft: #f8fafc;
  --brn-card: #ffffff;
  --brn-accent: #0ea5e9;
  --brn-accent-soft: #e0f2fe;
  --brn-success: #10b981;
  --brn-success-soft: #ecfdf5;
}

.hero-grid {
  background-image:
    linear-gradient(rgba(15, 23, 42, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 23, 42, 0.04) 1px, transparent 1px);
  background-size: 36px 36px;
}

.noise {
  position: absolute;
  inset: 0;
  opacity: 0.05;
  pointer-events: none;
  background-image:
    radial-gradient(
      circle at 20% 20%,
      rgba(15, 23, 42, 0.08) 0 1px,
      transparent 1px
    ),
    radial-gradient(
      circle at 80% 30%,
      rgba(15, 23, 42, 0.06) 0 1px,
      transparent 1px
    ),
    radial-gradient(
      circle at 45% 70%,
      rgba(15, 23, 42, 0.05) 0 1px,
      transparent 1px
    );
  background-size:
    24px 24px,
    28px 28px,
    32px 32px;
}

.text-gradient {
  background: linear-gradient(
    90deg,
    #0284c7 0%,
    #0ea5e9 30%,
    #10b981 65%,
    #6366f1 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.card-soft {
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.06),
    0 18px 48px rgba(15, 23, 42, 0.08);
}

.section-shell {
  background: #ffffff;
}

.section-soft {
  background: #f8fafc;
}

.logo-wrap img {
  object-fit: contain;
}

.partner-logo {
  max-height: 42px;
  width: auto;
  object-fit: contain;
}

.brn-brand-logo {
  height: 50px;
  width: auto;
  object-fit: contain;
}

.image-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sharp-card {
  border-radius: 0;
}

.nav-link {
  color: #475569;
  transition: color 0.2s ease;
}

.nav-link:hover {
  color: #0f172a;
}

.kicker {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: #64748b;
}

.body-copy {
  color: #475569;
  line-height: 1.8;
}

.subtle-chip {
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  color: #475569;
}

.hero-chip {
  border: 1px solid #e2e8f0;
  background: #ffffff;
  color: #0f172a;
}

.primary-btn {
  background: #0f172a;
  color: #ffffff;
  transition: 0.2s ease;
}

.primary-btn:hover {
  background: #020617;
}

.secondary-btn {
  border: 1px solid #cbd5e1;
  background: #ffffff;
  color: #0f172a;
  transition: 0.2s ease;
}

.secondary-btn:hover {
  background: #f8fafc;
}

.metric-card {
  border: 1px solid #e2e8f0;
  background: #ffffff;
}

.line-section {
  border-top: 1px solid #e2e8f0;
}

.input-shell {
  border: 1px solid #e2e8f0;
  background: #ffffff;
}

.input-shell input,
.input-shell select {
  background: transparent;
  color: #0f172a;
  outline: none;
}

.input-shell input::placeholder {
  color: #94a3b8;
}

.hero-title {
  letter-spacing: -0.03em;
}

.logo-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  color: #0f172a;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

html,
body {
  min-height: 100%;
}

a {
  text-decoration: none;
}
