/* Estilos básicos para el widget Itinerario (Timeline) */
.bn-itinerario { margin-bottom: 2rem; }
.bn-itinerario-header { margin-bottom: 1rem; display:flex; align-items:center; gap:1rem; }
.bn-itinerario-header-left { display:flex; align-items:center; gap:1rem; }
.bn-itinerario-header-icon { background: var(--e-global-color-primary); color: var(--bn-color-white); display:inline-flex; align-items:center; justify-content:center; width:55px; height:55px; border-radius:12px; padding:8px; box-shadow:0 12px 30px color-mix(in srgb, var(--e-global-color-primary) 18%, transparent); flex-shrink:0; }
.bn-itinerario-header-icon svg, .bn-itinerario-header-icon i { color: var(--bn-color-white); fill: currentColor; width:22px; height:22px; }
.bn-itinerario-title { font-family: var(--e-global-typography-primary-font-family); font-weight:700; font-size:2rem; margin:0; color: var(--e-global-color-text); }
.bn-itinerario-highlight { color: var(--e-global-color-primary); }

.bn-itinerario-timeline { position: relative; padding-left: 64px; }
.bn-itinerario-timeline .bn-timeline-line { position:absolute; left:28px; top:0; bottom:0; width:2px; background: var(--bn-color-border-soft); transform:translateX(-50%); z-index:0; }
.bn-itinerario-timeline .bn-timeline-progress { position:absolute; left:28px; top:0; width:4px; background: var(--e-global-color-primary); transform:translateX(-50%); height:0; z-index:5; border-radius:2px; }

.timeline-marker { position:absolute; left:28px; transform:translateX(-50%); background: var(--bn-color-bg-soft); border:3px solid var(--e-global-color-primary); width:12px; height:12px; border-radius:50%; box-shadow:0 2px 6px rgba(0,0,0,0.05); z-index:10; transition: all 0.35s ease; }
.timeline-marker.small { width:8px; height:8px; border-width:2px; }
.timeline-marker.timeline-icon-header { width:36px; height:36px; border-width:4px; background: var(--bn-color-surface-mid); color: var(--bn-color-white); display:flex; align-items:center; justify-content:center; border-radius: var(--bn-radius-pill); }
.timeline-marker.timeline-icon-header svg, .timeline-marker.timeline-icon-header i { width:20px; height:20px; color: var(--bn-color-white); fill:currentColor; }
.timeline-marker.is-active { background: var(--e-global-color-primary) !important; border-color: var(--e-global-color-primary) !important; transform: translateX(-50%) scale(1.25) !important; box-shadow:0 0 15px color-mix(in srgb, var(--e-global-color-primary) 40%, transparent); }

.bn-tl-row { position:static; margin-bottom:1.5rem; padding-top:6px; }
.bn-tl-stage { display:flex; align-items:center; gap:1rem; }
.bn-tl-stage-label { background: var(--bn-color-white); color: var(--bn-color-surface-mid); border:1px solid var(--e-global-color-primary); padding:8px 18px; border-radius:999px; font-weight:700; font-size:1.25rem; box-shadow:0 6px 18px rgba(0,0,0,0.05); }

.bn-tl-card { padding-left:6px; }
.bn-tl-card-box { background: var(--bn-color-white); border-radius:32px; padding:20px; box-shadow:0 18px 40px rgba(0,0,0,0.06); border:1px solid var(--bn-color-border-soft); transition: transform 0.35s ease, box-shadow 0.35s ease; }
.bn-tl-card-box:hover { transform: translateY(-6px); }
.bn-tl-stop-box:hover { transform: translateY(-6px); box-shadow: 0 18px 36px rgba(0,0,0,0.08); }
.bn-tl-card-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.bn-tl-card-title { margin:0; font-size:1.25rem; color: var(--bn-color-surface-mid); font-weight:800; }
.bn-tl-distance { background:#FFF4EB; color: var(--e-global-color-primary); padding:8px 12px; border-radius:999px; font-weight:800; font-size:0.9rem; }
.bn-tl-card-media {
    position:relative;
    margin-bottom:12px;
    border-radius:24px;
    overflow:hidden;
    /* Altura flexible pero limitada: entre 240px y 400px según viewport */
    height: clamp(240px, 28vw, 300px);
    width: 100%;
}

.bn-tl-card-media img {
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition: transform 0.35s ease;
}

.bn-tl-card-media .bn-media-badge {
    position:absolute;
    top:10px;
    left:10px;
    background:rgba(255,255,255,0.94);
    padding:8px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    box-shadow:0 6px 14px rgba(0,0,0,0.06);
    color: var(--e-global-color-text);
}

.bn-tl-card-media .bn-media-badge svg,
.bn-tl-card-media .bn-media-badge i {
    color: var(--e-global-color-text);
    stroke: currentColor;
    fill: currentColor;
}

/* Contenedor diferenciador para el contenido textual de la card */
.bn-tl-card-content {
    background: var(--bn-color-bg-soft);
    border: 1px solid var(--bn-color-border-soft);
    padding: 12px 14px;
    border-radius: 12px;
    margin-top: 10px;
}

.bn-tl-card-excerpt { color: var(--bn-color-text-strong); margin:0 0 10px 0; line-height:1.6; font-size:0.99rem; }
.bn-tl-card-excerpt p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
}
.bn-tl-card-meta { display:flex; gap:12px; color: var(--bn-color-text-strong); font-weight:700; font-size:0.95rem; align-items:center; flex-wrap:wrap; margin:0; }
.bn-tl-meta-item { display:inline-flex; align-items:center; gap:8px; padding:6px 8px; border-radius:10px; background:transparent; border-radius: 10px; border: 1px solid var(--bn-color-border-soft); padding: 10px; }
.bn-tl-meta-item i { margin-right:6px; color: var(--e-global-color-primary); font-size:0.95rem; }

.bn-tl-stop-box { display:flex; gap:14px; background: var(--bn-color-white); border-radius:24px; padding:14px; align-items:flex-start; border:1px solid var(--bn-color-border-soft); box-shadow:0 10px 24px rgba(0,0,0,0.05); flex-direction:column; transition: transform 420ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 420ms cubic-bezier(0.22, 1, 0.36, 1); will-change: transform; transform: translateZ(0); -webkit-transform: translate3d(0,0,0); -webkit-backface-visibility: hidden; backface-visibility: hidden; }
.bn-tl-stop-media { width:100%; height:200px; overflow:hidden; border-radius:14px; flex:0 0 auto; }
.bn-tl-stop-media img { width:100%; height:100%; object-fit:cover; display:block; }
.bn-tl-stop-body { width:100%; }
.bn-tl-stop-tag { font-size:11px; font-weight:800; color: var(--e-global-color-primary); text-transform:uppercase; }
.bn-tl-stop-title { margin:6px 0 4px 0; color: var(--bn-color-surface-mid); font-weight:800; }
.bn-tl-stop-detail { color: var(--bn-color-text-strong); font-weight:700; margin-bottom:6px; }
.bn-tl-stop-excerpt { margin:0; color: var(--bn-color-text-muted); }

@media (min-width: 768px) {
    .bn-tl-stop-box { flex-direction:row; align-items:center; }
    .bn-tl-stop-media { flex: 0 0 40%; max-width: 40%; height: 180px; }
    .bn-tl-stop-body { flex: 1 1 60%; }
}

/* small responsive tweaks */
@media (max-width: 768px) {
    .bn-itinerario-timeline { padding-left: 48px; }
    .bn-tl-card-media img { height:10rem; }
    .bn-tl-stop-media img { width:100%; height:100%; }
}


.bn-tl-card-media img {
    transition: transform 0.35s ease;
    height: 300px !important; /* Forzar altura fija */
}
