/**
 * Journey Planner Layout — Two-panel design
 * Left: sidebar (journey name, route, saved places)
 * Right: full-height map
 */

:root {
    --jp-sidebar-width: 360px;
    --jp-command-h: 52px;
    --jp-accent: #895348;
    --jp-accent-gold: #C9A053;
    --jp-border: rgba(139, 69, 19, 0.12);
    --jp-bg: #f8f5f0;
    --jp-sidebar-bg: #ffffff;
    --jp-text: #333F48;
    --jp-muted: rgba(51, 63, 72, 0.55);
}

/* ── Page shell ── */
.journey-planner-page {
    background: var(--jp-bg);
    font-family: 'Lato', sans-serif;
    color: var(--jp-text);
    overflow-y: visible;
    padding: 0;
}

/* Remove old header — it no longer exists in the template */
.journey-planner-header { display: none; }

/* ── Command bar ── */
.journey-command-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    height: var(--jp-command-h);
    padding: 0 16px;
    background: #fff;
    border-bottom: 1px solid var(--jp-border);
    position: sticky;
    top: 0;
    z-index: 50;
    box-shadow: 0 1px 6px rgba(0,0,0,0.06);
}

.command-bar-selector {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}

.command-bar-icon {
    color: var(--jp-accent);
    font-size: 16px;
    flex-shrink: 0;
}

.journey-select {
    flex: 1;
    max-width: 380px;
    padding: 7px 12px;
    border: 1px solid var(--jp-border);
    border-radius: 7px;
    background: #faf8f5;
    font-size: 14px;
    font-family: 'Cinzel', serif;
    color: var(--jp-text);
    cursor: pointer;
    transition: border-color 0.2s;
}

.journey-select:focus {
    outline: none;
    border-color: var(--jp-accent);
}

.command-bar-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.btn-command-save {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 16px;
    background: var(--jp-accent);
    color: #fff;
    border: none;
    border-radius: 7px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s;
}

.btn-command-save:hover {
    background: #723d2e;
    transform: translateY(-1px);
}

.btn-command-delete {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    background: none;
    border: 1px solid rgba(220,53,69,0.25);
    border-radius: 7px;
    color: #dc3545;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-command-delete:hover {
    background: #dc3545;
    color: #fff;
    border-color: #dc3545;
}

/* Hidden divider (kept for JS compatibility) */
.command-bar-divider,
.command-bar-brand { display: none; }

/* ── Two-panel body ── */
.journey-planner-body {
    display: flex;
    height: calc(100vh - var(--jp-command-h) - 64px); /* 64px = approx site header */
    min-height: 600px;
    overflow: hidden;
}

/* ── Left sidebar ── */
.journey-plan-sidebar {
    width: var(--jp-sidebar-width);
    flex-shrink: 0;
    background: var(--jp-sidebar-bg);
    border-right: 1px solid var(--jp-border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.plan-sidebar-inner {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    scrollbar-color: var(--jp-border) transparent;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.plan-sidebar-inner::-webkit-scrollbar { width: 4px; }
.plan-sidebar-inner::-webkit-scrollbar-track { background: transparent; }
.plan-sidebar-inner::-webkit-scrollbar-thumb { background: var(--jp-border); border-radius: 2px; }

/* Journey name + dates */
.sidebar-journey-meta {
    padding: 14px 16px 12px;
    border-bottom: 1px solid var(--jp-border);
    background: #fdfaf6;
}

.journey-name-input {
    width: 100%;
    border: none;
    background: transparent;
    font-family: 'Cinzel', serif;
    font-size: 15px;
    font-weight: 600;
    color: var(--jp-text);
    padding: 0 0 6px;
    border-bottom: 1px solid transparent;
    outline: none;
    transition: border-color 0.2s;
    box-sizing: border-box;
}

.journey-name-input:focus { border-bottom-color: var(--jp-accent); }
.journey-name-input::placeholder { color: var(--jp-muted); font-weight: 400; }

.journey-dates-compact {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    flex-wrap: wrap;
}

.journey-dates-compact .journey-date {
    border: 1px solid var(--jp-border);
    border-radius: 5px;
    padding: 4px 7px;
    font-size: 12px;
    color: var(--jp-text);
    background: #fff;
    outline: none;
    transition: border-color 0.2s;
    flex: 1;
    min-width: 110px;
}

.journey-dates-compact .journey-date:focus { border-color: var(--jp-accent); }

.dates-separator {
    color: var(--jp-muted);
    font-size: 13px;
    flex-shrink: 0;
}

.journey-duration-display {
    font-size: 11px;
    color: var(--jp-muted);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Route section */
.sidebar-stops-section {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    border-bottom: 1px solid var(--jp-border);
}

.sidebar-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px 8px;
    border-bottom: 1px solid var(--jp-border);
    flex-shrink: 0;
    background: #fdfaf6;
}

.sidebar-section-title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--jp-accent);
    margin: 0;
}

.sidebar-section-title i { font-size: 11px; }

.journey-view-toggle {
    display: flex;
    gap: 3px;
}

.view-btn {
    width: 28px;
    height: 28px;
    background: none;
    border: 1px solid var(--jp-border);
    border-radius: 5px;
    color: var(--jp-muted);
    font-size: 11px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
}

.view-btn.active, .view-btn:hover {
    background: var(--jp-accent);
    color: #fff;
    border-color: var(--jp-accent);
}

/* Journey items list */
.journey-items-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px 12px;
    scrollbar-width: thin;
    scrollbar-color: var(--jp-border) transparent;
}

.journey-items-empty {
    text-align: center;
    padding: 24px 16px;
    color: var(--jp-muted);
}

.journey-items-empty i {
    font-size: 1.8rem;
    color: rgba(139,69,19,0.15);
    margin-bottom: 8px;
    display: block;
}

.journey-items-empty strong { display: block; font-size: 13px; margin-bottom: 6px; }
.journey-items-empty p { font-size: 12px; line-height: 1.5; }

/* Saved places pool (collapsible) */
.sidebar-favorites-pool,
.sidebar-export-section {
    border-bottom: 1px solid var(--jp-border);
    flex-shrink: 0;
}

.pool-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    cursor: pointer;
    list-style: none;
    user-select: none;
    background: #fdfaf6;
    transition: background 0.15s;
}

.pool-summary::-webkit-details-marker { display: none; }

.pool-summary:hover { background: rgba(139,69,19,0.04); }

.pool-summary-label {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--jp-accent);
}

.pool-summary-label i { font-size: 11px; }

.location-count {
    background: var(--jp-accent);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 3px;
    min-width: 18px;
    text-align: center;
}

.pool-body {
    padding: 10px 14px 12px;
    background: #fff;
}

/* Search within pool */
.sidebar-search {
    display: flex;
    gap: 0;
    margin-bottom: 8px;
}

.sidebar-search input {
    flex: 1;
    border: 1px solid var(--jp-border);
    border-right: none;
    border-radius: 6px 0 0 6px;
    padding: 6px 10px;
    font-size: 12px;
    outline: none;
    transition: border-color 0.2s;
}

.sidebar-search input:focus { border-color: var(--jp-accent); }

.sidebar-search button {
    border: 1px solid var(--jp-border);
    border-left: none;
    border-radius: 0 6px 6px 0;
    background: #faf8f5;
    padding: 6px 10px;
    cursor: pointer;
    color: var(--jp-muted);
    font-size: 12px;
    transition: all 0.15s;
}

.sidebar-search button:hover { background: var(--jp-accent); color: #fff; border-color: var(--jp-accent); }

/* Map type filters */
.map-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 8px;
}

.filter-button {
    padding: 3px 9px;
    border: 1px solid var(--jp-border);
    border-radius: 3px;
    background: #fff;
    font-size: 11px;
    cursor: pointer;
    color: var(--jp-muted);
    transition: all 0.15s;
    display: flex;
    align-items: center;
    gap: 4px;
}

.filter-button.active,
.filter-button:hover {
    background: var(--jp-accent);
    color: #fff;
    border-color: var(--jp-accent);
}

.reset-filters {
    padding: 3px 8px;
    border: 1px solid var(--jp-border);
    border-radius: 3px;
    background: none;
    color: var(--jp-muted);
    font-size: 11px;
    cursor: pointer;
    transition: color 0.15s;
}

.reset-filters:hover { color: var(--jp-accent); }

.locations-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11px;
    color: var(--jp-muted);
    padding: 4px 2px 6px;
    border-bottom: 1px solid var(--jp-border);
    margin-bottom: 6px;
}

/* Favorites list */
.locations-list {
    max-height: 240px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--jp-border) transparent;
    background: #faf8f5;
    border-radius: 6px;
    border: 1px solid var(--jp-border);
    padding: 4px;
    margin-bottom: 8px;
}

.locations-list::-webkit-scrollbar { width: 4px; }
.locations-list::-webkit-scrollbar-track { background: transparent; }
.locations-list::-webkit-scrollbar-thumb { background: var(--jp-border); border-radius: 2px; }

.journey-actions-panel {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 6px;
}

/* Export grid compact */
.export-grid-compact {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.export-btn-sm {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    background: #faf8f5;
    border: 1px solid var(--jp-border);
    border-radius: 5px;
    font-size: 12px;
    color: var(--jp-text);
    cursor: pointer;
    transition: all 0.15s;
}

.export-btn-sm:hover { background: var(--jp-accent); color: #fff; border-color: var(--jp-accent); }

/* ── Right: map panel ── */
.journey-map-panel {
    flex: 1;
    min-width: 0;
    position: relative;
    display: flex;
    flex-direction: column;
}

.map-container {
    flex: 1;
    position: relative;
    min-height: 0;
    border-radius: 0;
    overflow: hidden;
}

#journey-map,
.journey-map {
    width: 100%;
    height: 100%;
    min-height: 500px;
    display: block;
}

/* Map controls */
.map-controls {
    position: absolute;
    top: 12px;
    right: 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    z-index: 10;
}

.map-control-btn {
    width: 32px;
    height: 32px;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 13px;
    color: #333;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
    transition: all 0.15s;
}

.map-control-btn:hover { background: var(--jp-accent); color: #fff; border-color: var(--jp-accent); }

/* Map style controls */
.map-style-controls {
    position: absolute;
    bottom: 12px;
    right: 12px;
    z-index: 10;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(0,0,0,0.1);
    border-radius: 7px;
    padding: 6px 10px;
    backdrop-filter: blur(4px);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.map-style-options {
    display: flex;
    gap: 10px;
}

.map-style-option {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    cursor: pointer;
    color: #333;
}

.map-style-option input { cursor: pointer; }

.map-style-label { display: none; }

/* Loading spinner overlay */
.map-loading-spinner {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.85);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    z-index: 5;
    font-size: 13px;
    color: var(--jp-muted);
}

/* ── Journey items (stop cards inside sidebar) ── */
.journey-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: #fff;
    border: 1px solid var(--jp-border);
    border-radius: 7px;
    margin-bottom: 6px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.journey-item:hover {
    border-color: rgba(139,69,19,0.25);
    box-shadow: 0 2px 8px rgba(139,69,19,0.08);
}

/* Location items in the favorites pool */
.location-item,
.favorite-item {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 6px 8px;
    border-radius: 5px;
    cursor: pointer;
    margin-bottom: 3px;
    background: rgba(255,255,255,0.6);
    border: 1px solid transparent;
    transition: all 0.15s;
    font-size: 12px;
    color: var(--jp-text);
}

.location-item:hover,
.favorite-item:hover {
    background: rgba(139,69,19,0.06);
    border-color: rgba(139,69,19,0.12);
}

.location-item.active,
.favorite-item.active {
    background: rgba(139,69,19,0.1);
    border-left: 3px solid var(--jp-accent);
    border-color: rgba(139,69,19,0.15);
}

/* ── Mobile toggle button ── */
.toggle-journey-items {
    display: none;
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 48px;
    height: 48px;
    background: var(--jp-accent);
    color: #fff;
    border: none;
    border-radius: 50%;
    font-size: 16px;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(139,69,19,0.35);
    z-index: 100;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}

/* ── Container override for journey planner page ── */
.journey-planner-page .container {
    max-width: 100%;
    padding: 0;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .journey-planner-body {
        flex-direction: column;
        height: auto;
        overflow: visible;
    }

    .journey-plan-sidebar {
        width: 100%;
        max-height: 55vh;
        border-right: none;
        border-bottom: 1px solid var(--jp-border);
    }

    .journey-map-panel {
        min-height: 380px;
    }

    #journey-map, .journey-map { min-height: 380px; }

    .toggle-journey-items { display: flex; }
}

@media (max-width: 480px) {
    .journey-command-bar { padding: 0 10px; gap: 8px; }
    .journey-select { font-size: 13px; }
    .btn-command-save { padding: 6px 12px; font-size: 12px; }
    .journey-plan-sidebar { max-height: 50vh; }
}

/* ── Keep old map-interface/map-sidebar hidden (compatibility) ── */
.map-interface,
.journey-main-content,
.map-sidebar,
.map-legend { display: none; }
