/* ==========================================================================
   Wolff Timeline
   ========================================================================== */

.wolff-timeline {
    --wolff-bg: #07101f;
    --wolff-gold: #c8a94e;
    --wolff-text: #f0e6d3;
    --wolff-muted: #7a8fa8;
    --wolff-line: rgba(200, 169, 78, .18);
    --wolff-line-strong: rgba(200, 169, 78, .35);
    --wolff-progress-color: #c8a94e;
    --wolff-progress-fade: rgba(200, 169, 78, .3);
    --wolff-dot-bg: #07101f;
    --wolff-dot-glow-color: rgba(200, 169, 78, .5);
    --wolff-dot-glow-blur: 14px;
    --wolff-event-rule-color: #c8a94e;
    --wolff-image-border: rgba(200, 169, 78, .2);
    --wolff-image-frame-bg: transparent;
    --wolff-image-radius: 2px;
    --wolff-lightbox-bg: rgba(4, 9, 18, .92);
    --wolff-lightbox-image-border: rgba(200, 169, 78, .34);
    --wolff-lightbox-max-width: 92vw;
    --wolff-lightbox-max-height: 82vh;
    --wolff-lightbox-radius: 2px;
    --wolff-lightbox-blur: 6px;
    --wolff-zoom-icon-bg: rgba(200, 169, 78, .85);
    --wolff-zoom-icon-color: #07101f;
    --wolff-zoom-icon-size: 40px;
    --wolff-close-bg: #c8a94e;
    --wolff-close-color: #07101f;
    --wolff-close-size: 36px;
    --wolff-close-icon-size: 28px;
    --wolff-close-offset: 14px;
    --wolff-hero-content-width: 760px;
    --wolff-hero-glow-opacity: .07;
    --wolff-logo-width: 128px;
    --wolff-timeline-max-width: 1280px;
    --wolff-column-gap: 40px;
    --wolff-line-offset: 0px;
    --wolff-axis-column: 56px;
    --wolff-text-width: 520px;
    --wolff-image-width: 520px;
    --wolff-line-width: 1px;
    --wolff-dot-size: 16px;
    --wolff-dot-border-width: 2px;
    --wolff-event-rule-width: 40px;
    --wolff-mobile-line-offset: 7px;
    --wolff-reveal-distance: 55px;
    --wolff-mobile-reveal-distance: 35px;
    --wolff-reveal-duration: .7s;
    --wolff-text-delay: .08s;
    --wolff-ease: cubic-bezier(.25, .46, .45, .94);
    --wolff-spring: cubic-bezier(.22, 1.42, .36, 1);

    position: relative;
    overflow: hidden;
    background: var(--wolff-bg);
    color: var(--wolff-text);
    font-family: "Jost", Arial, sans-serif;
}

.wolff-timeline *,
.wolff-timeline *::before,
.wolff-timeline *::after {
    box-sizing: border-box;
}

.wolff-timeline img {
    max-width: 100%;
    height: auto;
}

.wolff-timeline--no-line .wolff-timeline__axis-line,
.wolff-timeline--no-line .wolff-timeline__mobile-line {
    display: none;
}

.wolff-timeline--no-dots .wolff-timeline__dot,
.wolff-timeline--no-dots .wolff-timeline__end-cap {
    display: none;
}

.wolff-timeline--no-zoom .wolff-timeline__zoom-icon,
.wolff-timeline-lightbox--no-zoom .wolff-timeline-lightbox__zoom {
    display: none;
}

.wolff-timeline__hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 96px 24px;
    text-align: center;
    background:
        radial-gradient(ellipse 70% 60% at 50% 40%, rgba(200, 169, 78, var(--wolff-hero-glow-opacity)) 0%, transparent 70%),
        var(--wolff-bg);
}

.wolff-timeline__ruler {
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(200, 169, 78, .34), transparent);
    pointer-events: none;
}

.wolff-timeline__ruler--top {
    top: 0;
}

.wolff-timeline__ruler--bottom {
    bottom: 0;
}

.wolff-timeline__hero-inner {
    position: relative;
    z-index: 2;
    width: min(100%, var(--wolff-hero-content-width));
    margin: 0 auto;
}

.wolff-timeline__logo {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 7px;
    margin-bottom: 28px;
    color: var(--wolff-gold);
}

.wolff-timeline__logo img {
    width: auto;
    max-width: var(--wolff-logo-width);
    max-height: 96px;
    display: block;
}

.wolff-timeline__logo-mark {
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 2px solid currentColor;
    border-radius: 50%;
    font-family: "EB Garamond", Georgia, serif;
    font-size: 32px;
    line-height: 1;
}

.wolff-timeline__logo-name {
    display: block;
    font-family: "EB Garamond", Georgia, serif;
    font-size: 31px;
    line-height: .86;
    letter-spacing: 0;
}

.wolff-timeline__kicker,
.wolff-timeline__since,
.wolff-timeline__scroll-label,
.wolff-timeline__footer-label {
    font-family: "Jost", Arial, sans-serif;
    font-size: 11px;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: .55em;
    text-transform: uppercase;
    color: var(--wolff-gold);
}

.wolff-timeline__kicker {
    margin-bottom: 20px;
    opacity: .65;
}

.wolff-timeline__hero-title {
    margin: 0;
    font-family: "EB Garamond", Georgia, serif;
    font-size: 3.25rem;
    font-weight: 700;
    line-height: .95;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--wolff-text);
}

.wolff-timeline__since {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 17px;
    margin-top: 28px;
    letter-spacing: .45em;
}

.wolff-timeline__since span {
    width: 64px;
    height: 1px;
    background: var(--wolff-line-strong);
}

.wolff-timeline__since strong {
    display: block;
    font: inherit;
    color: var(--wolff-gold);
}

.wolff-timeline__hero-subtitle {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 9px;
    margin-top: 42px;
    font-family: "EB Garamond", Georgia, serif;
    font-size: 2.1rem;
    line-height: 1.1;
    color: var(--wolff-text);
}

.wolff-timeline__hero-subtitle em {
    font-style: italic;
    font-weight: 300;
}

.wolff-timeline__hero-subtitle span {
    color: var(--wolff-gold);
    font-style: normal;
    font-weight: 600;
}

.wolff-timeline__hero-description,
.wolff-timeline__body,
.wolff-timeline__footer-text {
    font-family: "Jost", Arial, sans-serif;
    font-weight: 300;
    color: var(--wolff-muted);
}

.wolff-timeline__hero-description {
    max-width: 520px;
    margin: 22px auto 0;
    font-size: 15px;
    line-height: 1.65;
}

.wolff-timeline__scroll-cue {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 38px;
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 18px;
    width: 100%;
    transform: none;
    transition: opacity .45s ease, visibility .45s ease;
}

.wolff-timeline.is-scroll-hidden .wolff-timeline__scroll-cue {
    opacity: 0;
    visibility: hidden;
}

.wolff-timeline__scroll-label {
    font-size: 10px;
    letter-spacing: .55em;
    opacity: .72;
    padding-left: .55em;
    text-align: center;
    white-space: nowrap;
}

.wolff-timeline__scroll-line {
    width: 1px;
    height: 42px;
    overflow: hidden;
    background: rgba(200, 169, 78, .16);
}

.wolff-timeline__scroll-line::after {
    content: "";
    display: block;
    width: 1px;
    height: 19px;
    background: var(--wolff-gold);
    animation: wolff-scroll-line 1.6s ease-in-out infinite;
}

.wolff-timeline__timeline {
    position: relative;
    max-width: var(--wolff-timeline-max-width);
    margin: 0 auto;
    padding: 96px 24px 130px;
}

.wolff-timeline__desktop {
    display: block;
}

.wolff-timeline__desktop-track {
    position: relative;
    width: 100%;
}

.wolff-timeline__axis-line {
    position: absolute;
    top: 0;
    bottom: 42px;
    left: 50%;
    width: var(--wolff-line-width);
    overflow: hidden;
    background: var(--wolff-line);
    transform: translateX(-50%);
}

.wolff-timeline__progress {
    position: absolute;
    inset: 0 0 auto;
    width: var(--wolff-line-width);
    height: 100%;
    background: linear-gradient(to bottom, var(--wolff-progress-color), var(--wolff-progress-fade));
    transform: scaleY(0);
    transform-origin: top;
    will-change: transform;
}

.wolff-timeline__item {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--wolff-axis-column) minmax(0, 1fr);
    align-items: center;
    column-gap: var(--wolff-column-gap);
    min-height: 340px;
    margin-bottom: 110px;
}

.wolff-timeline__item:last-of-type {
    margin-bottom: 78px;
}

.wolff-timeline__axis {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
}

.wolff-timeline__dot {
    width: var(--wolff-dot-size);
    height: var(--wolff-dot-size);
    display: block;
    border: var(--wolff-dot-border-width) solid var(--wolff-gold);
    border-radius: 50%;
    background: var(--wolff-dot-bg);
    box-shadow: 0 0 var(--wolff-dot-glow-blur) var(--wolff-dot-glow-color);
    transform: scale(0);
    opacity: 0;
    will-change: opacity, transform;
    transition: opacity .32s ease, transform .36s ease;
}

.wolff-timeline__item.is-visible .wolff-timeline__dot,
.wolff-timeline__mobile-item.is-visible .wolff-timeline__dot,
.wolff-timeline__dot.is-visible {
    opacity: 1;
    transform: scale(1);
    animation: wolff-dot-pop .62s var(--wolff-spring) var(--wolff-dot-delay, 0s) both;
}

.wolff-timeline[data-dot-animation="scale"] .wolff-timeline__item.is-visible .wolff-timeline__dot,
.wolff-timeline[data-dot-animation="scale"] .wolff-timeline__mobile-item.is-visible .wolff-timeline__dot,
.wolff-timeline[data-dot-animation="scale"] .wolff-timeline__dot.is-visible {
    animation: none;
    transition: opacity .32s ease, transform .36s var(--wolff-ease);
}

.wolff-timeline[data-dot-animation="fade"] .wolff-timeline__dot {
    transform: none;
}

.wolff-timeline[data-dot-animation="fade"] .wolff-timeline__item.is-visible .wolff-timeline__dot,
.wolff-timeline[data-dot-animation="fade"] .wolff-timeline__mobile-item.is-visible .wolff-timeline__dot,
.wolff-timeline[data-dot-animation="fade"] .wolff-timeline__dot.is-visible {
    animation: none;
    transform: none;
}

.wolff-timeline[data-dot-animation="none"] .wolff-timeline__dot {
    opacity: 1;
    transform: none;
    animation: none;
    transition: none;
}

.wolff-timeline__end-cap {
    position: relative;
    z-index: 2;
    width: 8px;
    height: 8px;
    margin: -14px auto 0;
    border-radius: 50%;
    background: var(--wolff-progress-color);
    box-shadow: 0 0 20px var(--wolff-dot-glow-color);
}

.wolff-timeline__text {
    position: relative;
    z-index: 2;
    width: min(100%, var(--wolff-text-width));
    --wolff-current-line-offset: var(--wolff-item-line-offset, var(--wolff-line-offset, 0px));
    --wolff-line-shift-x: 0px;
}

.wolff-timeline__text--left {
    --wolff-line-shift-x: calc(var(--wolff-current-line-offset) * -1);
    justify-self: end;
    text-align: center;
}

.wolff-timeline__text--right {
    --wolff-line-shift-x: var(--wolff-current-line-offset);
    justify-self: start;
    text-align: left;
}

.wolff-timeline__year {
    margin: 0 0 8px;
    font-family: "EB Garamond", Georgia, serif;
    font-size: 6.7rem;
    font-weight: 400;
    line-height: .9;
    color: var(--wolff-gold);
}

.wolff-timeline__event-title {
    margin: 0;
    font-family: "EB Garamond", Georgia, serif;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.25;
    color: var(--wolff-text);
}

.wolff-timeline__event-rule {
    display: block;
    width: var(--wolff-event-rule-width);
    height: 1px;
    margin: 17px 0 0;
    background: var(--wolff-event-rule-color);
}

.wolff-timeline__text--left .wolff-timeline__event-rule {
    margin-right: auto;
    margin-left: auto;
}

.wolff-timeline__body {
    margin-top: 20px;
    font-size: 15px;
    line-height: 1.85;
}

.wolff-timeline__media {
    position: relative;
    z-index: 2;
    width: min(100%, var(--wolff-image-width));
    --wolff-current-line-offset: var(--wolff-item-line-offset, var(--wolff-line-offset, 0px));
    --wolff-line-shift-x: 0px;
}

.wolff-timeline__media--left {
    --wolff-line-shift-x: calc(var(--wolff-current-line-offset) * -1);
    justify-self: end;
}

.wolff-timeline__media--right {
    --wolff-line-shift-x: var(--wolff-current-line-offset);
    justify-self: start;
}

.wolff-timeline__media--image {
    background: transparent !important;
    box-shadow: none !important;
}

.wolff-timeline__image-frame {
    position: relative;
    width: 100%;
    height: 240px;
    border: 1px solid var(--wolff-image-border);
    border-radius: var(--wolff-image-radius);
    overflow: hidden;
    background: var(--wolff-image-frame-bg);
}

.wolff-timeline__image-frame--image {
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    background-color: transparent !important;
}

.wolff-timeline__image-inner,
.wolff-timeline__image-action {
    position: relative;
    width: 100%;
    height: 100%;
    display: block;
}

.wolff-timeline__image-inner {
    will-change: transform;
}

.wolff-timeline__image-inner--image {
    overflow: visible !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
}

.wolff-timeline__image-action {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: inherit;
    cursor: pointer;
    overflow: hidden;
}

div.wolff-timeline__image-action {
    cursor: default;
}

.wolff-timeline__image-action--image {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
}

.wolff-timeline__image-action--image img {
    width: var(--wolff-event-image-width, auto);
    height: auto;
    max-width: 100%;
    max-height: var(--wolff-event-image-height, 100%);
    display: block;
    object-fit: contain;
    object-position: center center;
    transition: transform .5s var(--wolff-ease);
}

.wolff-timeline__image-action--image::before {
    display: none !important;
    content: none !important;
}

.wolff-timeline__image-action--video,
.wolff-timeline__image-action--custom,
.wolff-timeline__image-action--template,
.wolff-timeline__image-action--empty {
    cursor: default;
}

.wolff-timeline__video,
.wolff-timeline__embed {
    width: 100%;
    height: 100%;
    display: block;
    border: 0;
    background: #000;
}

.wolff-timeline__custom-content {
    width: 100%;
    min-height: 100%;
    padding: clamp(22px, 4vw, 42px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: var(--wolff-text);
    background: rgba(255, 255, 255, .025);
    overflow: auto;
}

.wolff-timeline__custom-content > :first-child {
    margin-top: 0;
}

.wolff-timeline__custom-content > :last-child {
    margin-bottom: 0;
}

.wolff-timeline__custom-content iframe,
.wolff-timeline__custom-content video,
.wolff-timeline__custom-content img {
    max-width: 100%;
}

.wolff-timeline__template-content {
    width: 100%;
    min-height: 100%;
    position: relative;
}

.wolff-timeline__template-content > .elementor {
    min-height: 100%;
}

.wolff-timeline__template-content .elementor-section,
.wolff-timeline__template-content .e-con {
    max-width: 100%;
}

.wolff-timeline__empty-media {
    width: 100%;
    height: 100%;
    min-height: 160px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px;
    color: var(--wolff-muted);
    text-align: center;
    background: rgba(255, 255, 255, .025);
}

.wolff-timeline__media--none {
    min-height: 1px;
    visibility: hidden;
    pointer-events: none;
}

.wolff-timeline__zoom-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    width: var(--wolff-zoom-icon-size);
    height: var(--wolff-zoom-icon-size);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--wolff-zoom-icon-bg);
    color: var(--wolff-zoom-icon-color);
    font-size: calc(var(--wolff-zoom-icon-size) * .52);
    line-height: 1;
    opacity: 0;
    transform: translate(-50%, -50%) scale(.88);
    transition: opacity .35s ease, transform .35s var(--wolff-ease);
}

.wolff-timeline__zoom-icon svg {
    width: 1em;
    height: 1em;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.wolff-timeline__image-action--image:hover img,
.wolff-timeline__image-action--image:focus-visible img {
    transform: scale(1.05);
}

.wolff-timeline__image-action--image:hover .wolff-timeline__zoom-icon,
.wolff-timeline__image-action--image:focus-visible .wolff-timeline__zoom-icon {
    opacity: 1;
}

.wolff-timeline__image-action--image:hover .wolff-timeline__zoom-icon,
.wolff-timeline__image-action--image:focus-visible .wolff-timeline__zoom-icon {
    transform: translate(-50%, -50%) scale(1);
}

.wolff-timeline__image-action:focus-visible {
    outline: 2px solid var(--wolff-gold);
    outline-offset: 4px;
}

.wolff-timeline__mobile {
    display: none;
}

.wolff-timeline__footer {
    margin-top: 44px;
    text-align: center;
}

.wolff-timeline__footer-label {
    letter-spacing: .24em;
    opacity: .9;
}

.wolff-timeline__footer-text {
    margin-top: 10px;
    font-size: 15px;
}

.wolff-timeline__animate {
    opacity: 0;
    will-change: opacity, transform;
    transition:
        opacity var(--wolff-reveal-duration) var(--wolff-ease) var(--wolff-delay, 0s),
        transform var(--wolff-reveal-duration) var(--wolff-ease) var(--wolff-delay, 0s);
}

.wolff-timeline__animate--left {
    transform: translate3d(calc(var(--wolff-line-shift-x, 0px) - var(--wolff-reveal-distance)), 0, 0);
}

.wolff-timeline__animate--right {
    transform: translate3d(calc(var(--wolff-line-shift-x, 0px) + var(--wolff-reveal-distance)), 0, 0);
}

.wolff-timeline__animate--up {
    transform: translate3d(0, 24px, 0);
}

.wolff-timeline[data-animation="fade_up"] .wolff-timeline__item .wolff-timeline__animate {
    transform: translate3d(var(--wolff-line-shift-x, 0px), var(--wolff-mobile-reveal-distance), 0);
}

.wolff-timeline[data-animation="zoom_soft"] .wolff-timeline__item .wolff-timeline__animate,
.wolff-timeline[data-animation="zoom_soft"] .wolff-timeline__mobile-item .wolff-timeline__animate {
    transform: translate3d(var(--wolff-line-shift-x, 0px), 0, 0) scale(.94);
}

.wolff-timeline[data-animation="fade"] .wolff-timeline__item .wolff-timeline__animate,
.wolff-timeline[data-animation="fade"] .wolff-timeline__mobile-item .wolff-timeline__animate {
    transform: translate3d(var(--wolff-line-shift-x, 0px), 0, 0);
}

.wolff-timeline__item.is-visible .wolff-timeline__media,
.wolff-timeline__item.is-visible .wolff-timeline__text {
    opacity: 1;
    transform: translate3d(var(--wolff-line-shift-x, 0px), 0, 0);
}

.wolff-timeline .wolff-timeline__item.is-visible > .wolff-timeline__media.wolff-timeline__animate.is-visible,
.wolff-timeline .wolff-timeline__item.is-visible > .wolff-timeline__text.wolff-timeline__animate.is-visible {
    opacity: 1;
    transform: translate3d(var(--wolff-line-shift-x, 0px), 0, 0);
}

.wolff-timeline .wolff-timeline__item.is-visible > .wolff-timeline__media.is-reveal-stable,
.wolff-timeline .wolff-timeline__item.is-visible > .wolff-timeline__text.is-reveal-stable {
    opacity: 1 !important;
    transform: translate3d(var(--wolff-line-shift-x, 0px), 0, 0) !important;
    transition: none !important;
}

.wolff-timeline__mobile-item.is-visible .wolff-timeline__media,
.wolff-timeline__mobile-item.is-visible .wolff-timeline__text,
.wolff-timeline__mobile-item.is-visible .wolff-timeline__mobile-content,
.wolff-timeline__hero .wolff-timeline__animate.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.wolff-timeline--editor-preview .wolff-timeline__animate,
.elementor-editor-active .wolff-timeline__animate,
.wolff-timeline--editor-preview .wolff-timeline__dot,
.elementor-editor-active .wolff-timeline__dot {
    opacity: 1;
    transition: none !important;
    animation: none;
}

.wolff-timeline--editor-preview .wolff-timeline__item .wolff-timeline__media,
.wolff-timeline--editor-preview .wolff-timeline__item .wolff-timeline__text,
.elementor-editor-active .wolff-timeline__item .wolff-timeline__media,
.elementor-editor-active .wolff-timeline__item .wolff-timeline__text {
    transform: translate3d(var(--wolff-line-shift-x, 0px), 0, 0);
}

.wolff-timeline--editor-preview .wolff-timeline__mobile-item .wolff-timeline__media,
.wolff-timeline--editor-preview .wolff-timeline__mobile-item .wolff-timeline__text,
.wolff-timeline--editor-preview .wolff-timeline__mobile-item .wolff-timeline__mobile-content,
.elementor-editor-active .wolff-timeline__mobile-item .wolff-timeline__media,
.elementor-editor-active .wolff-timeline__mobile-item .wolff-timeline__text,
.elementor-editor-active .wolff-timeline__mobile-item .wolff-timeline__mobile-content {
    transform: translate3d(0, 0, 0);
}

.wolff-timeline--editor-preview .wolff-timeline__progress,
.wolff-timeline--editor-preview .wolff-timeline__mobile-progress,
.elementor-editor-active .wolff-timeline__progress,
.elementor-editor-active .wolff-timeline__mobile-progress {
    transform: scaleY(1);
}

.wolff-timeline-lightbox {
    --wolff-lightbox-bg: rgba(4, 9, 18, .92);
    --wolff-lightbox-image-border: rgba(200, 169, 78, .34);
    --wolff-lightbox-max-width: 92vw;
    --wolff-lightbox-max-height: 82vh;
    --wolff-lightbox-radius: 2px;
    --wolff-lightbox-blur: 6px;
    --wolff-zoom-icon-bg: rgba(200, 169, 78, .85);
    --wolff-zoom-icon-color: #07101f;
    --wolff-zoom-icon-size: 40px;
    --wolff-close-bg: #c8a94e;
    --wolff-close-color: #07101f;
    --wolff-close-size: 36px;
    --wolff-close-icon-size: 28px;
    --wolff-close-offset: 14px;

    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 56px 24px;
    background: var(--wolff-lightbox-bg);
    -webkit-backdrop-filter: blur(var(--wolff-lightbox-blur));
    backdrop-filter: blur(var(--wolff-lightbox-blur));
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s var(--wolff-ease), visibility .3s var(--wolff-ease);
}

.wolff-timeline-lightbox.is-open {
    opacity: 1;
    visibility: visible;
}

.wolff-timeline-lightbox__stage {
    position: relative;
    max-width: var(--wolff-lightbox-max-width);
    max-height: var(--wolff-lightbox-max-height);
    display: flex;
    align-items: center;
    justify-content: center;
    isolation: isolate;
}

.elementor-editor-active .wolff-timeline:not(.wolff-timeline--no-zoom) .wolff-timeline__image-action--image .wolff-timeline__zoom-icon {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.wolff-timeline-lightbox__image {
    max-width: 100%;
    max-height: var(--wolff-lightbox-max-height);
    display: block;
    border: 1px solid var(--wolff-lightbox-image-border);
    border-radius: var(--wolff-lightbox-radius);
    object-fit: contain;
    opacity: 0;
    transform: scale(.88);
    transition: opacity .3s var(--wolff-ease), transform .3s var(--wolff-ease);
}

.wolff-timeline-lightbox.is-open .wolff-timeline-lightbox__image {
    opacity: 1;
    transform: scale(1);
}

.wolff-timeline-lightbox__zoom {
    display: none !important;
}

body .wolff-timeline-lightbox .wolff-timeline-lightbox__zoom {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

.wolff-timeline-lightbox__zoom svg {
    width: 1em;
    height: 1em;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.wolff-timeline-lightbox__close {
    position: absolute;
    top: var(--wolff-close-offset);
    right: var(--wolff-close-offset);
    z-index: 3;
    width: var(--wolff-close-size);
    height: var(--wolff-close-size);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: var(--wolff-close-bg);
    color: var(--wolff-close-color);
    font-size: var(--wolff-close-icon-size);
    line-height: 1;
    cursor: pointer;
    box-shadow: 0 10px 24px rgba(0, 0, 0, .18);
    opacity: 0;
    transform: scale(.9);
    transition: opacity .3s var(--wolff-ease), transform .3s var(--wolff-ease), box-shadow .3s var(--wolff-ease);
}

body .wolff-timeline-lightbox .wolff-timeline-lightbox__stage > .wolff-timeline-lightbox__close {
    position: absolute !important;
    top: var(--wolff-close-offset) !important;
    right: var(--wolff-close-offset) !important;
    bottom: auto !important;
    left: auto !important;
    z-index: 3 !important;
    width: var(--wolff-close-size) !important;
    min-width: var(--wolff-close-size) !important;
    max-width: var(--wolff-close-size) !important;
    height: var(--wolff-close-size) !important;
    min-height: var(--wolff-close-size) !important;
    max-height: var(--wolff-close-size) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 50% !important;
    outline: 0;
    background: var(--wolff-close-bg) !important;
    color: var(--wolff-close-color) !important;
    font-size: var(--wolff-close-icon-size) !important;
    line-height: 1 !important;
    text-decoration: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    box-sizing: border-box !important;
}

.wolff-timeline-lightbox.is-open .wolff-timeline-lightbox__close {
    opacity: 1;
    transform: scale(1);
}

.wolff-timeline-lightbox.is-open .wolff-timeline-lightbox__close:hover,
.wolff-timeline-lightbox.is-open .wolff-timeline-lightbox__close:focus-visible {
    transform: scale(1.06);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .24);
}

.wolff-timeline-lightbox__close svg {
    width: 1em;
    height: 1em;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

body .wolff-timeline-lightbox .wolff-timeline-lightbox__stage > .wolff-timeline-lightbox__close svg {
    width: 1em !important;
    height: 1em !important;
    display: block !important;
    fill: none !important;
    color: inherit !important;
    stroke: currentColor !important;
    stroke-width: 2 !important;
}

body .wolff-timeline-lightbox .wolff-timeline-lightbox__stage > .wolff-timeline-lightbox__close svg path {
    stroke: currentColor !important;
}

.wolff-timeline-lightbox__close:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 3px;
}

body.wolff-timeline-lightbox-open {
    overflow: hidden;
}

@keyframes wolff-scroll-line {
    0% {
        transform: translateY(-22px);
        opacity: 0;
    }
    28% {
        opacity: 1;
    }
    100% {
        transform: translateY(42px);
        opacity: 0;
    }
}

@keyframes wolff-dot-pop {
    0% {
        opacity: 0;
        transform: scale(0);
    }
    62% {
        opacity: 1;
        transform: scale(1.18);
    }
    82% {
        transform: scale(.96);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

@media (min-width: 768px) {
    .wolff-timeline__hero-title {
        font-size: 4.35rem;
    }

    .wolff-timeline__hero-subtitle {
        font-size: 2.35rem;
    }
}

@media (min-width: 1200px) {
    .wolff-timeline__hero-title {
        font-size: 5.5rem;
    }
}

@media (max-width: 1024px) {
    .wolff-timeline__item {
        column-gap: 24px;
    }

    .wolff-timeline__year {
        font-size: 5.4rem;
    }

    .wolff-timeline__body {
        font-size: 14px;
    }
}

@media (max-width: 767px) {
    .wolff-timeline__hero {
        min-height: 100vh;
        padding: 80px 18px 112px;
    }

    .wolff-timeline__logo {
        margin-bottom: 24px;
    }

    .wolff-timeline__kicker,
    .wolff-timeline__since,
    .wolff-timeline__scroll-label {
        letter-spacing: .3em;
    }

    .wolff-timeline__kicker {
        font-size: 10px;
        line-height: 1.7;
    }

    .wolff-timeline__hero-title {
        font-size: 3.25rem;
        letter-spacing: .09em;
    }

    .wolff-timeline__since {
        gap: 12px;
        margin-top: 24px;
        font-size: 10px;
    }

    .wolff-timeline__since span {
        width: 42px;
    }

    .wolff-timeline__hero-subtitle {
        flex-wrap: wrap;
        margin-top: 34px;
        font-size: 2rem;
    }

    .wolff-timeline__hero-description {
        font-size: 14px;
    }

    .wolff-timeline__scroll-cue {
        bottom: 30px;
    }

    .wolff-timeline__timeline {
        padding: 72px 18px 96px;
    }

    .wolff-timeline__desktop {
        display: none;
    }

    .wolff-timeline__mobile {
        position: relative;
        display: block;
        padding-left: calc(var(--wolff-mobile-line-offset) + 31px);
    }

    .wolff-timeline__mobile .wolff-timeline__media,
    .wolff-timeline__mobile .wolff-timeline__text {
        --wolff-current-line-offset: 0px;
        --wolff-line-shift-x: 0px;
    }

    .wolff-timeline__mobile-line {
        position: absolute;
        top: 0;
        bottom: 18px;
        left: var(--wolff-mobile-line-offset);
        width: var(--wolff-line-width);
        overflow: hidden;
        background: linear-gradient(to bottom, transparent, var(--wolff-line) 8%, var(--wolff-line) 92%, transparent);
    }

    .wolff-timeline__mobile-progress {
        position: absolute;
        inset: 0 0 auto;
        width: var(--wolff-line-width);
        height: 100%;
        background: linear-gradient(to bottom, var(--wolff-progress-color), var(--wolff-progress-fade));
        transform: scaleY(0);
        transform-origin: top;
    }

    .wolff-timeline__mobile-item {
        position: relative;
        margin-bottom: 64px;
    }

    .wolff-timeline__mobile-item:last-child {
        margin-bottom: 0;
    }

    .wolff-timeline__dot--mobile {
        position: absolute;
        top: 20px;
        left: -38px;
        z-index: 2;
    }

    .wolff-timeline__mobile-content {
        width: 100%;
        transform: translate3d(0, 35px, 0);
    }

    .wolff-timeline__text--mobile {
        width: 100%;
        margin-bottom: 22px;
        text-align: left;
    }

    .wolff-timeline__year {
        font-size: 4rem;
    }

    .wolff-timeline__event-title {
        font-size: 20px;
    }

    .wolff-timeline__body {
        font-size: 14px;
        line-height: 1.8;
    }

    .wolff-timeline__image-frame {
        height: 220px;
    }

    .wolff-timeline__footer {
        margin-top: 72px;
    }

    .wolff-timeline__footer-label {
        letter-spacing: .16em;
        line-height: 1.7;
    }
}

@media (prefers-reduced-motion: reduce) {
    .wolff-timeline *,
    .wolff-timeline *::before,
    .wolff-timeline *::after,
    .wolff-timeline-lightbox,
    .wolff-timeline-lightbox * {
        animation-duration: .01ms !important;
        transition-duration: .01ms !important;
        scroll-behavior: auto !important;
    }

    .wolff-timeline__animate,
    .wolff-timeline__dot,
    .wolff-timeline__progress,
    .wolff-timeline__mobile-progress {
        opacity: 1;
        transform: none !important;
    }
}
