
 .further-reading__document {
    max-width: 90vw;
    width: 100%;
    border: 0;
    box-shadow: 0 1rem 1rem rgba(0, 0, 0, 0.1);
    border-radius: 0.5rem;

	&::backdrop {
		background-color: rgba(0, 0, 0, 0.5);
	}
}

.picnic-table {
    /* background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI3IiBoZWlnaHQ9IjciIGZpbGw9Im5vbmUiPjxwYXRoIGZpbGw9IiNEOUQ5RDkiIGZpbGwtb3BhY2l0eT0iLjAxIiBkPSJNMCAwaDd2N0gweiIgb3BhY2l0eT0iLjAxIi8+PHBhdGggZmlsbD0iI0ZBNTk0MSIgZD0iTTAgMGgydjJIMHoiLz48L3N2Zz4='); */
    background-size: 7px 7px;
    background-repeat: repeat;
    padding: 0;
    @media (min-width: 64em) { 
        padding: var(--spacing-s) var(--spacing-s); 
    }
    max-width: 42rem;
    border-radius: 1rem;
    transition: all 1s linear;

    &.party {
        width: 100%;
        max-width: 100%;
        position: relative;
        padding-top: 1rem;
        padding-bottom: 1rem;
        
        .toast > * {
            z-index: 1;
        }

        @media (min-width: 768px) {
            padding-top: 1rem;
            padding-bottom: 1rem;
        }

        .further-reading__image {
            position: absolute;
            z-index: 0;
            width: 10rem;
            height: 12rem;
            aspect-ratio: 3/2;
            object-fit: cover;
            transform-origin: 100% -50%;
            top: 10%;
            zoom: 1.5;
            border-radius: 0.5rem;
            transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            filter: brightness(1) contrast(1) saturate(1);
            
            /* CSS variables for floating animation */
            --float-x: 0px;
            --float-y: -50px;
            --float-rotation: 0deg;

            @media (min-width: 768px) {
                top: 50%;
                zoom: 1.7;
            }
        }

        .further-reading__image--left{
            left: 25%;
            transform: rotate(calc(-10deg + var(--float-rotation))) translate(calc(-65% + var(--float-x)), calc(-58% + var(--float-y)));
            @media (min-width: 768px) {
                 left: 15%;
                 transform: rotate(calc(-10deg + var(--float-rotation))) translate(calc(-50% + var(--float-x)), calc(-60% + var(--float-y)));
             }
        }
        
        .further-reading__image--right{
            right: 25%;
            transform: rotate(calc(7deg + var(--float-rotation))) translate(calc(50% + var(--float-x)), calc(-60% + var(--float-y)));
            @media (min-width: 768px) {
                 right: 15%;
                 transform: rotate(calc(10deg + var(--float-rotation))) translate(calc(50% + var(--float-x)), calc(-60% + var(--float-y)));
             }
        }
    }

    /* Floating away animation on hover */
    &.party:hover .further-reading__image {
        transition: all 1.2s cubic-bezier(0.23, 1, 0.32, 1);
        filter: brightness(1.1) contrast(1.05) saturate(1.1);
    }

    &.party:hover .further-reading__image--left {
        transform: rotate(calc(-15deg + var(--float-rotation))) translate(calc(-45% + var(--float-x)), calc(-75% + var(--float-y))) scale(0.92);
        @media (min-width: 768px) {
            transform: rotate(calc(-12deg + var(--float-rotation))) translate(calc(-50% + var(--float-x)), calc(-55% + var(--float-y))) scale(0.90);
        }
    }

    &.party:hover .further-reading__image--right {
        transform: rotate(calc(12deg + var(--float-rotation))) translate(calc(50% + var(--float-x)), calc(-75% + var(--float-y))) scale(0.92);
        @media (min-width: 768px) {
            transform: rotate(calc(15deg + var(--float-rotation))) translate(calc(50% + var(--float-x)), calc(-45% + var(--float-y))) scale(0.90);
        }
    }

    /* 140px = 8.75rem */
    h2 {
        font-size: clamp(2rem, 6vw, 8.75rem); /* 140px = 8.75rem */
        max-width: 60%;
        text-align: center;
        @media (max-width: 900px) { max-width: 80%; }
        @media (max-width: 600px) { 
            max-width: 90%;
            margin-bottom: 0.5rem !important; 
        }
    }

    p {
        padding: 0 !important;
        margin-bottom: 0.5rem !important;
    }
}

.further-reading__title {
    text-wrap: balance;
}
.further-reading__title h2,
.further-reading__paragraph {
    max-width: 40rem;
    margin-bottom: 1rem;
}

.further-reading__link {
    font-size: 1.5rem;
    line-height: 90%;
}

.huge-text {
    font-size: clamp(2rem, 7vw, var(--heading-sizes--l));
}


.reading-mode .toast {
    z-index: 1;

    .further-reading__title {
        max-width: 24ch;
        text-decoration: underline;
        text-underline-offset: 0.1em;
        line-height: 1;

        &::after {
            content: "↗";
        }
    }
}

.jam-spread {
    background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCAzNzEgMjk5Ij48cGF0aCBmaWxsPSIjRkE1OTQxIiBkPSJNMzQxIDBhMzAgMzAgMCAwIDEgMjYgNDVjMyA0IDQgOSA0IDE1IDAgNS0xIDEwLTQgMTUgMyA0IDQgOSA0IDE0djFjMCA1LTEgMTAtNCAxNCAzIDUgNCAxMCA0IDE1djFjMCA1LTEgMTAtNCAxNGEzMCAzMCAwIDAgMSAwIDMwYzMgNCA0IDkgNCAxNXYxYzAgNS0xIDEwLTQgMTQgMyA0IDQgOSA0IDE0djFjMCA2LTEgMTEtNCAxNSAzIDQgNCA5IDQgMTR2MWMwIDYtMSAxMS00IDE1YTMwIDMwIDAgMCAxLTQzIDM5IDI5IDI5IDAgMCAxLTM2IDAgMjkgMjkgMCAwIDEtMzUgMCAyOSAyOSAwIDAgMS0zNSAwIDI5IDI5IDAgMCAxLTMzIDIgMjkgMjkgMCAwIDEtMzItMiAyOSAyOSAwIDAgMS0zNSAwIDI5IDI5IDAgMCAxLTM1IDAgMjkgMjkgMCAwIDEtMzYgMGMtNSA0LTExIDYtMTcgNmEzMCAzMCAwIDAgMS0yNi00NWMtMy00LTQtOS00LTE1di0xYzAtNSAxLTEwIDQtMTQtMy00LTQtOS00LTE1di0xYzAtNSAxLTEwIDQtMTQtMy00LTQtOS00LTE0di0xYzAtNiAxLTExIDQtMTUtMy00LTQtOS00LTE1IDAtNSAxLTEwIDQtMTUtMy00LTQtOS00LTE0di0xYzAtNSAxLTEwIDQtMTUtMy00LTQtOS00LTE0di0xYzAtNSAxLTEwIDQtMTRhMzAgMzAgMCAwIDEgMC0zMEEzMCAzMCAwIDAgMSA0NyA2YTMwIDMwIDAgMCAxIDM2IDAgMzAgMzAgMCAwIDEgMzUgMCAzMCAzMCAwIDAgMSAzNSAwIDMwIDMwIDAgMCAxIDMyLTIgMzAgMzAgMCAwIDEgMzMgMiAzMCAzMCAwIDAgMSAzNSAwIDMwIDMwIDAgMCAxIDM1IDAgMzAgMzAgMCAwIDEgMzYgMGM1LTQgMTEtNiAxNy02WiIvPjwvc3ZnPg==');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    padding: calc(var(--spacing-m)* 2) var(--spacing-m);
    z-index: 1;
    position: relative;
    @media (min-width: 728px) {
        background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCAzNzEgMjk5Ij48cGF0aCBmaWxsPSIjRkE1OTQxIiBkPSJNMzQxIDBhMzAgMzAgMCAwIDEgMjYgNDVjMyA0IDQgOSA0IDE1IDAgNS0xIDEwLTQgMTUgMyA0IDQgOSA0IDE0djFjMCA1LTEgMTAtNCAxNCAzIDUgNCAxMCA0IDE1djFjMCA1LTEgMTAtNCAxNGEzMCAzMCAwIDAgMSAwIDMwYzMgNCA0IDkgNCAxNXYxYzAgNS0xIDEwLTQgMTQgMyA0IDQgOSA0IDE0djFjMCA2LTEgMTEtNCAxNSAzIDQgNCA5IDQgMTR2MWMwIDYtMSAxMS00IDE1YTMwIDMwIDAgMCAxLTQzIDM5IDI5IDI5IDAgMCAxLTM2IDAgMjkgMjkgMCAwIDEtMzUgMCAyOSAyOSAwIDAgMS0zNSAwIDI5IDI5IDAgMCAxLTMzIDIgMjkgMjkgMCAwIDEtMzItMiAyOSAyOSAwIDAgMS0zNSAwIDI5IDI5IDAgMCAxLTM1IDAgMjkgMjkgMCAwIDEtMzYgMGMtNSA0LTExIDYtMTcgNmEzMCAzMCAwIDAgMS0yNi00NWMtMy00LTQtOS00LTE1di0xYzAtNSAxLTEwIDQtMTQtMy00LTQtOS00LTE1di0xYzAtNSAxLTEwIDQtMTQtMy00LTQtOS00LTE0di0xYzAtNiAxLTExIDQtMTUtMy00LTQtOS00LTE1IDAtNSAxLTEwIDQtMTUtMy00LTQtOS00LTE0di0xYzAtNSAxLTEwIDQtMTUtMy00LTQtOS00LTE0di0xYzAtNSAxLTEwIDQtMTRhMzAgMzAgMCAwIDEgMC0zMEEzMCAzMCAwIDAgMSA0NyA2YTMwIDMwIDAgMCAxIDM2IDAgMzAgMzAgMCAwIDEgMzUgMCAzMCAzMCAwIDAgMSAzNSAwIDMwIDMwIDAgMCAxIDMyLTIgMzAgMzAgMCAwIDEgMzMgMiAzMCAzMCAwIDAgMSAzNSAwIDMwIDMwIDAgMCAxIDM1IDAgMzAgMzAgMCAwIDEgMzYgMGM1LTQgMTEtNiAxNy02WiIvPjwvc3ZnPg==');
    }
}

.jam-spread.dot {
    text-decoration: underline;
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 2 / 1;
    font-size: clamp(2rem, 3vw, var(--heading-sizes--s));

    /* Non-breaking space in html before this arrow*/
    &::after { 
        display: contents;
        content: "↗";
    }
}


.further-reading {

    .toast {
        aspect-ratio: auto;
    }
    
    .marmalade-spread {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 100%;
        height: auto;
        z-index: -1;
        max-width: 50rem;

        @media (max-width: 70em) { max-width: 40rem; }
        @media (max-width: 47em) { max-width: 32rem; }

        @media ( max-width: 40em ) {
            transform: translate(-50%,-50%) rotate(0deg) scale(1.2, 1.5);
            transform: translate(-50%,-50%) rotate(0deg) scale(0.9, 0.85);
            width: 100vw;
            height: 100vw;
            object-fit: cover;
        }
    }

    .marmalade-spread-container {
        width: 320px;
        height: 320px;
        background-color: var(--reds--red);
        border-image-slice: 27 27 27 27;
        border-image-width: 27px;
        border-image-outset: 27px;
        border-image-repeat: round round;
        border-image-source: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCA0OTMgMjUwIj48cGF0aCBmaWxsPSIjRkE1OTQxIiBkPSJNNDUyIDBhNDEgNDEgMCAwIDEgMzUgNjIgNDEgNDEgMCAwIDEgMCA0MiA0MSA0MSAwIDAgMSAwIDQxIDQxIDQxIDAgMCAxIDAgNDIgNDEgNDEgMCAwIDEtNTYgNTYgNDEgNDEgMCAwIDEtNDEgMSA0MSA0MSAwIDAgMS00MSAwIDQxIDQxIDAgMCAxLTQxIDAgNDEgNDEgMCAwIDEtNDEgMCA0MSA0MSAwIDAgMS00MSAwIDQxIDQxIDAgMCAxLTQxIDAgNDEgNDEgMCAwIDEtNDEgMCA0MSA0MSAwIDAgMS00MSAwIDQxIDQxIDAgMCAxLTQxIDBjLTYgMy0xMyA1LTIxIDVhNDEgNDEgMCAwIDEtMzUtNjIgNDEgNDEgMCAwIDEgMC00MiA0MSA0MSAwIDAgMSAwLTQxIDQxIDQxIDAgMCAxIDAtNDJBNDEgNDEgMCAwIDEgNjIgNmE0MSA0MSAwIDAgMSA0MS0xIDQxIDQxIDAgMCAxIDQxIDAgNDEgNDEgMCAwIDEgNDEgMCA0MSA0MSAwIDAgMSA0MSAwIDQxIDQxIDAgMCAxIDQxIDAgNDEgNDEgMCAwIDEgNDEgMCA0MSA0MSAwIDAgMSA0MSAwIDQxIDQxIDAgMCAxIDQxIDAgNDEgNDEgMCAwIDEgNDEgMGM2LTMgMTMtNSAyMS01WiIvPjwvc3ZnPg==");
        border-style: solid;
        margin-bottom: 3rem;
    }
}

.plain-paper {
    text-align: left;
    
    width: 86.25rem;
    max-width: 95vw;
    height: 85vh;
    margin: 0 auto;
    padding: 2rem 5rem;
    
    p {
        font-family: 'Inter', sans-serif;
        font-size: 20px !important;
        line-height: 32px !important;
        margin-bottom: 15px !important;
    }
}