@media all {
  *[data-link-extends] {
    cursor: pointer;
  }
  ._rich-text * + h2,
  ._rich-text * + h3 {
    margin-top: 1em;
  }
  ._rich-text a,
  ._rich-text u {
    text-decoration: underline;
  }
  ._rich-text i {
    font-style: italic;
  }
  ._rich-text b {
    font-weight: 900;
  }
  ._close {
    line-height: 1;
    position: absolute;
    color: white;
  }
  ._close::after {
    content: "✕";
  }
  ._more {
    position: relative;
    margin-top: 2em;
    text-transform: uppercase;
    font-weight: 900;
    letter-spacing: 0.075em;
  }
  ._more:before {
    content: '';
    width: 1.75em;
    height: 0.25em;
    display: block;
    float: left;
    margin-top: 0.65em;
    margin-right: 1em;
    background-color: #AE90FA;
    color: inherit;
  }
  ._puce {
    position: relative;
  }
  ._puce:before {
    content: '';
    aspect-ratio: 0.83;
    position: absolute;
    left: 0px;
    top: 0.25em;
    background-color: #AE90FA;
    clip-path: polygon(32% 0%, 100% 0%, 40% 100%, 0% 49%);
  }
  ._vcenter {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  ._button {
    padding: 0.75em 2.75em;
    display: block;
    width: fit-content;
    border: 2px solid currentColor;
    border-radius: 1.5em;
  }
  ._tag {
    padding: 0.2em 1.5em;
    display: inline-block;
    margin-left: 1em;
    margin-bottom: 1em;
    border: 1px solid currentColor;
    border-radius: 1.5em;
    font-weight: 400;
  }
  ._checktag {
    padding-left: 0.75em;
    display: inline-block;
    position: relative;
    line-height: 1;
    font-weight: 900;
  }
  ._checktag input[type="checkbox"]:checked + label::before {
    content: '✕';
    position: absolute;
    top: 50%;
    margin-top: -0.3em;
    font-size: 0.6em;
    left: 0.1em;
  }
  ._checktag input[type="checkbox"]:not(:checked) + label {
    opacity: 0.4;
  }
  *:not(:empty) + ._empty {
    display: none;
  }
  ._infinite-scroll-trigger {
    position: relative;
    top: -50vh;
  }
  ._card {
    box-sizing: border-box;
    overflow: hidden;
  }
  ._card:not(:has(.image)) {
    background-color: #ECEEFF;
    color: #26325A;
  }
  ._card:not(:has(.image)) .cta {
    margin: 2em auto 0;
  }
  ._card:has(.image) .image {
    aspect-ratio: 0.9;
  }
  ._card:has(.image) .container {
    position: relative;
  }
  ._card:has(.image) .container .text {
    margin-top: 1em;
  }
  ._card:has(.image):has(.info) .container::after {
    content: '';
    aspect-ratio: 1;
    position: absolute;
    top: 2em;
    right: 2em;
    background-image: url('/img/interface/logos/main-logo_mini.svg');
  }
  ._card:has(.image) .info .type {
    margin-bottom: 1em;
  }
  ._card:has(.image) .info .type:not(:first-child) {
    margin-top: 2em;
  }
}
@media (min-width: 850px) {
  ._close {
    top: 0.75em;
    right: 0.75em;
    font-size: 35px;
    transition: margin-top cubic-bezier(0.2, 0.01, 0.45, 1) 0.4s;
  }
  ._close:hover {
    margin-top: -5px;
  }
  ._more:hover {
    color: #AE90FA;
  }
  ._puce {
    padding-left: clamp(38px, 2.8em, 63px);
  }
  ._puce:before {
    width: clamp(21px, 1.25em, 43px);
  }
  ._skew {
    width: 50%;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    overflow: hidden;
  }
  ._skew .shape {
    width: 100%;
    height: 400%;
    position: absolute;
    right: 0;
    transform: rotate(20deg);
    transform-origin: top right;
  }
  ._zoomable .zoom-container {
    overflow: hidden;
  }
  ._zoomable .zooms {
    transition: transform 1s cubic-bezier(0.2, 0.01, 0.45, 1);
  }
  ._zoomable:hover .zooms {
    transform: scale(1.05);
  }
  ._button:hover {
    color: white;
    background-color: #26325A;
    border-color: #26325A;
  }
  ._button:hover .picto {
    filter: brightness(20);
  }
  ._button.invert:hover {
    color: #26325A;
    background-color: white;
    border-color: white;
  }
  ._checktag:hover {
    color: #AE90FA;
  }
  ._card {
    border-radius: 20px;
  }
  ._card:not(:has(.image)) {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  ._card:not(:has(.image)) .title {
    margin-bottom: 1em;
  }
  ._card:has(.image) {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
  }
  ._card:has(.image) .container {
    background-color: #26325A;
    color: white;
  }
  ._card:has(.image):not(:hover) .info {
    display: none;
  }
  ._card:has(.image) .info {
    position: absolute;
    z-index: 1;
    inset: 0;
    background-color: #ECEEFF;
    color: #26325A;
  }
  ._card:has(.image) .info .type {
    line-height: 1.2;
  }
}
@media (min-width: 1400px) {
  ._footer {
    padding: 80px 0;
  }
  ._card:not(:has(.image)) {
    padding: 40px;
  }
  ._card:not(:has(.image)) .title {
    font-size: 55px;
  }
  ._card:not(:has(.image)) .title.small {
    font-size: 38px;
  }
  ._card:not(:has(.image)) .cta {
    font-size: 18px;
  }
  ._card:has(.image) .container {
    min-height: 200px;
    padding: 0 40px;
  }
  ._card:has(.image) .container .title {
    font-size: 30px;
  }
  ._card:has(.image) .container .text {
    font-size: 13px;
  }
  ._card:has(.image) .container::after {
    width: 27px;
  }
  ._card:has(.image) .info {
    padding: 60px 40px 0;
    font-size: 13px;
  }
  ._card:has(.image) .info .type {
    font-size: 30px;
  }
}
@media (min-width: 850px) and (max-width: 1399px) {
  ._footer {
    padding: 40px 0;
  }
  ._more {
    font-size: 11px;
  }
  ._card:not(:has(.image)) {
    padding: 40px;
  }
  ._card:not(:has(.image)) .title {
    font-size: 45px;
  }
  ._card:not(:has(.image)) .title.small {
    font-size: 28px;
  }
  ._card:has(.image) .container {
    min-height: 160px;
    padding: 0 20px;
  }
  ._card:has(.image) .container .title {
    font-size: 25px;
  }
  ._card:has(.image) .container .text {
    font-size: 13px;
  }
  ._card:has(.image) .container::after {
    width: 27px;
  }
  ._card:has(.image) .info {
    padding: 60px 40px 0;
    font-size: 13px;
  }
  ._card:has(.image) .info .type {
    font-size: 30px;
  }
}
@media (max-width: 849px) {
  ._close {
    top: 15px;
    right: 20px;
    font-size: 25px;
  }
  ._more {
    font-size: 10px;
  }
  ._puce {
    padding-left: clamp(26px, 2.8em, 37px);
  }
  ._puce:before {
    width: clamp(16px, 1.25em, 22px);
  }
  ._nav-button {
    width: 10px;
    height: 10px;
    display: inline-block;
    margin: 0 5px;
    border: 1px solid currentColor;
    border-radius: 100%;
    background-color: currentColor;
    color: #26325A;
  }
  ._footer {
    padding: 40px 0;
  }
  ._card {
    border-radius: 12px;
  }
  ._card:not(:has(.image)) {
    padding: 25px;
    aspect-ratio: 0.58;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  ._card:not(:has(.image)) .title {
    font-size: 34px;
  }
  ._card:not(:has(.image)) .title.small {
    font-size: 26px;
  }
  ._card:has(.image) {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
    background-color: #26325A;
    color: white;
  }
  ._card:has(.image) .container {
    padding: 35px 20px;
  }
  ._card:has(.image) .container .title {
    font-size: 18px;
  }
  ._card:has(.image) .container .text {
    font-size: 12px;
  }
  ._card:has(.image) .info {
    padding: 0 20px 35px;
  }
  ._card:has(.image) .info .type {
    font-size: 13px;
  }
}
