/* === Layer Controls ===
   Toggle-group rows (CAR selector, layer buttons, map-mode toggles, search).
   Also covers the map-search-group and layer-toggle-button states. */
.layer-toggle-group {
    align-items: flex-start;
}

.map-search-group {
    align-items: flex-start;
}

.map-search-controls {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex: 1;
    flex-wrap: wrap;
}

.map-search-controls input[type="search"] {
    min-width: 168px;
    flex: 1 1 168px;
    border: 1px solid var(--panel-border);
    border-radius: var(--border-pill);
    padding: 7px 12px;
    background: #edfbe2;
    color: var(--text-main);
    font: inherit;
}

.map-search-controls .export-button {
    min-width: 74px;
    padding: 7px 14px;
}

.layer-toggle-buttons {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.layer-toggle-controls {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
}

.layer-inline-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    font-size: 0.78rem;
    color: var(--text-muted);
}

.layer-inline-toggle[hidden] {
    display: none;
}

.layer-toggle-button {
    border: 1px solid rgba(55, 146, 55, 0.2);
    border-radius: var(--border-pill);
    padding: 6px 10px;
    background: rgba(255, 255, 255, 0.78);
    color: var(--text-main);
    font: inherit;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease, border-color 120ms ease;
}

.layer-toggle-button:hover {
    background: rgba(255, 255, 255, 0.95);
}

.layer-toggle-button.is-active {
    background: var(--accent-strong);
    color: var(--surface-inv);
    border-color: rgba(0, 0, 0, 0.08);
}

.reset-button {
    border: 0;
    border-radius: var(--border-pill);
    padding: 6px 14px;
    background: var(--accent-strong);
    color: var(--surface-inv);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    width: auto;
    display: block;
    margin: 10px auto 0;
}

.reset-button:hover {
    background: var(--surface-dark);
}

.export-button {
    border: 1px solid rgba(55, 146, 55, 0.2);
    border-radius: var(--border-pill);
    padding: 10px 14px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--text-main);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    width: 100%;
}

.export-button:hover {
    background: rgba(255, 255, 255, 0.92);
}

.export-button:disabled {
    opacity: 0.72;
    cursor: not-allowed;
}


/* === Terrain Legends ===
   Per-layer legend panels (DEM, slope, NDVI, soil texture, MapBiomas).
   Includes mode-control buttons, gradient bars, label rows, and data tables. */
.layer-legend {
    margin-top: 8px;
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(46, 81, 89, 0.06);
}

.layer-legend[hidden] {
    display: none;
}

.dem-legend-title {
    margin: 0 0 6px;
    font-size: 0.76rem;
    color: var(--text-muted);
}

.layer-mode-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    margin-bottom: 8px;
}

.layer-mode-btn {
    padding: 2px 8px;
    border-radius: var(--border-pill);
    border: 1px solid rgba(46, 81, 89, 0.25);
    background: transparent;
    color: var(--text-muted);
    font-size: 0.72rem;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.layer-mode-btn.is-active {
    background: rgba(84, 180, 53, 0.12);
    color: var(--text-main);
    border-color: rgba(55, 146, 55, 0.4);
}

.layer-bands-row {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    margin-top: 2px;
    font-size: 0.72rem;
    color: var(--text-muted);
}

.layer-bands-row[hidden] {
    display: none;
}

.layer-bands-row input[type="range"] {
    flex: 1;
    accent-color: rgba(84, 180, 53, 0.75);
}

.layer-select-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
    font-size: 0.72rem;
    color: var(--text-muted);
}

.layer-select-row select {
    border: 1px solid rgba(46, 81, 89, 0.2);
    border-radius: var(--border-pill);
    padding: 3px 8px;
    background: rgba(255, 255, 255, 0.78);
    color: var(--text-main);
    font: inherit;
    cursor: pointer;
}

.dem-legend-bar {
    height: 12px;
    border-radius: var(--border-pill);
    border: 1px solid rgba(46, 81, 89, 0.2);
    background: linear-gradient(90deg,
            #0033B3 0%,
            #00B3CC 30%,
            #E6E633 55%,
            #FA7A1F 78%,
            #9E1414 100%);
}

.slope-legend-bar {
    height: 12px;
    border-radius: var(--border-pill);
    border: 1px solid rgba(46, 81, 89, 0.2);
    background: linear-gradient(90deg,
            #000004 0%,
            #1B0C41 16%,
            #4F0C6B 32%,
            #A52C60 50%,
            #E16462 68%,
            #FCA636 84%,
            #FCFDBF 100%);
}

.ndvi-legend-bar {
    height: 12px;
    border-radius: var(--border-pill);
    border: 1px solid rgba(46, 81, 89, 0.2);
    background: linear-gradient(90deg,
            #A50026 0%,
            #D73027 22%,
            #FDAE61 44%,
            #FFFFBF 60%,
            #A6D96A 76%,
            #1A9850 90%,
            #006837 100%);
}

.dem-legend-labels {
    margin-top: 6px;
    display: flex;
    justify-content: space-between;
    gap: 8px;
    font-size: 0.72rem;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
}

.slope-relief-legend {
    margin-top: 8px;
}

.slope-relief-legend-note {
    margin: 0 0 6px;
    font-size: 0.72rem;
    color: var(--text-muted);
}

.soil-legend-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 4px;
    font-size: 0.72rem;
    color: var(--text-muted);
}

.mapbiomas-legend-table {
    display: block;
    max-height: 280px;
    overflow: auto;
}

.mapbiomas-legend-table thead,
.mapbiomas-legend-table tbody,
.mapbiomas-legend-table tr {
    display: table;
    width: 100%;
    table-layout: fixed;
}

.soil-legend-table th,
.soil-legend-table td {
    padding: 4px 6px;
    border-bottom: 1px solid rgba(46, 81, 89, 0.12);
    text-align: left;
}

.soil-legend-table th {
    font-weight: 700;
    color: var(--text-main);
}

.soil-legend-swatch {
    display: inline-block;
    width: 14px;
    height: 14px;
    border-radius: 3px;
    border: 1px solid rgba(46, 81, 89, 0.25);
    vertical-align: middle;
    background: var(--soil-color);
    flex: 0 0 10px;
}
