/* ========================================
   Travel Map
   ======================================== */

.travel-map-section {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(247, 240, 255, 0.9));
}

.travel-form {
    grid-template-columns: 1fr 1.4fr 0.8fr 0.8fr 0.72fr;
    align-items: end;
}

.travel-address-field,
.travel-note-field {
    grid-column: span 2;
}

.travel-map-status {
    margin: -4px 0 10px;
    color: var(--text-light);
    font-size: 0.78rem;
    font-weight: 800;
}

.travel-map {
    position: relative;
    min-height: 260px;
    margin-bottom: 14px;
    border: 2px solid rgba(255, 142, 199, 0.12);
    border-radius: 20px;
    overflow: hidden;
    background:
        linear-gradient(90deg, rgba(255, 142, 199, 0.08) 1px, transparent 1px),
        linear-gradient(180deg, rgba(183, 148, 246, 0.08) 1px, transparent 1px),
        linear-gradient(135deg, #fff8fc, #f7f0ff);
    background-size: 34px 34px, 34px 34px, 100% 100%;
}

.travel-map::before {
    content: '';
    position: absolute;
    inset: 18px;
    border: 2px dashed rgba(183, 148, 246, 0.14);
    border-radius: 18px;
}

.travel-map-empty {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    color: var(--text-light);
    font-weight: 900;
    text-align: center;
}

.travel-pin {
    position: absolute;
    z-index: 2;
    width: 30px;
    height: 30px;
    transform: translate(-50%, -50%);
    border: 2px solid #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 900;
    box-shadow: 0 7px 18px rgba(255, 142, 199, 0.24);
}

.travel-pin.visited {
    background: linear-gradient(135deg, #ff8ec7, #ff6b86);
}

.travel-pin.planned {
    background: linear-gradient(135deg, #b794f6, #a0d2ff);
}

.travel-geo {
    color: var(--text-light);
}

.travel-geo.good {
    color: #5fbf97;
}

.travel-geo.missing {
    color: #ff8a6b;
}

@media (max-width: 980px) {
    .travel-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .travel-form .memory-tool-primary,
    .travel-address-field,
    .travel-note-field {
        grid-column: 1 / -1;
    }
}

@media (max-width: 620px) {
    .travel-form {
        grid-template-columns: 1fr;
    }
}
