
@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works {
        padding-top: 30px;
        padding-bottom: 30px
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works {
        padding-top: 79px;
        padding-bottom: 60px
    }
}

.wp-block.how-it-works .mobile-image {
    display: block
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .mobile-image {
        max-width: 270px;
        margin-left: 30px;
        float: right;
        margin-top: 120px
    }
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .mobile-image {
        display: none
    }
    .wp-block.how-it-works .container {
        display: flex;
        position: relative
    }
}

.wp-block.how-it-works .lines-wrap {
    height: 64px;
    position: relative;
    width: 100%;
    left: 0px;
    max-width: 800px;
    right: 0px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 60px;
    display: none;
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .lines-wrap {
        display: block
    }
}

.wp-block.how-it-works .lines-wrap .line1 {
    height: 124px;
    width: 2px;
    background: #fff;
    display: block;
    position: absolute;
    top: -60px;
    transform: scaleY(0);
    transition: transform 250ms ease;
    transform-origin: bottom
}

.wp-block.how-it-works .lines-wrap .line2 {
    height: 2px;
    width: 800px;
    background: #fff;
    display: block;
    position: absolute;
    left: 0px;
    bottom: 0px;
    transform: scaleX(0);
    transition: transform 250ms ease 250ms;
    transform-origin: right
}

.wp-block.how-it-works .lines-wrap .line3 {
    height: 64px;
    width: 2px;
    background: #fff;
    display: block;
    position: absolute;
    right: 0px;
    bottom: 0px;
    transform: scaleY(0);
    transition: transform 250ms ease 500ms;
    transform-origin: top
}

.wp-block.how-it-works .lines-wrap.active .line1 {
    transform: scaleY(1);
    transform-origin: bottom;
    transition: transform 250ms ease 500ms
}

.wp-block.how-it-works .lines-wrap.active .line2 {
    transform: scaleX(1);
    transform-origin: right;
    transition: transform 250ms ease 250ms
}

.wp-block.how-it-works .lines-wrap.active .line3 {
    transform: scaleY(1);
    transform-origin: top;
    transition: transform 250ms ease
}

.wp-block.how-it-works .bottom-inner {
    display: flex;
    flex-direction: column;
    padding-top: 30px
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .bottom-inner {
        align-items: flex-start;
        flex-direction: row;
        padding-top: 0;
        align-items: start
    }
}

.wp-block.how-it-works .bottom-inner.active {
    align-items: start
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .bottom-inner.active {
        align-items: end
    }
}

.wp-block.how-it-works .rightside {
    align-self: flex-end;
    max-width: 890px;
    display: none;
    margin-right: -20px
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .rightside {
        display: flex
    }
}

@media only screen and (min-width: 1278px) {
    .wp-block.how-it-works .rightside {
        margin-right: calc(((100vw - 1248px) / 2) * -1)
    }
}

.wp-block.how-it-works .rightside .inner {
    position: relative;
    display: flex;
    align-self: flex-end
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .rightside .inner {
        margin-top: -120px;
        transform: translate(0px, -40px)
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .rightside .inner {
        margin-top: 0;
        transform: translate(0px, 0px)
    }
}

.wp-block.how-it-works .rightside .inner .initial-cross {
    cursor: pointer;
    z-index: 2;
    position: absolute
}

.wp-block.how-it-works .rightside .inner .cross-icon1 {
    right: 49.5%;
    top: 29.5%
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .rightside .inner .cross-icon1 {
        top: 27.5%
    }
}

@media only screen and (min-width: 1280px) {
    .wp-block.how-it-works .rightside .inner .cross-icon1 {
        top: 28.9%
    }
}

@media only screen and (min-width: 1500px) {
    .wp-block.how-it-works .rightside .inner .cross-icon1 {
        top: 30%;
        right: 50%
    }
}

.wp-block.how-it-works .rightside .inner .cross-icon2 {
    right: 49.5%;
    top: 42.5%
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .rightside .inner .cross-icon2 {
        top: 40.5%
    }
}

@media only screen and (min-width: 1280px) {
    .wp-block.how-it-works .rightside .inner .cross-icon2 {
        top: 41.5%
    }
}

@media only screen and (min-width: 1500px) {
    .wp-block.how-it-works .rightside .inner .cross-icon2 {
        top: 42%;
        right: 50%
    }
}

.wp-block.how-it-works .rightside .inner .cross-icon3 {
    right: 49.5%;
    top: 55.5%
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .rightside .inner .cross-icon3 {
        top: 53.5%
    }
}

@media only screen and (min-width: 1280px) {
    .wp-block.how-it-works .rightside .inner .cross-icon3 {
        top: 55.5%
    }
}

@media only screen and (min-width: 1500px) {
    .wp-block.how-it-works .rightside .inner .cross-icon3 {
        top: 55%;
        right: 50%
    }
}

.wp-block.how-it-works .rightside .inner .cross-icon4 {
    right: 49.5%;
    top: 68.5%
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .rightside .inner .cross-icon4 {
        top: 66.5%
    }
}

@media only screen and (min-width: 1280px) {
    .wp-block.how-it-works .rightside .inner .cross-icon4 {
        top: 67.5%
    }
}

@media only screen and (min-width: 1500px) {
    .wp-block.how-it-works .rightside .inner .cross-icon4 {
        top: 68%;
        right: 50%
    }
}

.wp-block.how-it-works .rightside .inner .image-wrap {
    position: absolute;
    left: 0;
    bottom: 0
}

.wp-block.how-it-works .rightside .inner .image-wrap .cross-icon {
    opacity: 0;
    transition: opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap .image-set {
    opacity: 0;
    transition: transform 500ms ease, opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap0 {
    height: auto;
    position: relative
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap0 .image-set {
    opacity: 1;
    transition: transform 500ms ease, opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap0 .initial-cross {
    opacity: 1;
    transition: opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap0.hide .image-set {
    opacity: 0;
    transition: transform 500ms ease, opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap0.hide .initial-cross.active {
    opacity: 0;
    transition: opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap.active .image-set {
    opacity: 1;
    transform: translate(0, 0px);
    transition: transform 500ms ease, opacity 500ms ease
}

.wp-block.how-it-works .rightside .inner .image-wrap.active .cross-icon {
    opacity: 1;
    transition: opacity 500ms ease 200ms
}

.wp-block.how-it-works .rightside .inner .image-wrap .cross-icon {
    transform: rotate(45deg);
    cursor: pointer;
    position: absolute;
    z-index: 1
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap1 .cross-icon {
    left: -25px;
    top: 29%
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap2 .cross-icon {
    left: -25px;
    top: 41%
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap3 .cross-icon {
    left: -25px;
    top: 54%
}

.wp-block.how-it-works .rightside .inner .image-wrap.image-wrap4 .cross-icon {
    left: -25px;
    top: 67%
}

.wp-block.how-it-works .leftside-top {
    width: 100%;
    max-width: 570px
}

.wp-block.how-it-works .leftside-bottom {
    width: 100%;
    max-width: 570px
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .leftside-bottom {
        margin-right: 20px
    }
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .leftside-bottom {
        margin-top: 37px;
        min-height: 419px
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .leftside-bottom {
        min-height: 513px;
        margin-top: 67px
    }
}

@media only screen and (min-width: 1900px) {
    .wp-block.how-it-works .leftside-bottom {
        min-height: 583px
    }
}

.wp-block.how-it-works .leftside-bottom.active {
    align-self: flex-end
}

.wp-block.how-it-works .leftside-bottom .initial {
    overflow: hidden
}

.wp-block.how-it-works .leftside-bottom .initial.hide {
    animation-name: slideLeftFade;
    animation-duration: 0.5s;
    animation-fill-mode: forwards
}

.wp-block.how-it-works .leftside-bottom .coloured-box {
    overflow: hidden;
    border-bottom: solid 1px #0a2e30
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .leftside-bottom .coloured-box {
        opacity: 0;
        height: 0;
        border-bottom: solid 0 #0a2e30
    }
}

.wp-block.how-it-works .leftside-bottom .coloured-box.active {
    animation-name: slideLeftFade;
    animation-duration: 0.5s;
    animation-direction: reverse;
    animation-fill-mode: forwards;
    animation-delay: 0.2s
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .leftside-bottom .coloured-box.active {
        animation-delay: 0.2s
    }
}

.wp-block.how-it-works p.pre-title {
    font-weight: 700;
    font-size: 20px;
    line-height: 30px;
    font-family: "grotesque_bold";
    color: #f7ebd6;
    margin-bottom: 25px
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works p.pre-title {
        font-size: 25px;
        line-height: 30px
    }
}

.wp-block.how-it-works .title {
    font-style: normal !important;
    font-family: "grotesque_extrabold" !important;
    color: #ffb500 !important;
    margin-bottom: 26px !important;
    font-size: 50px !important;
    line-height: 52px !important;
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .title {
        font-size: 55px !important;
        line-height: 60px !important;
        margin-bottom: 15px !important;
    }
}

@media only screen and (min-width: 768px) and (min-width: 1024px) {
    .wp-block.how-it-works .title {
        margin-bottom: 15px !important;
    }
}

@media only screen and (min-width: 768px) and (min-width: 1600px) {
    .wp-block.how-it-works .title {
        font-size: 65px !important;
        line-height: 70px !important;
        margin-bottom: 15px !important;
    }
}

.wp-block.how-it-works .title span {
    color: transparent !important;
    background: url(/wp-content/themes/floe/blocks/how-it-works/images/floe-logo.svg) no-repeat center center/contain !important;
    width: 108.18px !important;
    height: 43.66px !important;
    display: inline-block !important;
    transform: translate(0px, 3px) !important;
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .title span {
        width: 124.18px !important;
        height: 41.66px !important;
        transform: translate(0px, 8px) !important;
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .title span {
        width: 144.18px !important;
        height: 51.66px !important;
        transform: translate(0px, 8px) !important;
    }
}

.wp-block.how-it-works .sub-title {
    font-style: normal !important;
    font-weight: 300 !important;
    font-size: 25px !important;
    line-height: 30px !important;
    color: #f7ebd6 !important;
    font-family: "grotesque_light" !important;
    margin-bottom: 0 !important;
    margin-bottom: 30px !important;
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .sub-title {
        font-size: 24px !important;
        line-height: 34px !important;
        margin-bottom: 0 !important;
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .sub-title {
        font-size: 42px !important;
        line-height: 43px !important;
        margin-bottom: 0 !important;
    }
}

.wp-block.how-it-works .line-side {
    margin-bottom: 20px
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .line-side {
        max-width: 420px
    }
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .line-side {
        margin-left: 0;
        padding-left: 30px;
        border-left: solid 3px #fff
    }
}

@media only screen and (min-width: 1280px) {
    .wp-block.how-it-works .line-side {
        margin-left: 43px;
        padding-left: 47px
    }
}

.wp-block.how-it-works .line-side .desc {
    font-style: normal;
    font-weight: 300;
    font-size: 25px;
    line-height: 30px;
    color: #fff;
    margin-bottom: 40px;
    display: none;
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .line-side .desc {
        display: block;
        font-size: 22px;
        line-height: 28px
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .line-side .desc {
        font-size: 29px;
        line-height: 34px
    }
}

.wp-block.how-it-works .line-side .yellow-link {
    color: #ffb500;
    font-weight: 300;
    font-size: 29px;
    line-height: 34px;
    font-family: "grotesque_bold";
    display: none;
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .line-side .yellow-link {
        display: block;
        font-size: 22px;
        line-height: 28px
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .line-side .yellow-link {
        font-size: 29px;
        line-height: 34px
    }
}

.wp-block.how-it-works .coloured-box {
    display: flex;
    overflow: hidden;
    position: relative;
    max-width: 416px
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box {
        border-radius: 25px
    }
}

.wp-block.how-it-works .coloured-box.box-1 .rightside-text {
    border-radius: 0 25px 0 0
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box.box-1 .rightside-text {
        border-radius: 0
    }
}

.wp-block.how-it-works .coloured-box.box-4 .rightside-text {
    border-radius: 0 0 25px 0
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box.box-4 .rightside-text {
        border-radius: 0
    }
}

.wp-block.how-it-works .coloured-box .close-box {
    position: absolute;
    right: 35px;
    top: 35px;
    cursor: pointer;
    display: none;
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .close-box {
        display: block
    }
}

.wp-block.how-it-works .coloured-box .leftside-colour {
    width: 8px;
    flex-shrink: 0
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .coloured-box .leftside-colour {
        width: 24px
    }
}

.wp-block.how-it-works .coloured-box .rightside-text {
    background: #fff;
    width: 100%
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .rightside-text {
        padding-left: 26px;
        padding-top: 50px;
        display: block;
        padding-right: 24px;
        padding-bottom: 50px
    }
}

.wp-block.how-it-works .coloured-box .rightside-text .accordion-top {
    padding-left: 20px;
    padding-top: 19px;
    padding-right: 22px;
    padding-bottom: 19px;
    display: flex;
    align-items: center;
    justify-content: space-between
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .rightside-text .accordion-top {
        padding: 0
    }
}

.wp-block.how-it-works .coloured-box .rightside-text .accordion-top.active .accordion-close .line2 {
    transform-origin: center;
    transform: translate(9px, -3px) rotate(90deg);
    transition: transform 400ms ease
}

.wp-block.how-it-works .coloured-box .rightside-text .accordion-top.active + .bottom-text {
    display: block
}

.wp-block.how-it-works .coloured-box .rightside-text .accordion-top .accordion-close {
    display: block;
    width: 21px;
    height: 21px;
    position: relative;
    margin-left: 21px
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .rightside-text .accordion-top .accordion-close {
        display: none
    }
}

.wp-block.how-it-works .coloured-box .rightside-text .accordion-top .accordion-close .line1 {
    width: 21px;
    height: 3px;
    background: #000;
    display: block;
    transform: translate(0px, 9px)
}

.wp-block.how-it-works .coloured-box .rightside-text .accordion-top .accordion-close .line2 {
    width: 3px;
    height: 21px;
    background: #000;
    display: block;
    transform: translate(9px, -3px) rotate(0deg);
    transition: transform 400ms ease;
    transform-origin: center
}

.wp-block.how-it-works .coloured-box .rightside-text .bottom-text {
    display: none;
    padding-left: 20px;
    padding-top: 19px;
    padding-right: 22px;
    padding-bottom: 19px
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .rightside-text .bottom-text {
        display: block;
        padding: 0
    }
}

.wp-block.how-it-works .coloured-box .rightside-text .title-small {
    text-transform: uppercase !important;
    color: #0a2e30 !important;
    font-size: 14px !important;
    line-height: 20px !important;
    font-family: "grotesque_bold" !important;
    margin-bottom: 0 !important;
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .rightside-text .title-small {
        margin-bottom: 20px !important;
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .coloured-box .rightside-text .title-small {
        margin-bottom: 40px !important;
    }
}

.wp-block.how-it-works .coloured-box .rightside-text .title-medium {
    color: #0a2e30 !important;
    font-weight: 300 !important;
    font-size: 20px !important;
    line-height: 24px !important;
    font-family: "grotesque_regular" !important;
    margin-bottom: 28px !important;
}

@media only screen and (min-width: 1024px) {
    .wp-block.how-it-works .coloured-box .rightside-text .title-medium {
        font-size: 20px !important;
        line-height: 24px !important;
        margin-bottom: 18px !important;
    }
}

@media only screen and (min-width: 1600px) {
    .wp-block.how-it-works .coloured-box .rightside-text .title-medium {
        font-size: 30px !important;
        line-height: 35px !important;
        margin-bottom: 28px !important;
    }
}

.wp-block.how-it-works .coloured-box .rightside-text .desc-set {
    font-weight: 400 !important;
    font-size: 16px !important;
    line-height: 21px !important;
    color: #0a2e30 !important;
}

@media only screen and (min-width: 768px) {
    .wp-block.how-it-works .coloured-box .rightside-text .desc-set {
        font-size: 18px !important;
        line-height: 23px !important;
    }
}

@keyframes slideLeftFade {
    0% {
        opacity: 1;
        height: auto
    }
    25% {
        opacity: 0
    }
    50% {
        opacity: 0;
        height: auto
    }
    100% {
        height: 0;
        opacity: 0
    }
}

