.rrp-wrapper {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
    box-sizing: border-box;
    color: #172033;
    font-family: inherit;
}

.rrp-wrapper * {
    box-sizing: border-box;
}

.rrp-panel {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 20px;
    border: 1px solid #d9e0ea;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

.rrp-panel h2,
.rrp-panel h3 {
    margin: 0;
    line-height: 1.2;
}

.rrp-panel h2 {
    font-size: clamp(1.35rem, 2.4vw, 1.9rem);
}

.rrp-panel h3 {
    margin-top: 14px;
    font-size: 1.05rem;
}

.rrp-top-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.rrp-muted,
.rrp-attribution {
    color: #667085;
    font-size: 0.9rem;
    line-height: 1.45;
}

.rrp-muted {
    margin: 0;
}

.rrp-middle-row {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
    gap: 12px;
    width: 100%;
    align-items: start;
}

.rrp-grid {
    display: grid;
    gap: 12px;
}

.rrp-search-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rrp-options-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rrp-sub-grid {
    position: relative;
    min-width: 0;
}

.rrp-grid label,
.rrp-map-controls label {
    display: grid;
    gap: 6px;
    color: #344054;
    font-size: 0.88rem;
    font-weight: 700;
}

.rrp-grid input,
.rrp-grid select,
.rrp-map-controls input[type="range"],
.rrp-search-row button,
.rrp-actions button {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    min-height: 42px;
    border-radius: 10px;
    font: inherit;
}

.rrp-grid input,
.rrp-grid select {
    border: 1px solid #cfd8e3;
    background: #fff;
    color: #172033;
    padding: 9px 11px;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.rrp-grid input:focus,
.rrp-grid select:focus {
    border-color: #1f6feb;
    box-shadow: 0 0 0 3px rgba(31, 111, 235, 0.14);
}

.rrp-search-row {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 88px;
    gap: 8px;
    align-items: center;
}

.rrp-search-row br {
    display: none;
}

.rrp-actions {
    display: flex;
    justify-content: flex-end;
}

.rrp-actions button,
.rrp-search-row button {
    border: 0;
    background: #1f6feb;
    color: #fff;
    cursor: pointer;
    font-weight: 800;
    letter-spacing: 0.01em;
    padding: 0 16px;
    box-shadow: 0 6px 16px rgba(31, 111, 235, 0.24);
    transition: transform 0.12s ease, filter 0.12s ease, box-shadow 0.12s ease;
}

.rrp-actions button {
    width: auto;
    min-width: 220px;
}

.rrp-actions button:hover,
.rrp-search-row button:hover {
    filter: brightness(0.96);
    box-shadow: 0 8px 20px rgba(31, 111, 235, 0.28);
}

.rrp-actions button:active,
.rrp-search-row button:active {
    transform: translateY(1px);
}

.rrp-hidden-controls {
    display: none !important;
}

.rrp-bottom-row {
    display: grid;
    gap: 10px;
}

.rrp-status {
    min-height: 22px;
    font-weight: 700;
    line-height: 1.35;
}

.rrp-status[data-type="error"] {
    color: #b42318;
}

.rrp-status[data-type="success"] {
    color: #027a48;
}

.rrp-status[data-type="info"] {
    color: #175cd3;
}

.rrp-progress {
    height: 10px;
    overflow: hidden;
    border-radius: 999px;
    background: #e6eaf0;
    border: 1px solid #d0d7de;
}

.rrp-progress-bar {
    height: 100%;
    width: 0%;
    border-radius: inherit;
    background: linear-gradient(90deg, #1f6feb, #54aeff);
    transition: width 0.35s ease;
}

.rrp-progress[hidden] {
    display: none;
}

.rrp-results {
    margin-top: 2px;
}

.rrp-best {
    padding: 14px;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid #d0d7de;
}

.rrp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.rrp-table th,
.rrp-table td {
    padding: 8px 6px;
    border-bottom: 1px solid #e6e6e6;
    text-align: left;
}

.rrp-timeline {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.rrp-timeline-point {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 2px 7px;
    border-radius: 999px;
    font-size: 0.8rem;
    border: 1px solid #d0d7de;
}

.rrp-dry {
    background: #f6f8fa;
}

.rrp-light {
    background: #fff8c5;
}

.rrp-rain {
    background: #d6eaff;
}

.rrp-heavy {
    background: #ffd8d3;
}

.rrp-unknown {
    background: #f0f0f0;
}

.rrp-map-wrap {
    display: grid;
    grid-template-columns: minmax(280px, 1fr);
    gap: 14px;
    align-items: stretch;
}

.rrp-map {
    position: relative;
    min-height: 590px;
    width: 100%;
    overflow: hidden;
    border: 1px solid #d9e0ea;
    border-radius: 16px;
    background: #eef2f6;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

.rrp-map-controls {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-self: start;
    padding: 14px;
    border: 1px solid #d9e0ea;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.rrp-inline-option {
    display: flex !important;
    align-items: center;
    gap: 9px !important;
    min-height: 42px;
    padding: 10px 11px;
    border: 1px solid #cfd8e3;
    border-radius: 10px;
    background: #f8fafc;
    font-weight: 700;
    cursor: pointer;
}

.rrp-inline-option input {
    width: auto;
    min-height: auto;
    margin: 0;
}

.rrp-map-controls input[type="range"] {
    min-height: auto !important;
    accent-color: #1f6feb;
}

.rrp-weather-marker {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 44px !important;
    height: 44px !important;
    margin-left: -22px !important;
    margin-top: -22px !important;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #1f2937;
    font-size: 17px;
    font-weight: 800;
    line-height: 1;
    text-align: center;
    z-index: 1200 !important;
    cursor: pointer;
}

.rrp-weather-marker span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: 2px solid #fff;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
    pointer-events: none;
}

.rrp-weather-dry span {
    background: #e9f8ef;
}

.rrp-weather-light span {
    background: #fff4ba;
}

.rrp-weather-rain span,
.rrp-weather-heavy span {
    background: #d6eaff;
    color: #003a75;
}

.rrp-weather-unknown span {
    background: #f0f0f0;
}

.leaflet-rrpRoutePane-pane {
    z-index: 1200 !important;
    pointer-events: none;
}

.leaflet-rrpWeatherPane-pane {
    z-index: 1300 !important;
}

.leaflet-popup-pane {
    z-index: 1800 !important;
}

.leaflet-popup {
    z-index: 1800 !important;
}

.rrp-debug-details {
    margin-top: 12px;
}

.rrp-debug-details summary {
    cursor: pointer;
    font-weight: 700;
}

.rrp-debug-table-wrap {
    max-height: 260px;
    overflow: auto;
    margin-top: 8px;
}

.rrp-debug-table {
    font-size: 0.78rem;
    white-space: nowrap;
}

.rrp-radar-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 1400;
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(0, 0, 0, 0.12);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
    font-size: 0.85rem;
    color: #1f2937;
    line-height: 1.35;
    pointer-events: none;
}

.rrp-radar-badge strong {
    display: inline;
    margin-right: 2px;
}

.rrp-autocomplete {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 96px;
    z-index: 2000;
    overflow: hidden;
    border: 1px solid #cfd8e3;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.16);
}

.rrp-autocomplete[hidden] {
    display: none;
}

.rrp-autocomplete button {
    display: block;
    width: 100%;
    min-height: auto;
    padding: 10px 12px;
    border: 0;
    border-bottom: 1px solid #eef2f6;
    border-radius: 0;
    background: #fff;
    color: #172033;
    text-align: left;
    cursor: pointer;
    box-shadow: none;
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.35;
}

.rrp-autocomplete button:hover,
.rrp-autocomplete button:focus {
    background: #f3f7ff;
    outline: none;
}

.rrp-autocomplete button:last-child {
    border-bottom: 0;
}

.rrp-plan[disabled],
.rrp-search-row button[disabled] {
    cursor: wait;
    opacity: 0.65;
}

.rrp-attribution {
    margin: 0;
}

@media (max-width: 1000px) {
    .rrp-middle-row,
    .rrp-map-wrap {
        grid-template-columns: 1fr;
    }

    .rrp-map-controls {
        display: grid;
        grid-template-columns: repeat(2, minmax(180px, 1fr));
    }

    .rrp-autocomplete {
        right: 96px;
    }
}

@media (max-width: 720px) {
    .rrp-panel {
        padding: 16px;
    }

    .rrp-search-grid,
    .rrp-options-grid,
    .rrp-map-controls {
        grid-template-columns: 1fr;
    }

    .rrp-search-row {
        grid-template-columns: 1fr;
    }

    .rrp-actions button {
        width: 100%;
        min-width: 0;
    }

    .rrp-map {
        min-height: 430px;
    }

    .rrp-autocomplete {
        right: 0;
    }
}


@media (max-width: 1180px) {
    .rrp-middle-row {
        grid-template-columns: 1fr;
    }

    .rrp-options-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .rrp-panel {
        padding: 16px;
    }

    .rrp-search-grid,
    .rrp-options-grid {
        grid-template-columns: 1fr;
    }

    .rrp-search-row {
        grid-template-columns: 1fr;
    }

    .rrp-autocomplete {
        right: 0;
    }

    .rrp-actions {
        justify-content: stretch;
    }

    .rrp-actions button {
        width: 100%;
        min-width: 0;
    }
}

/* 0.4.10 radar control and result polish */
.rrp-map-wrap {
    grid-template-columns: minmax(280px, 1fr);
}

.rrp-map-shell {
    position: relative;
    min-width: 0;
}

.rrp-map-radar-controls {
    position: absolute;
    top: 12px;
    left: 58px;
    right: 12px;
    z-index: 1450;
    display: grid;
    grid-template-columns: auto auto auto minmax(150px, 1fr) minmax(110px, 145px) minmax(110px, 145px);
    gap: 8px;
    align-items: center;
    padding: 8px;
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.18);
    backdrop-filter: blur(8px);
}

.rrp-radar-play {
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 12px;
    background: #1f6feb;
    color: #fff;
    font-size: 1rem;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 5px 14px rgba(31, 111, 235, 0.25);
}

.rrp-radar-play:disabled {
    cursor: default;
    opacity: 0.55;
}

.rrp-map-radar-controls .rrp-inline-option {
    min-height: 38px;
    padding: 7px 9px;
    background: #fff;
    white-space: nowrap;
}

.rrp-map-controls {
    display: none;
}

.rrp-radar-timeline-label,
.rrp-radar-mini-label {
    display: grid;
    gap: 4px;
    color: #344054;
    font-size: 0.78rem;
    font-weight: 800;
    min-width: 0;
}

.rrp-radar-time-text {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.rrp-map-radar-controls input[type="range"] {
    width: 100%;
    min-width: 0;
    accent-color: #1f6feb;
}

.rrp-radar-badge {
    display: none !important;
}

.rrp-best {
    display: grid;
    gap: 8px;
    padding: 14px;
}

.rrp-best-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.rrp-kicker {
    display: block;
    margin-bottom: 2px;
    color: #667085;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.rrp-best h3 {
    margin: 0;
    font-size: clamp(1.35rem, 2.2vw, 1.8rem);
}

.rrp-result-pill {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #eaf3ff;
    color: #175cd3;
    font-size: 0.86rem;
    font-weight: 800;
    white-space: nowrap;
}

.rrp-best-summary {
    margin: 0;
    color: #344054;
    font-weight: 650;
}

.rrp-alternatives {
    margin-top: 12px;
    border: 1px solid #d0d7de;
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
}

.rrp-alternatives summary {
    padding: 11px 13px;
    cursor: pointer;
    font-weight: 800;
    background: #f8fafc;
}

.rrp-alt-list {
    display: grid;
    gap: 8px;
    padding: 10px;
}

.rrp-alt-select {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    width: 100%;
    padding: 10px 11px;
    border: 1px solid #d0d7de;
    border-radius: 10px;
    background: #fff;
    color: #172033;
    cursor: pointer;
    text-align: left;
    font: inherit;
}

.rrp-alt-select:hover,
.rrp-alt-select:focus {
    border-color: #1f6feb;
    outline: none;
    box-shadow: 0 0 0 3px rgba(31, 111, 235, 0.12);
}

.rrp-alt-select.is-active {
    border-color: #1f6feb;
    background: #f3f7ff;
}

.rrp-alt-select small {
    color: #667085;
    white-space: nowrap;
}

.rrp-timeline-point {
    cursor: pointer;
}

button.rrp-timeline-point {
    border: 1px solid #d0d7de;
    color: #172033;
    font: inherit;
}

button.rrp-timeline-point:hover,
button.rrp-timeline-point:focus {
    border-color: #1f6feb;
    outline: none;
    box-shadow: 0 0 0 3px rgba(31, 111, 235, 0.12);
}

@media (max-width: 1000px) {
    .rrp-map-radar-controls {
        left: 12px;
        grid-template-columns: auto auto auto minmax(160px, 1fr);
    }

    .rrp-radar-mini-label {
        grid-column: span 1;
    }
}

@media (max-width: 720px) {
    .rrp-map-radar-controls {
        position: relative;
        top: auto;
        left: auto;
        right: auto;
        z-index: 1;
        grid-template-columns: 42px 1fr;
        margin-bottom: 10px;
    }

    .rrp-radar-timeline-label,
    .rrp-radar-mini-label {
        grid-column: 1 / -1;
    }

    .rrp-alt-select {
        grid-template-columns: 1fr;
    }

    .rrp-alt-select small {
        white-space: normal;
    }

    .rrp-best-main {
        align-items: flex-start;
        flex-direction: column;
    }
}


/* 0.4.11 neutral UI polish */
.rrp-grid input:focus,
.rrp-grid select:focus {
    border-color: #475467;
    box-shadow: 0 0 0 3px rgba(71, 84, 103, 0.16);
}

.rrp-actions button,
.rrp-search-row button,
.rrp-radar-play,
.rrp-alt-select,
button.rrp-timeline-point {
    border: 1px solid #d0d5dd;
    background: #f8fafc;
    color: #111827;
    box-shadow: none;
}

.rrp-actions button {
    background: #111827;
    border-color: #111827;
    color: #ffffff;
}

.rrp-actions button:hover,
.rrp-search-row button:hover,
.rrp-radar-play:hover,
.rrp-alt-select:hover,
button.rrp-timeline-point:hover {
    filter: none;
    background: #eef2f6;
    border-color: #98a2b3;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.10);
}

.rrp-actions button:hover {
    background: #1f2937;
    border-color: #1f2937;
}

.rrp-actions button:focus,
.rrp-search-row button:focus,
.rrp-radar-play:focus,
.rrp-alt-select:focus,
button.rrp-timeline-point:focus {
    outline: none;
    border-color: #475467;
    box-shadow: 0 0 0 3px rgba(71, 84, 103, 0.16);
}

.rrp-radar-play {
    width: auto;
    min-width: 86px;
    padding: 0 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.9rem;
    line-height: 1;
    white-space: nowrap;
}

.rrp-result-pill {
    background: #f2f4f7;
    color: #344054;
}

.rrp-alt-select:hover,
.rrp-alt-select:focus,
button.rrp-timeline-point:hover,
button.rrp-timeline-point:focus {
    border-color: #475467;
    box-shadow: 0 0 0 3px rgba(71, 84, 103, 0.12);
}

.rrp-alt-select.is-active {
    border-color: #475467;
    background: #f2f4f7;
}

.rrp-map-radar-controls input[type="range"],
.rrp-map-controls input[type="range"] {
    appearance: none;
    -webkit-appearance: none;
    height: 22px;
    padding: 0;
    background: transparent;
    accent-color: #475467;
}

.rrp-map-radar-controls input[type="range"]::-webkit-slider-runnable-track,
.rrp-map-controls input[type="range"]::-webkit-slider-runnable-track {
    height: 6px;
    border-radius: 999px;
    background: #d0d5dd;
}

.rrp-map-radar-controls input[type="range"]::-webkit-slider-thumb,
.rrp-map-controls input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    margin-top: -6px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    background: #475467;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.28);
}

.rrp-map-radar-controls input[type="range"]::-moz-range-track,
.rrp-map-controls input[type="range"]::-moz-range-track {
    height: 6px;
    border: 0;
    border-radius: 999px;
    background: #d0d5dd;
}

.rrp-map-radar-controls input[type="range"]::-moz-range-thumb,
.rrp-map-controls input[type="range"]::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    background: #475467;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.28);
}

.rrp-map-radar-controls input[type="range"]:focus,
.rrp-map-controls input[type="range"]:focus {
    outline: none;
}

.rrp-map-radar-controls input[type="range"]:focus::-webkit-slider-thumb,
.rrp-map-controls input[type="range"]:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 4px rgba(71, 84, 103, 0.16);
}

.rrp-map-radar-controls input[type="range"]:focus::-moz-range-thumb,
.rrp-map-controls input[type="range"]:focus::-moz-range-thumb {
    box-shadow: 0 0 0 4px rgba(71, 84, 103, 0.16);
}

.rrp-progress-bar {
    background: linear-gradient(90deg, #344054, #667085);
}

.rrp-weather-sunny span,
.rrp-weather-dry span {
    background: #fff3b0;
    color: #5f4300;
}

.rrp-weather-partly_cloudy span {
    background: #e8f3ff;
    color: #1f4f7a;
}

.rrp-weather-cloudy span {
    background: #e5e7eb;
    color: #374151;
}

.rrp-weather-night span {
    background: #dbeafe;
    color: #1e3a8a;
}

.rrp-timeline-point.rrp-sunny,
.rrp-timeline-point.rrp-dry {
    background: #fff3b0;
    color: #5f4300;
}

.rrp-timeline-point.rrp-partly_cloudy {
    background: #e8f3ff;
    color: #1f4f7a;
}

.rrp-timeline-point.rrp-cloudy {
    background: #e5e7eb;
    color: #374151;
}

.rrp-timeline-point.rrp-night {
    background: #dbeafe;
    color: #1e3a8a;
}
