@keyframes checked {
    to {
        stroke-dashoffset: 0;
    }
}
  
.checklist-checkbox {
    display: block;
    min-width: 30px;
    height: 30px;
    border: 2px solid rgb(var(--color-foreground));
    border-radius: 2px;
}

.assessment-checklist label {
    font-weight: var(--type-medium);
    display: flex;
    gap: 24px;
    align-items: center;
    cursor: pointer;
}

.assessment-checklist {
    padding-top: 44px;
    padding-bottom: 44px;
}

@media screen and (min-width: 768px) {
    .assessment-checklist {
        padding-top: 56px;
        padding-bottom: 56px;
    }
}

.assessment-checklist input[type=checkbox] {
    /* https://snook.ca/archives/html_and_css/hiding-content-for-accessibility */
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
    clip: rect(1px 1px 1px 1px);
    /* IE6, IE7 */
    clip: rect(1px, 1px, 1px, 1px);
}

.assessment-checklist .checklist-checkbox svg {
    vertical-align: middle;
}

.assessment-checklist input[type=checkbox]:checked + label .checklist-checkbox {
    /* background-image: url(checkbox.svg); */
    background-color: rgb(var(--color-medium-green));
    /* background-size: cover; */
}

.assessment-checklist .checklist-checkbox  path {
    stroke-dasharray: 400;
    stroke-dashoffset: 400;
  }

.assessment-checklist input[type=checkbox]:checked + label .checklist-checkbox  path {
    animation: checked 2s ease forwards;
}

.assessment-checklist {
    padding-left: 24px;
    padding-right: 24px;
    border-radius: 32px;
    position: relative;
}

.assessment-checklist ul {
    margin-top: 16px;
}

.assessment-checklist ul:first-of-type {
    margin-top: 24px;
}

.assessment-checklist ul li + li {
    margin-top: 16px;
}

@media screen and (min-width: 750px) {
    .assessment-checklist ul {
        margin-top: 40px;
    }

    .assessment-checklist ul li + li {
        margin-top: 24px;
    }

    .assessment-checklist {
        padding-left: 40px;
        padding-right: 40px;
    }
}

@media screen and (min-width: 1024px) {
    .assessment-checklist {
        padding-top: 80px;
        padding-bottom: 80px;
        padding-left: 90px;
        padding-right: 90px;
        border-radius: 56px;
    }
}

.assessment-checklist__content {
    position: relative;
    z-index: 2;
}

.flowers {
    width: 67%;
    max-width: 234px;
    height: 0;
    padding-bottom: 70%;
    background-image: url(flowers-mobile.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    top: 0;
    right: -72px;
    transform: translate(0, -44%)
}

@media screen and (min-width: 768px) {
    .flowers {
        width: 52%;
        max-width: 290px;
        height: 0;
        padding-bottom: 68%;
        background-image: url(flowers.svg);
        top: 0;
        right: -36px;
        transform: translate(0, -50%)
    }
    
}