/* ============================================================================
   FTS V2 - Content Sections: Overview, Highlights, Itinerary, Includes, CTA
   ============================================================================ */

/* Generic Section — white card on warm page bg */
.fts-v2-section {
    margin-bottom: 16px !important;
    padding: 28px 32px !important;
    border-bottom: none !important;
    background: var(--v2-bg) !important;
    border-radius: var(--v2-radius-xl) !important;
    box-shadow: var(--v2-shadow-sm) !important;
}
.fts-v2-section:last-child { margin-bottom: 0 !important; }

.fts-v2-section-title {
    font-family: var(--v2-font-heading) !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--v2-dark) !important;
    margin: 0 0 24px 0 !important;
    letter-spacing: -0.3px !important;
}
.fts-v2-section-subtitle { color: var(--v2-text-light) !important; margin: -16px 0 24px 0 !important; font-size: 13px !important; }
.fts-v2-subsection-title {
    font-family: var(--v2-font-heading) !important;
    font-size: 16px !important; font-weight: 700 !important;
    color: var(--v2-dark) !important; margin: 0 0 16px 0 !important;
}

/* Overview */
.fts-v2-overview-text { font-size: 14px !important; line-height: 1.7 !important; color: var(--v2-text) !important; }
.fts-v2-overview-text p { margin-bottom: 16px !important; }

/* Highlights */
.fts-v2-highlights { margin-top: 32px !important; background: var(--v2-bg-gray) !important; border-radius: var(--v2-radius-lg) !important; padding: 24px !important; }
.fts-v2-highlights-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 14px 20px !important; }
.fts-v2-highlight-item {
    display: flex !important; align-items: center !important; gap: 10px !important;
    font-size: 13px !important; line-height: 1.4 !important;
    background: #fff !important; padding: 12px 14px !important;
    border-radius: var(--v2-radius-sm) !important;
    border: 1px solid var(--v2-border) !important;
}
.fts-v2-hl-icon {
    flex-shrink: 0 !important;
    width: 28px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    font-size: 16px !important;
}
.fts-v2-hl-icon i {
    color: inherit !important; font-size: 16px !important;
}
.fts-v2-highlight-item span:last-child {
    color: var(--v2-dark) !important; font-weight: 500 !important;
}

/* Itinerary — inherits card from .fts-v2-section */

/* Itinerary Timeline */
.fts-v2-itinerary-timeline { position: relative !important; }

.fts-v2-timeline-item {
    display: flex !important;
    gap: 20px !important;
    margin-bottom: 0 !important;
    position: relative !important;
}

/* Marker column */
.fts-v2-timeline-marker {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    flex-shrink: 0 !important;
}

/* Default circle: hollow with orange border */
.fts-v2-timeline-num {
    width: 38px !important;
    height: 38px !important;
    background: var(--v2-bg) !important;
    color: var(--v2-primary) !important;
    border: 2.5px solid var(--v2-primary) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-family: var(--v2-font-heading) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    flex-shrink: 0 !important;
    z-index: 1 !important;
    transition: all 0.25s ease !important;
}

/* First circle: solid filled */
.fts-v2-timeline-item:first-child .fts-v2-timeline-num {
    background: var(--v2-primary) !important;
    color: #fff !important;
    border-color: var(--v2-primary) !important;
    box-shadow: 0 3px 12px rgba(255, 107, 53, 0.3) !important;
}

/* Timeline connecting line — orange */
.fts-v2-timeline-line {
    width: 2.5px !important;
    flex: 1 !important;
    background: var(--v2-primary) !important;
    min-height: 20px !important;
    opacity: 0.4 !important;
}
.fts-v2-timeline-item:last-child .fts-v2-timeline-line { display: none !important; }

/* Content area */
.fts-v2-timeline-content {
    padding-bottom: 24px !important;
    flex: 1 !important;
    min-width: 0 !important;
}

/* Clickable header row: label + title + chevron */
.fts-v2-timeline-header {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    cursor: pointer !important;
    padding: 4px 0 !important;
}
.fts-v2-timeline-header:hover .fts-v2-timeline-title {
    color: var(--v2-primary) !important;
}

.fts-v2-timeline-header-text {
    flex: 1 !important;
    min-width: 0 !important;
}

/* Time label — orange */
.fts-v2-timeline-label {
    font-size: 12px !important;
    color: var(--v2-primary) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    margin-bottom: 2px !important;
    display: block !important;
}

/* Title */
.fts-v2-timeline-title {
    font-family: var(--v2-font-heading) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--v2-dark) !important;
    margin: 0 !important;
    transition: color 0.2s !important;
}

/* Toggle chevron */
.fts-v2-timeline-toggle {
    flex-shrink: 0 !important;
    width: 28px !important;
    height: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--v2-text-muted) !important;
    font-size: 13px !important;
    transition: transform 0.3s ease, color 0.2s !important;
    margin-top: 2px !important;
}
.fts-v2-timeline-item.active .fts-v2-timeline-toggle {
    transform: rotate(180deg) !important;
    color: var(--v2-primary) !important;
}

/* Description — hidden by default, jQuery controls visibility */
.fts-v2-timeline-desc {
    font-size: 13px !important;
    color: var(--v2-text-light) !important;
    line-height: 1.7 !important;
    margin-top: 8px !important;
    display: none;
}

/* Includes / Excludes */
.fts-v2-includes-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 32px !important; }
.fts-v2-includes-col h3 {
    font-family: var(--v2-font-heading) !important; font-size: 15px !important; font-weight: 700 !important;
    margin: 0 0 16px 0 !important; display: flex !important; align-items: center !important; gap: 8px !important;
}
.fts-v2-col-included h3 { color: var(--v2-success) !important; }
.fts-v2-col-excluded h3 { color: var(--v2-accent) !important; }

.fts-v2-includes-col ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.fts-v2-includes-col li {
    padding: 8px 0 !important; border-bottom: 1px solid var(--v2-border) !important;
    font-size: 13px !important; display: flex !important; align-items: flex-start !important; gap: 8px !important;
}
.fts-v2-includes-col li:last-child { border-bottom: none !important; }
.fts-v2-col-included li i { color: var(--v2-success) !important; margin-top: 3px !important; }
.fts-v2-col-excluded li i { color: var(--v2-accent) !important; margin-top: 3px !important; }

/* CTA Banner */
.fts-v2-cta-banner {
    margin-top: 32px !important;
    background: linear-gradient(135deg, var(--v2-dark) 0%, #16213e 100%) !important;
    border-radius: var(--v2-radius-lg) !important; padding: 32px !important;
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; gap: 20px !important;
}
.fts-v2-cta-text h3 { color: #fff !important; font-family: var(--v2-font-heading) !important; font-size: 17px !important; font-weight: 700 !important; margin: 0 0 6px 0 !important; }
.fts-v2-cta-text p { color: rgba(255,255,255,0.7) !important; margin: 0 !important; font-size: 13px !important; }
.fts-v2-cta-actions { display: flex !important; gap: 12px !important; flex-shrink: 0 !important; }
.fts-v2-cta-btn-primary {
    background: var(--v2-primary) !important; color: #fff !important; padding: 12px 28px !important;
    border-radius: var(--v2-radius-sm) !important; font-weight: 700 !important;
    text-decoration: none !important; font-size: 13px !important; transition: all 0.2s !important; white-space: nowrap !important;
}
.fts-v2-cta-btn-primary:hover { background: var(--v2-primary-dark) !important; color: #fff !important; }
.fts-v2-cta-btn-secondary {
    background: rgba(255,255,255,0.1) !important; color: #fff !important; padding: 12px 28px !important;
    border-radius: var(--v2-radius-sm) !important; font-weight: 600 !important;
    text-decoration: none !important; font-size: 13px !important; transition: all 0.2s !important; white-space: nowrap !important;
}
.fts-v2-cta-btn-secondary:hover { background: rgba(255,255,255,0.2) !important; color: #fff !important; }
.fts-v2-cta-btn-secondary i { color: #25D366 !important; margin-right: 4px !important; }
