[hidden] { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; white-space: nowrap; }
.hero-map__frame { display: block; min-height: 62vh; }
.hero-map__canvas-wrap { min-height: 62vh; }
.rnrn-strip { display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(320px, 1.15fr); gap: 22px; align-items: center; padding: 22px; }
.rnrn-strip__copy h2 { margin: 6px 0 0; font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1.04; letter-spacing: -0.02em; }
.rnrn-strip__copy p { margin: 10px 0 0; color: var(--muted); line-height: 1.55; }
.map-search { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 10px; padding: 10px; border: 1px solid rgba(244, 239, 228, 0.14); border-radius: 24px; background: rgba(255, 255, 255, 0.035); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03); }
.map-search__input { width: 100%; min-height: 44px; border: 1px solid rgba(244, 239, 228, 0.12); border-radius: 16px; padding: 0 14px; background: rgba(255, 255, 255, 0.06); color: var(--ink); outline: none; }
.map-search__input::placeholder { color: var(--muted-soft); }
.map-status { display: none !important; }
.locate-button { position: absolute; right: 18px; bottom: 18px; z-index: 5; width: 48px; height: 48px; border: 1px solid rgba(244, 239, 228, 0.14); border-radius: 999px; background: rgba(9, 9, 10, 0.82); color: var(--ink); box-shadow: 0 14px 34px rgba(0, 0, 0, 0.32); cursor: pointer; backdrop-filter: blur(14px); }
.locate-button span { display: block; transform: translateY(-1px); font-size: 1.35rem; line-height: 1; }
.locate-button:disabled { opacity: 0.58; cursor: not-allowed; }
.cards-header, .cards-footer { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.cards-header { margin-bottom: 16px; }
.cards-footer { justify-content: center; margin-top: 18px; }
.cards-summary { margin: 4px 0 0; color: var(--muted); line-height: 1.5; }
.selected-source-slot:not(:empty) { margin-bottom: 16px; }
.selected-source-card { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px; border: 1px solid rgba(212, 181, 122, 0.3); border-radius: 22px; background: linear-gradient(180deg, rgba(212, 181, 122, 0.1), rgba(255,255,255,0.03)), rgba(255,255,255,0.02); }
.selected-source-card h3 { margin: 4px 0 0; font-size: 1.12rem; }
.selected-source-card p { margin: 8px 0 0; color: var(--muted); line-height: 1.45; }
.selected-source-card__distance { color: var(--ink) !important; }
.map-search__input:focus-visible, .locate-button:focus-visible { outline: 2px solid var(--focus); outline-offset: 3px; box-shadow: 0 0 0 3px rgba(11,11,12,0.75); }
@media (max-width: 1120px) { .hero-map__frame, .hero-map__canvas-wrap { min-height: 56vh; } .rnrn-strip { grid-template-columns: 1fr; } }
@media (max-width: 760px) { .hero-map__frame, .hero-map__canvas-wrap { min-height: 52vh; } .rnrn-strip { padding: 18px; gap: 16px; } .map-search { grid-template-columns: minmax(0, 1fr) auto; padding: 8px; border-radius: 20px; } .map-search__clear { grid-column: 1 / -1; } .map-search__input { min-height: 42px; } .locate-button { right: 12px; bottom: 12px; } .selected-source-card { display: grid; } }
