/* SVS Hafenplan – Frontend Map */
.svs-hafenplan-wrap { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; position: relative; }
.svs-map-controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 12px; }
.svs-map-search { padding: 8px 14px; border: 1px solid #d0d7de; border-radius: 20px; font-size: 14px; width: 260px; outline: none; }
.svs-map-search:focus { border-color: #0969da; box-shadow: 0 0 0 2px rgba(9,105,218,.15); }
.svs-map-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.svs-filter-btn { padding: 6px 14px; border: 1px solid #d0d7de; border-radius: 16px; background: #fff; color: #424a53; cursor: pointer; font-size: 13px; transition: all .15s; }
.svs-filter-btn:hover { border-color: #0969da; color: #0969da; }
.svs-filter-btn.active { background: #0969da; border-color: #0969da; color: #fff; }
.svs-map-container { position: relative; border: 1px solid #d0d7de; border-radius: 8px; overflow: hidden; background: #fff; }
.svs-map-svg { display: block; width: 100%; height: 100%; }
.svs-map-bp { cursor: pointer; }
.svs-map-bp:hover rect { filter: brightness(.88); }
.svs-map-tooltip {
    position: absolute; background: #fff; border: 1px solid #d0d7de;
    border-radius: 10px; padding: 12px 16px; min-width: 180px; max-width: 240px;
    box-shadow: 0 4px 16px rgba(0,0,0,.12); z-index: 100; pointer-events: none;
    font-size: 13px;
}
.svs-tt-nr    { font-size: 10px; font-family: monospace; color: #0969da; font-weight: 600; margin-bottom: 3px; }
.svs-tt-boot  { font-size: 16px; font-weight: 700; color: #1f2328; margin-bottom: 2px; }
.svs-tt-owner { font-size: 12px; color: #424a53; margin-bottom: 3px; }
.svs-tt-breite{ font-size: 11px; font-family: monospace; color: #6e7781; margin-bottom: 3px; }
.svs-tt-phone { font-size: 11px; font-family: monospace; color: #6e7781; margin-bottom: 2px; }
.svs-tt-email { font-size: 11px; font-family: monospace; color: #6e7781; }
.svs-tt-email a { color: inherit; text-decoration: underline; }
.svs-map-noaccess { padding: 20px; background: #fff8c5; border: 1px solid #eac54f; border-radius: 6px; color: #9a6700; }
.svs-badge-free     { fill: #f6f8fa; stroke: #d0d7de; }
.svs-badge-occupied { fill: #ddf4ff; stroke: #0969da; }
.svs-badge-svs      { fill: #dafbe1; stroke: #1a7f37; }
