/* VetAdvisorMatch — sage green + warm off-white + amber, earthy/veterinary feel. */
:root {
  --sage: #5c7a4c; --sage-deep: #3e5633; --sage-light: #a0b886;
  --off-white: #faf8f2; --off-white-2: #efe9d8;
  --ink: #2b2619; --ink-soft: #524a3b; --muted: #807461;
  --amber: #c67e3b; --border: #dbd4c0; --surface: #fff;
  --max-w: 780px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "Inter", system-ui, -apple-system, sans-serif; font-size: 17px; line-height: 1.7; color: var(--ink); background: var(--off-white); -webkit-font-smoothing: antialiased; }
h1,h2,h3,h4 { font-family: "Inter", sans-serif; color: var(--sage-deep); line-height: 1.25; font-weight: 700; letter-spacing: -0.01em; }
h1 { font-size: 2.4rem; margin: 0 0 1rem; }
h2 { font-size: 1.6rem; margin: 2.5rem 0 0.75rem; }
h3 { font-size: 1.2rem; margin: 1.75rem 0 0.5rem; color: var(--sage); }
a { color: var(--sage); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--sage-deep); }
p { margin: 0 0 1rem; } strong { color: var(--ink); }
ul,ol { padding-left: 1.25rem; } li { margin: 0.4rem 0; }
code { background: var(--off-white-2); color: var(--sage-deep); padding: 2px 6px; border-radius: 3px; font-size: 0.9em; font-family: "SF Mono", monospace; }
.re-container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.re-wide { max-width: 980px; }
header.re-site { background: var(--surface); padding: 1rem 0; border-bottom: 1px solid var(--border); }
header.re-site .re-container { display: flex; justify-content: space-between; align-items: center; }
.re-brand { font-family: "Inter", sans-serif; font-weight: 700; font-size: 1.1rem; color: var(--sage-deep); text-decoration: none; }
.re-brand::before { content: "✚ "; color: var(--amber); font-weight: 400; }
nav.re-nav a { margin-left: 1.5rem; font-size: 0.92rem; color: var(--ink-soft); text-decoration: none; font-weight: 500; }
nav.re-nav a:hover { color: var(--sage); }
main.re-main { padding: 2rem 0 4rem; }
.re-hero { padding: 3rem 0 1.5rem; }
.re-hero h1 { font-size: 2.7rem; }
.re-hero .re-tag { font-size: 1.2rem; color: var(--muted); margin-top: 0.5rem; max-width: 620px; }
.re-cta-button, .re-submit { display: inline-block; background: var(--sage); color: white; padding: 0.85rem 1.6rem; border: none; border-radius: 6px; font-weight: 600; font-size: 1rem; font-family: inherit; text-decoration: none; cursor: pointer; transition: all 0.15s; }
.re-cta-button:hover, .re-submit:hover { background: var(--sage-deep); color: white; }
.re-card, .re-calc { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 1.5rem; margin: 1.25rem 0; }
.re-callout { background: var(--off-white-2); border-left: 4px solid var(--amber); padding: 1rem 1.25rem; margin: 1.5rem 0; border-radius: 0 6px 6px 0; }
.re-pros-cons { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1.5rem 0; }
.re-pros-cons > div { background: var(--surface); border: 1px solid var(--border); border-radius: 6px; padding: 1rem 1.25rem; }
.re-pros-cons h3 { margin-top: 0; }
.re-pros-cons .re-pros h3 { color: var(--sage); } .re-pros-cons .re-cons h3 { color: var(--amber); }
@media (max-width: 600px) { .re-pros-cons { grid-template-columns: 1fr; } }
table.re-table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: 0.95rem; }
table.re-table th, table.re-table td { border: 1px solid var(--border); padding: 0.65rem 0.85rem; text-align: left; }
table.re-table th { background: var(--off-white-2); color: var(--sage-deep); font-weight: 600; }
table.re-table tr:nth-child(even) td { background: var(--off-white); }
table.re-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
#lead-form { margin-top: 2.5rem; }
.re-lead-form { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 1.5rem; }
.re-field { display: flex; flex-direction: column; margin-bottom: 1rem; }
.re-field label { font-weight: 500; color: var(--ink); margin-bottom: 0.35rem; font-size: 0.95rem; }
.re-field input, .re-field textarea, .re-field select { padding: 0.65rem 0.75rem; border: 1px solid var(--border); border-radius: 6px; font-family: inherit; font-size: 1rem; background: #fff; color: var(--ink); }
.re-field input:focus, .re-field textarea:focus, .re-field select:focus { outline: none; border-color: var(--sage); box-shadow: 0 0 0 3px rgba(92,122,76,0.15); }
.re-required { color: var(--amber); }
.re-status { margin-top: 1rem; min-height: 1.5rem; }
.re-status-ok { color: var(--sage-deep); background: var(--off-white-2); padding: 0.85rem 1.1rem; border-radius: 6px; }
.re-calc .re-calc-inputs { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 600px) { .re-calc .re-calc-inputs { grid-template-columns: 1fr; } }
.re-calc-result { margin-top: 1.5rem; padding: 1.5rem; background: var(--off-white-2); border-radius: 8px; }
.re-calc-result h3 { color: var(--sage-deep); margin-top: 0; }
.re-calc-big { font-size: 2.25rem; font-weight: 700; color: var(--sage-deep); font-variant-numeric: tabular-nums; }
footer.re-footer { background: var(--sage-deep); color: var(--off-white-2); padding: 2rem 0; margin-top: 4rem; font-size: 0.85rem; }
footer.re-footer a { color: var(--amber); }
#disclaimers p { margin: 0 0 0.5rem; font-size: 0.83rem; color: var(--off-white-2); }
.re-internal-links { margin: 2rem 0; padding: 1.25rem; background: var(--off-white-2); border-radius: 8px; border-left: 4px solid var(--sage); }
.re-internal-links h3 { margin-top: 0; color: var(--sage-deep); }
.re-internal-links ul { margin-bottom: 0; padding-left: 1.2rem; }
