/* Shared styles for /kampala neighbourhood pages */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url('/fonts/open-sans-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
:root { --cream: #FFFDF7; --dark: #1A1A1A; --gold: #FFD700; --green: #25D366; --brown: #6B5B3E; --muted: #8B7355; --warm: #FFF8E1; }
* { box-sizing: border-box; }
body { margin: 0; font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif; background: var(--cream); color: var(--dark); line-height: 1.65; font-size: 16px; }
a { color: var(--dark); }
header.site { background: var(--dark); padding: 14px 20px; display: flex; justify-content: space-between; align-items: center; }
header.site > a { color: var(--gold); text-decoration: none; font-weight: 800; font-size: 18px; }
header.site nav a { color: #ccc; font-weight: 400; font-size: 14px; margin-left: 14px; text-decoration: none; }
.breadcrumbs { max-width: 760px; margin: 20px auto 0; padding: 0 20px; font-size: 13px; color: var(--muted); }
.breadcrumbs a { color: var(--brown); text-decoration: underline; }
main { max-width: 760px; margin: 20px auto 40px; padding: 0 20px; }
main h1 { font-size: 32px; line-height: 1.15; font-weight: 800; margin: 16px 0 8px; }
main .meta { color: var(--muted); font-size: 13px; margin-bottom: 24px; }
picture.hero { display: block; width: 100%; }
picture.hero img { display: block; width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; border-radius: 16px; margin: 24px 0; }
main h2 { font-size: 24px; line-height: 1.25; font-weight: 800; margin: 40px 0 12px; }
main h3 { font-size: 18px; font-weight: 700; margin: 24px 0 8px; }
main p { margin: 0 0 18px; color: #4A3728; }
main ul { padding-left: 22px; margin: 0 0 18px; color: #4A3728; }
main ul li { margin-bottom: 8px; }
main strong { color: var(--dark); }
main table { width: 100%; border-collapse: collapse; margin: 20px 0; font-size: 14px; border: 1px solid #E8DCC8; border-radius: 8px; overflow: hidden; }
main th, main td { padding: 10px 12px; text-align: left; border-bottom: 1px solid #E8DCC8; }
main th { background: var(--warm); font-weight: 700; }
main td:first-child { font-weight: 600; }
.cta-box { background: linear-gradient(135deg, #FFF8E1, #FFFDF7); border: 1px solid rgba(255,215,0,0.4); border-radius: 16px; padding: 24px; margin: 32px 0; text-align: center; }
.cta-box .cta-title { font-size: 19px; font-weight: 800; color: var(--dark); margin-bottom: 8px; }
.cta-btn { display: inline-block; background: var(--green); color: white !important; padding: 14px 28px; border-radius: 12px; font-weight: 800; text-decoration: none; margin-top: 8px; }
.cta-btn:hover { background: #20bd5a; }
.faq-block { background: #fff; border: 1px solid #E8DCC8; border-radius: 12px; padding: 18px 22px; margin: 16px 0; }
.faq-block h3 { margin-top: 0; margin-bottom: 6px; font-size: 16px; }
.faq-block p { margin: 0; font-size: 15px; }
.neighbour-nav { background: #fff; border: 1px solid #E8DCC8; border-radius: 12px; padding: 16px 20px; margin: 28px 0; font-size: 14px; }
.neighbour-nav strong { display: block; margin-bottom: 6px; }
.neighbour-nav a { color: var(--brown); text-decoration: underline; margin-right: 12px; display: inline-block; margin-bottom: 4px; }
footer.site { background: var(--dark); color: #ccc; padding: 30px 20px; text-align: center; font-size: 13px; margin-top: 40px; }
footer.site a { color: var(--gold); text-decoration: none; }
@media (max-width: 600px) { main h1 { font-size: 26px; } main h2 { font-size: 20px; } }
