.satisfactory-map-page {
    position: relative;
    z-index: 0;
    display: grid;
    gap: 1rem;
}

.satisfactory-map-header,
.satisfactory-map-panel,
.satisfactory-map-notice {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.satisfactory-map-header {
    display: grid;
    gap: 0.8rem;
    padding: clamp(1.15rem, 2.6vw, 1.7rem);
}

.satisfactory-map-header .page-title {
    max-width: none;
}

.satisfactory-map-description {
    margin: 0;
    max-width: 70ch;
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.65;
}

.satisfactory-map-description strong {
    color: var(--text);
    font-weight: 600;
}

.satisfactory-map-panel {
    display: grid;
    gap: 0.9rem;
    padding: clamp(0.8rem, 2vw, 1rem);
    background:
        linear-gradient(135deg, rgba(201, 135, 73, 0.08), transparent 32%),
        var(--surface);
}

.satisfactory-map-filters {
    display: grid;
    gap: 0.75rem;
    padding: 0.85rem;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface-soft);
}

.satisfactory-map-filters__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.satisfactory-map-filters__status {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.86rem;
}

.satisfactory-map-filters__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 0.55rem;
}

.satisfactory-map-board-header {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface-soft);
}

.satisfactory-map-board-title {
    margin: 0.12rem 0 0;
    color: var(--text);
    font-size: 1rem;
    line-height: 1.2;
    font-weight: 600;
}

.satisfactory-map-board-copy {
    margin: 0;
    max-width: 45rem;
    color: var(--text-muted);
    font-size: 0.88rem;
    line-height: 1.55;
}

.satisfactory-map-board-copy strong {
    color: var(--text);
    font-weight: 600;
}

.satisfactory-map-filter {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 2.45rem;
    padding: 0.52rem 0.68rem;
    border: 1px solid var(--line);
    border-radius: 10px;
    color: var(--text);
    background: var(--surface-muted);
    font-size: 0.9rem;
    cursor: pointer;
}

.satisfactory-map-filter input {
    width: 1rem;
    height: 1rem;
    accent-color: var(--accent);
}

.satisfactory-map-wrapper {
    position: relative;
    z-index: 0;
    overflow: hidden;
    border: 1px solid var(--line-strong);
    border-radius: 16px;
    background: #000;
}

#satisfactory-map {
    width: 100%;
    height: 75vh;
    min-height: 500px;
    background: #000;
}

#satisfactory-map .leaflet-container,
#satisfactory-map .leaflet-tile-pane,
#satisfactory-map .leaflet-overlay-pane {
    background: #000;
}

#satisfactory-map .leaflet-image-layer {
    image-rendering: auto;
}

.satisfactory-map-notice {
    margin: 0;
    padding: 0.85rem 1rem;
    color: var(--text-muted);
    font-size: 0.92rem;
}

.satisfactory-map-wrapper > .satisfactory-map-notice {
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    z-index: 500;
    border-color: rgba(201, 120, 106, 0.4);
    background: color-mix(in srgb, var(--surface) 92%, transparent);
    color: var(--text);
}

.satisfactory-map-notice[hidden] {
    display: none;
}

.satisfactory-map-error {
    border-color: rgba(201, 120, 106, 0.42);
}

.satisfactory-map-notice strong {
    color: var(--text);
    font-weight: 600;
}

.satisfactory-map-popup {
    display: grid;
    gap: 0.28rem;
    min-width: 180px;
    color: #1f2226;
}

.satisfactory-map-popup__title {
    margin: 0;
    font-size: 1rem;
    line-height: 1.2;
}

.satisfactory-map-popup__meta,
.satisfactory-map-popup__description {
    margin: 0;
    font-size: 0.86rem;
    line-height: 1.45;
}

.satisfactory-map-popup__meta {
    color: #5d554c;
}

.satisfactory-map-popup__description {
    color: #2d3034;
}

@media (max-width: 640px) {
    .satisfactory-map-board-header {
        display: grid;
    }

    .satisfactory-map-filters__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    #satisfactory-map {
        height: 68vh;
        min-height: 420px;
    }
}
