.jrnf-wrap { max-width: 1200px; margin: 30px auto; padding: 0 20px; }
.jrnf-heading { margin-bottom: 18px; }
.jrnf-heading h2 { color: #14532d; font-size: 34px; font-weight: 900; margin: 0 0 6px; }
.jrnf-heading p { color: #667085; margin: 0; }
.jrnf-filter-bar { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; background: #fff; border: 1px solid #dce7de; border-radius: 18px; padding: 16px; box-shadow: 0 10px 30px rgba(20,83,45,0.08); margin-bottom: 12px; }
.jrnf-filter-bar select, .jrnf-filter-bar input { min-height: 44px; border: 1px solid #dce7de; border-radius: 999px; padding: 10px 14px; background: #f7fbf8; outline: none; }
.jrnf-filter-bar input { width: 120px; }
.jrnf-detect-location, .jrnf-apply { border: none; background: #14532d; color: #fff; min-height: 44px; padding: 10px 16px; border-radius: 999px; font-weight: 900; cursor: pointer; }
.jrnf-apply { background: #d6336c; }
.jrnf-status { color: #667085; font-weight: 700; margin: 8px 0 16px; }
.jrnf-distance { color: #14532d; font-size: 13px; font-weight: 900; margin-bottom: 12px; }
.jrnf-loading, .jrnf-empty { background: #eef7f0; color: #14532d; font-weight: 900; text-align: center; border-radius: 18px; padding: 26px; }
.jrnf-wrap img.emoji { width: 1em !important; height: 1em !important; max-width: 1em !important; max-height: 1em !important; display: inline-block !important; vertical-align: -0.15em !important; object-fit: contain !important; border-radius: 0 !important; }
@media (max-width: 768px) { .jrnf-wrap { padding: 0 12px; } .jrnf-heading h2 { font-size: 28px; } .jrnf-filter-bar { display: grid; grid-template-columns: 1fr; } .jrnf-filter-bar input, .jrnf-filter-bar select, .jrnf-detect-location, .jrnf-apply { width: 100%; } }
