/* Story Section
-------------------------------------------------- */
.story-section {
    padding: var(--spacing-xxxl) 0;
    background-color: var(--color-white);
    overflow: hidden;
}

.story-container {
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 0 var(--spacing-lg);
}

.story-title {
    color: var(--color-primary);
    font-size: clamp(var(--font-size-hero), 5vw, var(--font-size-xxxl));
    text-align: center;
    margin-bottom: var(--spacing-xxl);
}

/* Timeline Container */
.timeline-container {
    position: relative;
    padding: var(--spacing-xl) 0;
}

/* Add this to your our-story.css for timeline-line animation */
/* Animate the timeline line from top to bottom */
.timeline-line {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 3px;
    height: 100%;
    background-color: var(--color-primary-light);
    /* Animation setup */
    transform-origin: top;
    scale: 1 0; /* Start collapsed vertically */
    transition: scale 8.2s cubic-bezier(.4,0,.2,1);
    z-index: 1;
}

.timeline-line.animated {
    scale: 1 1; /* Expand to full height */
}

/* Timeline Items */ 
.timeline-items {
    position: relative;
    max-width: 3000px;
    margin: 0 auto;
}

.timeline-item {
    display: flex;
    align-items: center;
    margin-bottom: var(--spacing-xxl);
    position: relative;
    width: 100%;
}

.timeline-item.right {
    padding-left: calc(50% + var(--spacing-xxxl));
    padding-right: var(--spacing-xl);
}

.timeline-item.left {
    padding-right: calc(50% + var(--spacing-xl));
    padding-left: var(--spacing-xl);
    flex-direction: row-reverse;
}


.timeline-icon:hover {
    transform: scale(1.05);
}

.timeline-icon img {
    width: 80%;
    height: auto;
}

/* Timeline Content */
.timeline-content {
    flex: 1;
    padding: 0 var(--spacing-xl);
    max-width: 700px; /* Increased width for desktop */
    width: 100%;
}

.timeline-content p {
    font-size: clamp(var(--font-size-sm), 2vw, var(--font-size-lg));
    line-height: var(--line-height-normal);
    color: var(--color-text);
    margin: 0;
    word-break: normal;        /* Avoids breaking inside words */
    hyphens: none;             /* Disables hyphenation */
    max-width: 100%;
    white-space: normal;       /* Allows wrapping */
}

.timeline-content {
    max-width: 480px;
    min-width: 300px;
    flex-shrink: 1;
}

.timeline-content strong {
    color: var(--color-primary);
}

/* Animation classes */
.story-fade-in {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s cubic-bezier(.4,0,.2,1), transform 0.8s cubic-bezier(.4,0,.2,1);
}
.story-fade-in.visible {
    opacity: 1;
    transform: none;
}

/* Optional: staggered animation for timeline items */
.timeline-item {
    transition-delay: 0s;
}

/* Typewriter effect base styles */
/* .timeline-content .typewriter {
    display: inline-block;
    border-right: 2px solid var(--color-primary, #1a4d8f);
    white-space: pre-line;
    overflow: hidden;
    animation: blink-caret 0.8s step-end infinite;
    vertical-align: middle; 
    height: 1em;            
    line-height: 1em;
}

@keyframes blink-caret {
    0%, 100% { border-color: transparent; }
    50% { border-color: var(--color-primary, #1a4d8f); }
} */


.timeline-content p span {
    display: inline-block;
    animation: fadeInChar 0.2s ease-in;
}
@keyframes fadeInChar {
    from { opacity: 0; transform: translateY(1px); }
    to   { opacity: 1; transform: translateY(0); }
}
.timeline-content p.typewriter::after {
    content: '|';
    display: inline-block;
    animation: blink 0.7s infinite;
    color: var(--color-primary);
    margin-left: 0.1em;
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0; }
}
.timeline-content p {
    white-space: pre-wrap;
}


/* Responsive Adjustments */
@media screen and (min-width: 1281px) and (max-width: 1440px) {
  .story-title {
    font-size: var(--font-size-xxxxxxl);
  }
}

@media screen and (max-width: 1280px) {

    .story-title {
        font-size: var(--font-size-xxxxxl);
    }

    .timeline-item.right {
        padding-left: calc(50% + var(--spacing-xl));
        padding-right: var(--spacing-lg);
    }

    .timeline-item.left {
        padding-right: calc(50% + var(--spacing-lg));
        padding-left: var(--spacing-lg);
    }

    .timeline-icon {
        width: 150px;
        height: 150px;
        margin: 0 calc(var(--spacing-lg) * -1);
        margin-left: var(--spacing-sm);
    }
}


@media screen and (max-width: 1024px) {

       .story-title {
        font-size: var(--font-size-xxxxl);
    }

    .timeline-item,
    .timeline-item.left,
    .timeline-item.right {
        flex-direction: column !important;
        align-items: center !important;
        padding: var(--spacing-lg) 0 !important;
        text-align: center !important;
    }
    .timeline-icon {
        width: 120px;
        height: 120px;
        margin: 0 0 var(--spacing-md) 0;
        position: static;
    }
    .timeline-content {
        max-width: 500px;
        min-width: 0;
        padding: 0 var(--spacing-md);
        text-align: center;
    }
    .timeline-line {
        display: none;
        left: 0%;
        transform: translateX(-50%);
        width: 2px;
        height: 100%;
        background-color: var(--color-primary-light);
    }
}

/* Mobile: further reduce width and spacing */
@media screen and (max-width: 768px) {
       .story-title {
        font-size: var(--font-size-xxxl);
    }

    .timeline-item,
    .timeline-item.left,
    .timeline-item.right {
        flex-direction: column !important;
        align-items: center !important;
        padding: var(--spacing-md) 0 !important;
        text-align: center !important;
    }
    .timeline-icon {
        width: 80px;
        height: 80px;
        margin: 0 0 var(--spacing-sm) 0;
    }
    .timeline-content {
        max-width: 350px;
        padding: 0 var(--spacing-sm);
        text-align: center;
    }
}

/* Small Mobile: even more compact */
@media screen and (max-width: 576px) {

    .story-title {
        font-size: var(--font-size-xl);
    }

    .timeline-item,
    .timeline-item.left,
    .timeline-item.right {
        flex-direction: column !important;
        align-items: center !important;
        padding: var(--spacing-sm) 0 !important;
        text-align: center !important;
    }
    .timeline-icon {
        width: 60px;
        height: 60px;
        margin: 0 0 var(--spacing-xs) 0;
    }
    .timeline-content {
        max-width: 95vw;
        padding: 0;
        text-align: center;
    }
    .timeline-content p {
        font-size: var(--font-size-sm) !important;
    }
}

