/* Routes page specific styles */
.routes-header {
    margin-bottom: var(--space-4);
}

.routes-description {
    color: var(--text-light);
    font-size: var(--font-size-lg);
    margin-bottom: var(--space-4);
}

.search-card {
    background-color: white;
    border-radius: var(--radius-md);
    padding: var(--space-3);
    margin-bottom: var(--space-4);
    box-shadow: var(--shadow-sm);
}

.route-point {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    padding: var(--space-2) 0;
}

.point-indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-top: 6px;
}

.start-point {
    background-color: var(--success-color);
}

.end-point {
    background-color: var(--error-color);
}

.dashed-line {
    width: 2px;
    height: 30px;
    border-left: 2px dashed var(--border-color);
    margin-left: 5px;
}

.point-label {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    color: var(--text-light);
    margin-bottom: var(--space-1);
}

.point-name {
    font-weight: 500;
}

.routes-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-3);
}

.routes-title {
    font-size: var(--font-size-xl);
    color: var(--text-color);
}

.routes-sort {
    color: var(--text-light);
    font-size: var(--font-size-sm);
}

.route-card {
    background-color: white;
    border-radius: var(--radius-md);
    padding: var(--space-3);
    margin-bottom: var(--space-3);
    box-shadow: var(--shadow-sm);
}

.route-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--space-3);
}

.route-info {
    display: flex;
    gap: var(--space-2);
}

.transport-icons {
    display: flex;
    gap: var(--space-1);
}

.transport-icon {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    color: white;
}

.pedestrian-icon {
    background-color: #28A745;
    background-image: url('https://api.iconify.design/mdi:walk.svg?color=%23ffffff');
}

.bus-icon {
    background-color: var(--primary-color);
}

.trolleybus-icon {
    background-color: var(--success-color);
}

.route-title {
    font-weight: 500;
    margin-bottom: var(--space-1);
}

.route-subtitle {
    color: var(--text-light);
    font-size: var(--font-size-sm);
}

.duration-info {
    text-align: right;
}

.duration-label {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    color: var(--text-light);
    margin-bottom: var(--space-1);
}

.duration-value {
    font-size: var(--font-size-xl);
    font-weight: 500;
}

.route-times {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-3);
    padding: var(--space-2);
    background-color: var(--secondary-light);
    border-radius: var(--radius-md);
}

.time-point {
    text-align: center;
}

.time-label {
    color: var(--text-light);
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-1);
}

.time-value {
    font-size: var(--font-size-lg);
    font-weight: 500;
    margin-bottom: var(--space-1);
}

.time-location {
    color: var(--text-light);
    font-size: var(--font-size-sm);
}

.dashed-separator {
    flex-grow: 1;
    height: 2px;
    border-top: 2px dashed var(--border-color);
    margin: 0 var(--space-2);
}

.route-stats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
    padding: var(--space-2);
    background-color: var(--background-color);
    border-radius: var(--radius-md);
}

.stat-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    color: var(--text-light);
    font-size: var(--font-size-sm);
}

.stat-icon {
    width: 24px;
    height: 24px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}

.distance-icon {
    background-image: url('https://api.iconify.design/mdi:map-marker-distance.svg?color=%236c757d');
}

.walking-icon {
    background-image: url('https://api.iconify.design/mdi:walk.svg?color=%236c757d');
}

.transfers-icon {
    background-image: url('https://api.iconify.design/mdi:transfer.svg?color=%236c757d');
}

.co2-icon {
    background-image: url('https://api.iconify.design/mdi:molecule-co2.svg?color=%236c757d');
}

.calories-icon {
    background-image: url('https://api.iconify.design/mdi:fire.svg?color=%236c757d');
}

.route-details-toggle {
    margin-bottom: var(--space-3);
}

.details-button {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    color: var(--primary-color);
    font-weight: 500;
    padding: var(--space-2);
    width: 100%;
    background-color: transparent;
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-medium);
}

.details-button:hover {
    background-color: var(--secondary-light);
}

.details-arrow {
    transition: transform var(--transition-medium);
}

.route-details {
    display: none;
    padding: var(--space-2);
    margin-top: var(--space-2);
    border-top: 1px solid var(--border-light);
}

.section {
    margin-bottom: var(--space-3);
}

.section:last-child {
    margin-bottom: 0;
}

.section-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}

.section-transport-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}

.section-info h4 {
    font-weight: 500;
    margin-bottom: var(--space-1);
}

.section-subtitle {
    color: var(--text-light);
    font-size: var(--font-size-sm);
}

.section-times {
    display: flex;
    justify-content: space-between;
    color: var(--text-light);
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-2);
}

.intermediate-stops {
    background-color: var(--background-color);
    padding: var(--space-2);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-2);
}

.intermediate-title {
    font-weight: 500;
    margin-bottom: var(--space-1);
}

.intermediate-stop {
    color: var(--text-light);
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-1);
}

.intermediate-stop:last-child {
    margin-bottom: 0;
}

.map-placeholder {
    background-color: var(--background-color);
    border-radius: var(--radius-md);
    padding: var(--space-2);
}

.map-placeholder h5 {
    margin-bottom: var(--space-2);
}

.map-area {
    height: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: white;
    border-radius: var(--radius-md);
}

.map-text {
    font-size: var(--font-size-md);
    margin: var(--space-1) 0;
}

.map-distance {
    font-size: var(--font-size-sm);
    color: var(--text-light);
}

.eco-badge {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-2);
    background-color: #E8F5E9;
    color: #2E7D32;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
}

.eco-icon {
    font-size: var(--font-size-lg);
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .route-header {
        flex-direction: column;
        gap: var(--space-2);
    }

    .duration-info {
        text-align: left;
    }

    .route-times {
        flex-direction: column;
        gap: var(--space-2);
    }

    .dashed-separator {
        width: 2px;
        height: 20px;
        border-left: 2px dashed var(--border-color);
        border-top: none;
        margin: var(--space-1) 0;
    }

    .route-stats {
        gap: var(--space-1);
    }

    .stat-item {
        width: calc(50% - var(--space-1));
    }
}

@media (max-width: 576px) {
    .stat-item {
        width: 100%;
    }

    .section-times {
        flex-direction: column;
        gap: var(--space-1);
    }
}