/* =========================================================
   MC Timeline Widget
   ========================================================= */

.mc-timeline {
    --mc-tl-line-color:     #2C2C2C;
    --mc-tl-line-w:         2px;
    --mc-tl-connector-len:  50px;
    --mc-tl-step-gap:       64px;
    --mc-tl-badge-area-w:   140px;
    --mc-tl-img-h:          180px;
    --mc-tl-line-left:      0px;

    position: relative;
}

/* ── Vertical line: single pseudo on mc-timeline, always visible ─ */
/*    Drawn directly on wrapper so overflow of children never hides it. */
/*    bottom: img-h/2 ends the line at the last badge vertical center. */
.mc-timeline::before {
    content: '';
    position: absolute;
    left: calc(var(--mc-tl-badge-area-w) / 2 - var(--mc-tl-line-w) / 2);
    top: 0;
    bottom: calc(var(--mc-tl-img-h, 180px) / 2);
    width: var(--mc-tl-line-w);
    background-color: var(--mc-tl-line-color);
    pointer-events: none;
    z-index: 1;
}

/* ── Intro (main heading, aligned with image column) ────── */
.mc-timeline__intro {
    margin-left: calc(var(--mc-tl-badge-area-w) + var(--mc-tl-connector-len));
    margin-bottom: 40px;
}

.mc-timeline__intro-heading {
    margin: 0 0 12px;
}

.mc-timeline__intro-desc {
    margin: 0;
}

/* ── Step (flex row: axis | body) ───────────────────────── */
.mc-timeline__step {
    display: flex;
    align-items: flex-start;
    margin-bottom: var(--mc-tl-step-gap);
    position: relative;
}

.mc-timeline__step--last {
    margin-bottom: 0;
}

/* ── Axis (fixed-width badge column, height = image height) ─ */
.mc-timeline__step-axis {
    flex-shrink: 0;
    width: var(--mc-tl-badge-area-w);
    height: var(--mc-tl-img-h, 180px);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
}

/* Horizontal connector: right edge of axis → body (at badge center = image center) */
.mc-timeline__step-axis::after {
    content: '';
    position: absolute;
    left: 100%;
    top: 50%;
    width: var(--mc-tl-connector-len);
    height: var(--mc-tl-line-w);
    background-color: var(--mc-tl-line-color);
    transform: translateY(-50%);
}

/* ── Badge (full-width of axis → line centered, connector flush) */
.mc-timeline__badge {
    display: block;
    width: 100%;
    text-align: center;
    background-color: #2C2C2C;
    color: #fff;
    border-radius: 4px;
    padding: 8px 20px;
    white-space: nowrap;
    pointer-events: none;
    user-select: none;
    position: relative;
    z-index: 2;
    box-sizing: border-box;
}

/* ── Step body (offset by connector length) ─────────────── */
.mc-timeline__step-body {
    display: flex;
    align-items: center;
    flex: 1;
    gap: 32px;
    flex-wrap: wrap;
    margin-left: var(--mc-tl-connector-len);
    min-width: 0;
}

/* ── Image ──────────────────────────────────────────────── */
.mc-timeline__step-image {
    flex-shrink: 0;
    width: 240px;
    overflow: hidden;
}

.mc-timeline__step-image img {
    display: block;
    width: 100%;
    height: 180px;
    object-fit: cover;
}

/* ── Text column ────────────────────────────────────────── */
.mc-timeline__step-text-col {
    flex: 1;
    min-width: 0;
}

.mc-timeline__step-heading {
    margin: 0 0 12px;
}

.mc-timeline__step-text {
    margin: 0;
}

.mc-timeline__step-text p {
    margin: 0;
}

/* ── Button ─────────────────────────────────────────────── */
.mc-timeline__step-btn-wrap {
    flex-shrink: 0;
}

.mc-timeline__step-btn {
    display: inline-block;
    background-color: #2C2C2C;
    color: #fff;
    border-radius: 4px;
    padding: 12px 24px;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease;
    white-space: nowrap;
}

.mc-timeline__step-btn:hover {
    text-decoration: none;
}

/* =========================================================
   TABLET  (768px – 1199px)
   ========================================================= */
@media (min-width: 768px) and (max-width: 1199px) {

    .mc-timeline__step-body {
        flex-direction: column;
        align-items: stretch;
    }

    .mc-timeline__step-image {
        width: 100%;
    }
}

/* =========================================================
   MOBILE  (≤ 767px)
   Layout:
     - vertical line stays on left (left: line-left)
     - badge moves to top, connected by:
         → horizontal connector (line → badge left edge)
         → vertical connector  (badge bottom center → content)
     - content stacks vertically below
   ========================================================= */
@media (max-width: 767px) {

    /* ── Line: override position to left edge on mobile ─── */
    .mc-timeline::before {
        left: var(--mc-tl-line-left);
        bottom: 0;
    }

    /* ── Intro: full width, no left offset on mobile ───── */
    .mc-timeline__intro {
        margin-left: 0;
        width: 100%;
        box-sizing: border-box;
    }

    /* ── Step: pad left by line offset, stack vertically ── */
    .mc-timeline__step {
        flex-direction: column;
        align-items: stretch;
        padding-left: var(--mc-tl-line-left);
    }

    /* ── Axis: inline at top as flex-row, shrink to content ─ */
    /* align-self: flex-start prevents stretching to full step width,  */
    /* so axis width = connector + badge text → ::after centers on badge */
    .mc-timeline__step-axis {
        width: auto;
        height: auto;
        flex-direction: row;
        justify-content: flex-start;
        align-self: flex-start;
        margin-left: 0;
        padding-bottom: 0;
        z-index: 1;
    }

    /* Horizontal connector: line → badge */
    .mc-timeline__step-axis::before {
        content: '';
        display: block;
        flex-shrink: 0;
        width: var(--mc-tl-connector-len);
        height: var(--mc-tl-line-w);
        background-color: var(--mc-tl-line-color);
        align-self: center;
    }

    /* Vertical connector: badge bottom center → content */
    /* Badge center = connector-len + (axis-width - connector-len)/2 = (axis-width + connector-len)/2 */
    .mc-timeline__step-axis::after {
        left: calc((100% + var(--mc-tl-connector-len)) / 2 - var(--mc-tl-line-w) / 2);
        top: 100%;
        width: var(--mc-tl-line-w);
        height: var(--mc-tl-connector-len);
        transform: none;
        right: auto;
    }

    /* ── Step body stacks vertically ───────────────────── */
    .mc-timeline__step-body {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
        margin-left: 0;
        margin-top: var(--mc-tl-connector-len);
        width: 100%;
        box-sizing: border-box;
    }

    /* ── Image full width on mobile ─────────────────────── */
    .mc-timeline__step-image {
        width: 100%;
        box-sizing: border-box;
    }

    /* ── Button full width on mobile ───────────────────── */
    .mc-timeline__step-btn {
        display: block;
        text-align: center;
    }
}
