:root {
  --ramcc-font-display: "Sora", "Trebuchet MS", sans-serif;
  --ramcc-font-body: "Source Sans 3", "Segoe UI", sans-serif;

  --ramcc-color-bg: #f3f4f1;
  --ramcc-color-surface: #ffffff;
  --ramcc-color-surface-muted: #e8ebe5;
  --ramcc-color-ink: #131b24;
  --ramcc-color-ink-muted: #5f666f;

  --ramcc-color-primary: #99e56f;
  --ramcc-color-primary-strong: #6fca3e;
  --ramcc-color-primary-soft: #e8f8dc;
  --ramcc-color-accent: #2f8f86;

  --ramcc-color-dark: #212833;
  --ramcc-color-dark-soft: #313947;
  --ramcc-color-border: #cbd1c7;

  --ramcc-color-success: #2b8a54;
  --ramcc-color-warning: #b97a00;
  --ramcc-color-danger: #c23f3f;

  --ramcc-space-2: 0.5rem;
  --ramcc-space-3: 0.75rem;
  --ramcc-space-4: 1rem;
  --ramcc-space-5: 1.25rem;
  --ramcc-space-6: 1.5rem;
  --ramcc-space-8: 2rem;
  --ramcc-space-10: 2.5rem;

  --ramcc-radius-sm: 0.5rem;
  --ramcc-radius-md: 0.9rem;
  --ramcc-radius-lg: 1.25rem;
  --ramcc-radius-pill: 999px;

  --ramcc-shadow-sm: 0 8px 18px rgba(20, 30, 26, 0.08);
  --ramcc-shadow-md: 0 20px 50px rgba(20, 30, 26, 0.14);
}

body {
  font-family: var(--ramcc-font-body);
  color: var(--ramcc-color-ink);
  background-color: var(--ramcc-color-bg);
}

h1,
h2,
h3,
h4,
h5,
h6,
.ramcc-display {
  font-family: var(--ramcc-font-display);
  letter-spacing: -0.02em;
}

.btn-ramcc-primary {
  border: 2px solid var(--ramcc-color-primary-strong);
  border-radius: var(--ramcc-radius-pill);
  background: var(--ramcc-color-dark);
  color: #ffffff;
  font-family: var(--ramcc-font-display);
  font-weight: 600;
  padding: 0.7rem 1.2rem;
  line-height: 1;
  transition: transform 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease;
}

.btn-ramcc-primary:hover,
.btn-ramcc-primary:focus {
  color: #ffffff;
  background: #171d25;
  box-shadow: var(--ramcc-shadow-sm);
  transform: translateY(-1px);
  text-decoration: none;
}

.btn-ramcc-primary:focus-visible,
.ramcc-focus:focus-visible {
  outline: 3px solid rgba(47, 143, 134, 0.35);
  outline-offset: 2px;
}
