:root {
  --pdg-green: #2e7d32;
  --pdg-dark: #1b5e20;
  --pdg-text: #212529;
  --pdg-muted: #6c757d;
  --pdg-border: #dee2e6;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  color: var(--pdg-text);
  line-height: 1.6;
}

main { max-width: 46rem; margin: 0 auto; padding: 0 1rem 3rem; }

.site-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.75rem 1rem; background: var(--pdg-dark); color: #fff;
}
.site-header a { color: #fff; text-decoration: none; margin-left: 1rem; }
.site-header .brand { font-weight: 700; margin-left: 0; }

.breadcrumbs { max-width: 46rem; margin: 0.5rem auto; padding: 0 1rem; font-size: 0.875rem; color: var(--pdg-muted); }
.breadcrumbs a { color: var(--pdg-green); }

h1 { margin: 1rem 0 0.25rem; }
.place { color: var(--pdg-muted); margin-top: 0; }

.badge {
  display: inline-block; padding: 0.1rem 0.5rem; margin-right: 0.25rem;
  border: 1px solid var(--pdg-border); border-radius: 1rem; font-size: 0.8rem;
}

.actions { margin: 1rem 0; }
.cta {
  display: inline-block; padding: 0.5rem 1rem; margin: 0 0.5rem 0.5rem 0;
  background: var(--pdg-green); color: #fff; border-radius: 0.375rem; text-decoration: none;
}
.cta-secondary { background: #fff; color: var(--pdg-green); border: 1px solid var(--pdg-green); }

table.details { border-collapse: collapse; margin: 1rem 0; }
table.details th, table.details td { text-align: left; padding: 0.35rem 0.75rem; border-bottom: 1px solid var(--pdg-border); }
table.details th { color: var(--pdg-muted); font-weight: 600; }

.course-list, .region-list, .country-list, .nearby { padding-left: 1.25rem; }
.course-list li, .region-list li, .country-list li, .nearby li { margin: 0.35rem 0; }
.count, .dist { color: var(--pdg-muted); font-size: 0.875rem; }

.curation {
  margin: 1.5rem 0; padding: 1rem; border: 1px dashed var(--pdg-green); border-radius: 0.5rem;
  background: #f1f8f1;
}

.updated { color: var(--pdg-muted); font-size: 0.875rem; }

#mini-map { height: 320px; margin: 1.5rem 0; border-radius: 0.5rem; }

.site-footer {
  border-top: 1px solid var(--pdg-border); margin-top: 2rem;
  padding: 1rem; text-align: center; font-size: 0.875rem; color: var(--pdg-muted);
}
