:root {
  --so-bg: #f6faf5;
  --so-surface: #ffffff;
  --so-green: #4caf50;
  --so-green-dark: #357a38;
  --so-coral: #ef6c4d;
  --so-coral-dark: #cf5236;
  --so-ink: #2b2f2a;
  --so-muted: #71776e;
  --so-border: #e3ebe0;
  --so-head: "Montserrat", Helvetica, Arial, sans-serif;
  --so-body: "Open Sans", Helvetica, Arial, sans-serif;
}

.so-body {
  background-color: #f6faf5;
  color: #2b2f2a;
  font-family: "Open Sans", Helvetica, Arial, sans-serif;
  font-size: 17px;
  line-height: 1.7;
}
.so-main { min-height: 60vh; }

h1, h2, h3, h4, .so-h, .so-brand, .so-hero-title {
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  color: #357a38;
  line-height: 1.2;
}
h1, .so-hero-title { font-size: 36px; font-weight: 700; }
h2 { font-size: 27px; font-weight: 700; }
h3 { font-size: 20px; font-weight: 600; }

/* nav */
.so-navbar { background: #4caf50; border-bottom: 3px solid #ef6c4d; align-items: center; }
.so-brand { color: #ffffff !important; font-size: 1.35rem; font-family: var(--so-head); }
.so-burger { color: #ffffff; font-size: 1.6rem; }
.so-navlink { color: #ffffff !important; }
.so-navlink:hover { color: #ffe2da !important; }
.so-dropdown { position: relative; }
.so-dropdown-menu { display: none; position: absolute; top: 100%; left: 0; min-width: 200px; background: #357a38; z-index: 60; }
.so-dropdown:hover .so-dropdown-menu, .so-dropdown:focus-within .so-dropdown-menu { display: block; }
.so-dropitem { display: block; padding: 0.4rem 1rem; color: #fff; }
.so-dropitem:hover { background: #4caf50; }

/* hero */
.so-hero { background: linear-gradient(135deg, #4caf50 0%, #357a38 100%); color: #fff; padding: 3rem 0; }
.so-hero-title { color: #fff; }
.so-hero-sub { color: #dcefd8; font-size: 1.1rem; }

/* sections / prose */
.so-section { padding: 2.5rem 0; }
.so-prose { background: #ffffff; border: 1px solid #e3ebe0; border-radius: 8px; padding: 1.9rem 2.1rem; color: #2b2f2a; box-shadow: 0 2px 6px rgba(76,175,80,0.06); }
.so-prose img, .so-img { max-width: 100%; height: auto; border-radius: 6px; }
.so-prose a { color: #ef6c4d; text-decoration: underline; text-decoration-color: #e3ebe0; }
.so-prose a:hover { color: #cf5236; text-decoration-color: #ef6c4d; }
.so-muted { color: #71776e; }
.so-quote { border-left: 3px solid #ef6c4d; padding-left: 1rem; color: #2b2f2a; background: #f6faf5; font-style: italic; }
.so-listing-title { border-bottom: 2px solid #ef6c4d; padding-bottom: 0.4rem; margin-bottom: 1.5rem; }
.so-breadcrumb a { color: #71776e; }
.so-related { margin-top: 1.5rem; }
.divider { border-top: 1px solid #e3ebe0; }

/* cards */
.so-card { background: #fff; border: 1px solid #e3ebe0; color: #2b2f2a; margin-bottom: 1.5rem; }
.so-card .card-title a { color: #357a38; text-decoration: none; font-family: var(--so-head); }
.so-card .card-title a:hover { color: #ef6c4d; }
.read-more, .btn-primary { background: #ef6c4d; border-color: #ef6c4d; color: #fff; }
.read-more:hover, .btn-primary:hover { background: #cf5236; border-color: #cf5236; }

/* footer */
.so-footer { background: #357a38; color: #d6ead2; }
.so-footer .so-brand { color: #ef6c4d; }
.so-footer-sitemap { display: flex; flex-wrap: wrap; gap: 0.25rem 1rem; }
.so-footer-link { color: #d6ead2; text-decoration: none; font-size: 0.9rem; }
.so-footer-link:hover { color: #ffe2da; }
.so-footer-copy { color: #a6cb9f; border-top: 1px solid #4caf50; margin-top: 1rem; padding-top: 0.75rem; font-size: 0.85rem; }

@media print { .so-navbar, .so-footer { display: none; } }
