.actualities-list--sticky-background {
    width: 100%;
    height: 100dvh;
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    left: 0
}

.actualities-list--sticky-background .sticky-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    opacity: .25
}

.actualities-list--sticky-elements {
    width: 100%;
    display: none;
    justify-content: space-between;
    padding: 0 24px;
    position: absolute;
    bottom: 44px;
    left: 0;
    opacity: .8
}

@media screen and (min-width: 768px) {
    .actualities-list--sticky-elements {
        display: flex;
        justify-content: flex-start;
        gap: clamp(16px, 5.56vw, 80px);
        align-items: center;
        bottom: 24px
    }
}

@media screen and (min-width: 992px) {
    .actualities-list--sticky-elements {
        padding: 0 56px
    }
}

.actualities-list--sticky-elements p {
    font-size: 0.625rem;
    font-style: normal;
    font-weight: 300;
    line-height: 170%;
    letter-spacing: 0.1px
}

@media screen and (min-width: 768px) {
    .actualities-list--sticky-elements p {
        font-size: 0.75rem
    }
}

.actualities-list--title {
    max-width: 1140px;
    padding-inline: 24px;
    margin-inline: auto;
    z-index: 99;
    position: -webkit-sticky;
    position: sticky;
    top: 160px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px
}

@media screen and (min-width: 604px) {
    .actualities-list--title {
        align-items: flex-start
    }
}

@media screen and (min-width: 768px) {
    .actualities-list--title {
        top: clamp(160px, 15.56vw, 224px)
    }
}

@media screen and (min-width: 1188px) {
    .actualities-list--title {
        padding-inline: 0
    }
}

.actualities-list--title h1 {
    text-align: center;
    font-size: 40px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%
}

@media screen and (min-width: 604px) {
    .actualities-list--title h1 {
        max-width: 604px;
        text-align: left
    }
}

@media screen and (min-width: 992px) {
    .actualities-list--title h1 {
        font-size: 4.5rem;
        line-height: 84px
    }
}

.actualities-list--title p {
    font-size: 0.75rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.2px;
    text-transform: uppercase
}

@media screen and (min-width: 992px) {
    .actualities-list--title p {
        font-size: 0.875rem;
        letter-spacing: 1.4px
    }
}

.actualities-list--title .animate-txt {
    letter-spacing: 2px
}

.actualities-list--title .cursor {
    display: inline-block;
    width: 32px;
    border-bottom: 3px solid white;
    margin-left: 2px
}

.actualities-list--container {
    max-width: 1140px;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    padding-inline: 24px;
    padding-top: 120px;
    padding-bottom: 60px;
    overflow-x: clip
}

@media screen and (min-width: 768px) {
    .actualities-list--container {
        padding-bottom: 120px;
        overflow-x: unset
    }
}

@media screen and (min-width: 992px) {
    .actualities-list--container {
        padding-top: 0;
        padding-bottom: 120px
    }
}

.actualities-list--container>div:not(:last-child) {
    margin-bottom: 32px
}

@media screen and (min-width: 992px) {
    .actualities-list--container>div:not(:last-child) {
        margin-bottom: 64px
    }
}

.actualities-list--container>div:nth-child(even) {
    margin-left: auto
}

@media screen and (min-width: 1188px) {
    .actualities-list--container {
        padding-inline: 0
    }

    .actualities-list--container>div:nth-child(4n-1) {
        transform: translateX(80px)
    }
}

.actualities-list--container .load-more {
    cursor: pointer;
    z-index: 9;
    margin-inline: auto
}

.actualities-list .actuality-card-container {
    position: relative;
    max-width: 500px
}

.actualities-list .actuality-card-container::before,
.actualities-list .actuality-card-container::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    -webkit-filter: drop-shadow(0px 0px 8px #44B0FF);
    filter: drop-shadow(0px 0px 8px #44B0FF);
    transition: all .4s ease
}

.actualities-list .actuality-card-container::before {
    border-bottom: 3px solid #44B0FF;
    border-left: 3px solid #44B0FF;
    left: -14px;
    bottom: -14px
}

.actualities-list .actuality-card-container::after {
    border-right: 3px solid #44B0FF;
    border-top: 3px solid #44B0FF;
    right: -14px;
    top: -14px
}

.actualities-list .actuality-card-wrapper {
    display: flex;
    -webkit-clip-path: polygon(42px 0, 100% 0, 100% calc(100% - 42px), calc(100% - 42px) 100%, 0% 100%, 0 42px);
    clip-path: polygon(42px 0, 100% 0, 100% calc(100% - 42px), calc(100% - 42px) 100%, 0% 100%, 0 42px);
    max-width: 500px
}

.actualities-list .actuality-card {
    --s: 20px;
    --b: 4px;
    --a: 180deg;
    --p: 10px;
    max-width: 500px;
    display: inline-block;
    box-sizing: border-box;
    position: relative
}

.actualities-list .actuality-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: #44B0FF;
    padding: var(--b);
    --g: #000 var(--a), #0000 0;
    -webkit-mask: conic-gradient(from calc(var(--a)/-2 - 45deg) at top var(--s) left var(--s), var(--g)) 0 0/50.1% 50.1% no-repeat content-box, conic-gradient(from calc(var(--a)/-2 - 45deg) at top var(--s) left var(--s), var(--g)) 0 0/50.1% 50.1% no-repeat, conic-gradient(from calc(var(--a)/-2 + 135deg) at bottom var(--s) right var(--s), var(--g)) 100% 100%/50.1% 50.1% no-repeat content-box, conic-gradient(from calc(var(--a)/-2 + 135deg) at bottom var(--s) right var(--s), var(--g)) 100% 100%/50.1% 50.1% no-repeat, conic-gradient(from 90deg at var(--b) var(--b), rgba(0, 0, 0, 0) 90deg, #000 0) 0 0/calc(100% - var(--b)) calc(100% - var(--b));
    -webkit-mask-composite: xor;
    mask-composite: exclude
}

.actualities-list .actuality-card:hover .actuality-card--inner::before {
    left: -18px;
    bottom: -18px
}

.actualities-list .actuality-card:hover .actuality-card--inner::after {
    right: -18px;
    top: -18px
}

.actualities-list .actuality-card--overlay {
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: -1;
    left: 0;
    top: 0;
    opacity: .85;
    background: #113550;
    -webkit-clip-path: polygon(40px 0, calc(100% - 40px) 0, 100% 0px, 100% calc(100% - 40px), calc(100% - 40px) 100%, 40px 100%, 0 calc(100% - 0px), 0 40px);
    clip-path: polygon(40px 0, calc(100% - 40px) 0, 100% 0px, 100% calc(100% - 40px), calc(100% - 40px) 100%, 40px 100%, 0 calc(100% - 0px), 0 40px)
}

.actualities-list .actuality-card--inner {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative
}

@media screen and (min-width: 992px) {
    .actualities-list .actuality-card--inner {
        flex-direction: row;
        gap: 24px;
        align-items: stretch
    }
}

.actualities-list .actuality-card--inner>a {
    display: flex;
    width: 100%;
    position: relative;
    padding: 4px
}

@media screen and (min-width: 992px) {
    .actualities-list .actuality-card--inner>a {
        max-width: 158px
    }
}

.actualities-list .actuality-card--inner>a img {
    height: 200px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -webkit-clip-path: polygon(40px 0, 100% 0, 100% 100%, 0 100%, 0 40px);
    clip-path: polygon(40px 0, 100% 0, 100% 100%, 0 100%, 0 40px)
}

@media screen and (min-width: 992px) {
    .actualities-list .actuality-card--inner>a img {
        height: unset
    }
}

.actualities-list .actuality-card--inner>div {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px;
    padding-top: 0
}

@media screen and (min-width: 992px) {
    .actualities-list .actuality-card--inner>div {
        padding: 24px 24px 24px 0
    }
}

.actualities-list .actuality-card--inner>div h3 {
    font-size: 1.375rem;
    font-style: normal;
    font-weight: 700;
    line-height: 120%
}

@media screen and (min-width: 992px) {
    .actualities-list .actuality-card--inner>div h3 {
        font-size: 1.75rem
    }
}

.actualities-list .actuality-card--inner>div p {
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.actualities-list .bottom-button {
    background: #333E85;
    cursor: pointer;
    -webkit-mask: url("../images/button-bottom.svg") no-repeat center;
    mask: url("../images/button-bottom.svg") no-repeat center;
    width: 112px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    position: absolute;
    left: calc(50% - 56px);
    bottom: 0;
    position: -webkit-sticky
}

.actualities-list .bottom-button::before {
    content: '';
    background: white;
    width: 16px;
    height: 16px;
    -webkit-mask: url("../images/chevron-down.svg") no-repeat center;
    mask: url("../images/chevron-down.svg") no-repeat center;
    -webkit-mask-size: contain;
    mask-size: contain
}

.breaking-card {
    position: relative;
    padding-bottom: 24px
}

@media screen and (min-width: 560px) {
    .breaking-card {
        max-width: 400px
    }
}

@media screen and (min-width: 992px) {
    .breaking-card {
        display: flex;
        flex-direction: column;
        gap: 24px;
        padding-bottom: 32px
    }
}

@media screen and (min-width: 1188px) {
    .breaking-card {
        margin-left: 104px
    }
}

.breaking-card::after {
    content: '';
    height: 86px;
    width: calc(100% + 104px);
    position: absolute;
    right: 0;
    bottom: 0;
    background: url("../images/breaking-line.svg") no-repeat center;
    background-size: cover;
    background-position: bottom;
    pointer-events: none
}

.breaking-card p {
    font-size: 1.125rem;
    font-style: normal;
    font-weight: 500;
    line-height: 180%;
    letter-spacing: 0.18px
}

.breaking-card div {
    display: flex;
    gap: 24px;
    align-items: center
}

.breaking-card span {
    font-family: var(--visby);
    font-size: 1.25rem;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1px
}

.breaking-card .date {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.8px;
    display: flex;
    gap: 24px;
    align-items: center
}

.breaking-card .date::before {
    content: '';
    width: 30px;
    height: 1px;
    background: white
}

.audio-card {
    display: flex;
    gap: 32px;
    align-items: flex-start;
    width: 100%;
    position: relative
}

@media screen and (min-width: 636px) {
    .audio-card {
        max-width: 636px
    }
}

.audio-card--content {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: relative
}

.audio-card--content::before {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    -webkit-filter: drop-shadow(0px 0px 8px #44B0FF);
    filter: drop-shadow(0px 0px 8px #44B0FF);
    border-top: 3px solid #44B0FF;
    border-left: 3px solid #44B0FF;
    left: -16px;
    top: -16px
}

.audio-card .uptitle {
    font-size: 1rem;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.8px
}

.audio-card h3 {
    font-size: 1.375rem;
    font-style: normal;
    font-weight: 700;
    line-height: 120%
}

@media screen and (min-width: 992px) {
    .audio-card h3 {
        font-size: 1.75rem
    }
}

.audio-card img {
    height: 210px;
    -o-object-fit: contain;
    object-fit: contain;
    position: absolute;
    top: calc(100% - 100px);
    right: -56px
}

@media screen and (min-width: 768px) {
    .audio-card img {
        position: unset
    }
}

.video-card {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
    z-index: 9
}

@media screen and (min-width: 450px) {
    .video-card {
        max-width: 450px
    }
}

.video-card--illus {
    -webkit-clip-path: polygon(42px 0, calc(100% - 42px) 0, 100% 42px, 100% calc(100% - 42px), calc(100% - 42px) 100%, 42px 100%, 0% calc(100% - 42px), 0 42px);
    clip-path: polygon(42px 0, calc(100% - 42px) 0, 100% 42px, 100% calc(100% - 42px), calc(100% - 42px) 100%, 42px 100%, 0% calc(100% - 42px), 0 42px);
    position: relative
}

.video-card--illus::before {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: linear-gradient(0deg, rgba(17, 53, 80, 0.6) 0%, rgba(17, 53, 80, 0.6) 100%)
}

.video-card--illus img {
    height: 200px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

@media screen and (min-width: 768px) {
    .video-card--illus img {
        height: 290px
    }
}

.video-card--link {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px
}

.video-card--link:hover span {
    scale: 1.05
}

.video-card--link span {
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0px 0px 8px 1.5px #44B0FF;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    background: #44B0FF;
    transition: all .3s ease
}

.video-card--link span::before {
    content: '';
    -webkit-mask: url("../images/icon-play.svg") no-repeat center;
    mask: url("../images/icon-play.svg") no-repeat center;
    -webkit-mask-size: contain;
    mask-size: contain;
    background: #080B21;
    height: 18px;
    width: 18px
}

.video-card--link p {
    font-size: 0.875rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.4px;
    text-transform: uppercase
}

.video-card h3 {
    font-size: 1.375rem;
    font-style: normal;
    font-weight: 700;
    line-height: 120%
}

.quote-card {
    font-family: var(--visby);
    margin-top: 72px;
    text-align: center;
    max-width: 750px;
    margin-inline: auto;
    padding: 16px;
    position: relative
}

.quote-card p {
    font-size: 1.75rem;
    font-style: normal;
    font-weight: 700;
    line-height: 140%;
    letter-spacing: 1.4px
}

@media screen and (min-width: 992px) {
    .quote-card p {
        font-size: 2.5rem;
        line-height: 120%;
        letter-spacing: 0.8px
    }
}

.quote-card .informations {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 24px
}

@media screen and (min-width: 768px) {
    .quote-card .informations {
        flex-direction: row;
        gap: 24px;
        margin-top: 32px
    }
}

.quote-card .author {
    font-size: 1.25rem;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1px
}

.quote-card .context {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px
}

@media screen and (min-width: 768px) {
    .quote-card .context {
        flex-direction: row;
        gap: 24px
    }
}

.quote-card .context::before {
    content: '';
    height: 1px;
    width: 30px;
    background: white
}

.quote-card .corner {
    width: 100%;
    position: absolute;
    left: 0
}

.quote-card .corner::before,
.quote-card .corner::after {
    content: '';
    width: 40px;
    height: 40px;
    background: url("../images/corner-quote-card.svg") no-repeat center;
    background-size: cover;
    -webkit-filter: drop-shadow(0px 0px 8px #44B0FF);
    filter: drop-shadow(0px 0px 8px #44B0FF);
    position: absolute
}

.quote-card .corner::before {
    left: 0
}

.quote-card .corner::after {
    right: 0
}

.quote-card .corner-top {
    top: 0
}

.quote-card .corner-top::before,
.quote-card .corner-top::after {
    top: 0
}

.quote-card .corner-top::after {
    rotate: .25turn
}

.quote-card .corner-bottom {
    bottom: 0
}

.quote-card .corner-bottom::before,
.quote-card .corner-bottom::after {
    bottom: 0
}

.quote-card .corner-bottom::after {
    rotate: .5turn
}

.quote-card .corner-bottom::before {
    rotate: -.25turn
}