:root {
	--blog-link-hover: rgb(117 117 117);
	--blog-primary-font: 'Nunito';
	--blog-primary-font-heavy: 'Nunito';
	--blog-primary-font-med: 'Nunito';
	--blog-title-font: 'Berry Rotunda Regular';
	--groo-font-berry: 'Berry Rotunda Regular', serif;
	--groo-font-albertus: 'Albertus Medium Regular';
	--groo-font-ocr-a: 'OCR A Std';
	--groo-font-ocr-b: 'OCR B Pro Regular';
	--groo-dark-red: #A60816;
	--groo-light-red: #CA0012;
	--groo-light-beige: #E5DDCC;
	--groo-beige: #C7AB77;
	--groo-yellow: #FFD40B;
	--groo-light-yellow: #FFF70B;
}

body > header {
    padding: 0;
    background-size: cover;
    background-position: center;
}
    .webp body > header {
        background-image: url('../images/parchment-2x.webp');
    }
    .no-webp body > header {
        background-image: url('../images/parchment.jpg');
    }
        header .header-inner {
            height: 70px;
        }
            #hdr_logo,
            #hdr_logo img {
                height: 50px;
            }
            #hdr_nav {
                align-items: center;
                font-size: 1.25em;
                justify-content: center;
            }
                #hdr_nav a.nav-item {
                    padding: 0;
                    font-family: var(--groo-font-albertus);
                    width: auto;
                    margin-right: 5%;
                    margin-left: 0;
                }
                    #hdr_nav a.nav-item:last-child {
                    	margin-right: 0;
                    }
                    a.nav-item.nav-item-search {
                        display: none;
                    }

#main {
    padding-top: 70px;
}

h1 {
	display: inline-block;
	font-size: 2.625em;
	font-family: var(--groo-font-berry);
	font-weight: normal;
	letter-spacing: 0;
	line-height: 1.1em;
	margin: 0 0 .35em;
	text-transform: capitalize;
}
h2 {
    font-family: var(--groo-font-albertus);
    font-size: 2.625em;
    line-height: 1.2em;
    text-transform: capitalize;
    font-weight: normal;
    margin: 0;
}
h3 {
    font-family: var(--groo-font-berry);
    font-weight: normal;
    font-size: 2.5em;
    line-height: 1.4em;
    margin: 0;
}
h4 {
    font-family: var(--groo-font-berry);
    font-weight: normal;
    font-size: 1.625em;
    margin: 0 0 .5667em;
}
a:focus, 
input:focus {
    outline: none;
}

.section-title-hr {
    height: 2px;
    width: 38.091%;
    max-width: 327px;
    background-color: #4B4646;
    border: 0 none;
    margin: .8125em auto 1.625em;
}

.section-subtitle {
    font-size: 1.125em;
    font-family: var(--groo-font-ocr-b);
    margin: 0 0 1.25em;
    text-transform: uppercase;
}
.section-body-text {
    font-size: 1.125em;
    font-family: Nunito;
    font-weight: 300;
    margin: 0;
}
    .section-body-text img {
        max-width: 100%;
    }
    .section-body-text p {
        line-height: 1.18em;
        margin: 0 0 .75em;
    }
        .section-body-text p:last-child {
            margin-bottom: 0;
        }

a.btn, input.btn {
    background-color: var(--groo-yellow);
    text-decoration: none;
    color: #000;
    font-size: 1.125em;
    font-family: var(--groo-font-ocr-b);
    padding: 1.0833em 3em 1em;
    border-radius: calc(1.125em + (1.0833em * 2));
    text-transform: uppercase;
    position: relative;
    display: inline-block;
}
    a.btn:hover, input.btn:hover {
        box-shadow: 3px 3px 6px rgb(0 0 0 / 25%);
        background-color: var(--groo-light-yellow);
        transform: translateY(-3px);
    }

footer {
    color: #FFF;
    background-color: #3e0808;
    background-position: center;
    background-size: cover;
    text-align: center;
    position: relative;
}
    .webp footer {
        background-image: url('../images/footer_bg.webp');
    }
	.no-webp footer,
	.no-js footer, 
	.no-webp footer, 
	.no-js footer {
        background-image: url('../images/footer_bg.jpg');
    }
    .footer-inner {
        padding: 2.9375em 0 1.75em;
        max-width: 1440px;
        margin: 0 auto;
    }
        h4.footer-headline {
            font-family: var(--groo-font-albertus);
            font-size: 1.375em;
            line-height: 1.27em;
            margin: 0 5% .5667em;
        }
        .footer-copyright {
			margin: 0 auto;
			width: 90%;
		}
			.footer-copyright a {
				color: #FFF;
				margin-left: .5em;
			}

.social-cont {
    display: flex;
    height: 54px;
    justify-content: space-around;
    align-items: stretch;
    margin: 2em auto 2em;
    width: 30%;
    min-width: 316px;
}
    a.social-link {
        position: relative;
        display: inline-block;
        width: 54px;
        height: 54px;
        border-radius: 50%;
        overflow: hidden;
    }
        a.social-link > * {
            width: 60%;
            height: auto;
            background-color: var(--groo-yellow);
            padding: calc(20% + 1px);
        }
    .social-cont.mobile-nav-social-cont {
		height: 42px;
		margin: 0 auto 0 0;
		justify-content: flex-start;
		font-size: 1.375em;
	}

#mobile_nav #groo_mobile_nav_close {
    position: absolute;
    top: 14px;
    left: 24px;
    font-family: sans-serif;
    font-size: 2em;
    width: 20px;
    height: 20px;
    margin: 0;
}
    #groo_mobile_nav_close svg {
		width: 100%;
		height: 100%;
		fill: #FFF;
	}

/********************************
SECTIONS COMMON TO MULTIPLE PAGES
********************************/
.announcement-section {
    padding: 5.21625em 0;
    background-size: cover;
}
	.webp .announcement-section, 
	.webp .feature-section {
		background-image: url('../images/parchment-2x.webp');
	}
	.no-webp .announcement-section,
	.no-js .announcement-section, 
	.no-webp .feature-section, 
	.no-js .feature-section {
		background-image: url('../images/parchment.jpg');
	}
    .announcement-section .section-inner {
        margin: 0 20.139%;
        text-align: center;
    }
        .announcement-section-btn-cont {
            margin: 2.5em 0 0;
        }


.feature-section .section-inner {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    max-width: 1440px;
    box-sizing: border-box;
    margin: 0 auto;
}
    .feature-content-cont {
        width: 50%;
        padding: 5.625% 3% 5.625% 5.625%;
        box-sizing: border-box;
    }
        .graphic-placement-left .feature-content-cont {
            order: 2;
        }
        .feature-content-cont .section-title-hr {
            margin-left: 0;
            width: 50%;
        }
        .feature-section-btn-cont {
            margin: 2.5em 0 0;
        }
            .feature-section-btn-cont a.btn {
                background-color: var(--groo-dark-red);
                color: #FFF;
            }
                .feature-section-btn-cont a.btn:hover {
                    background-color: var(--groo-light-red);
                }
    .feature-graphic-cont {
        position: relative;
        width: 50%;
        overflow: hidden;
        padding: 0;
    }
        .graphic-placement-left .feature-graphic-cont {
            order: 1;
        }
        .feature-graphic-cont::after {
            content: "";
            display: block;
            padding-bottom: 100%;
        }
        .feature-graphic {
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center left;
        }
            .graphic-placement-left .feature-graphic {
                object-position: center right;
            }

.hp-creators-section {
    background-color: #000;
    color: #FFF;
}
    .hp-creators-section .section-inner {
        padding: 3.125% 0;
    }
        .all_chars_illustration_img {
            width: 93.75%;
            margin: 0 auto 3.125%;
            height: auto;
            display: block;
            position: relative;
        }
        .hp-creators-section h2 {
            text-align: center;
            margin: 0 3.125%;
        }
        .hp-creators-section .section-title-hr {
            background-color: #FFF;
        }
        .creators-section-subtitle {
            margin: 0 3.125%;
            text-align: center;
        }
        .hp-creators-items-cont {
            margin: 4.9375em auto;
            width: 82.43%;
        }
            .creator-item {
                display: flex;
                justify-content: space-between;
                align-items: flex-start;
                padding-bottom: 7em;
                border-bottom: 2px solid var(--groo-beige);
                margin-bottom: 7em;
            }
                .creator-item:last-child {
                    border-bottom: 0 none;
                    margin-bottom: 0;
                    padding-bottom: 0;
                }
            .creator-content-cont {
                width: 47.54%;
            }
                .creator-content-cont h3 {
                    color: var(--groo-beige);
                    font-family: var(--groo-font-albertus);
                    font-size: 2.5em;
                    line-height: 1.22em;
                    margin-bottom: .556em;
                }
                .creator-item-body-text {
                    margin: 0 0 2.636em;
                }
            .graphic-placement-left .creator-content-cont {
                order: 2;
                margin-left: 5%;
            }
            .graphic-placement-right .creator-content-cont {
                order: 1;
                margin-right: 5%;
            }
            .creator-item-img {
                width: 36%;
            }
                .graphic-placement-left .creator-item-img {
                    order: 1;
                }
                .graphic-placement-right .creator-item-img {
                    order: 2;
                }

/*********************************
RESPONSIVE STYLES
*********************************/
@media all and (min-width: 1455px) {
	.section-body-text {
		width: 860px;
		margin: 0 auto;
	}
	.announcement-section .section-inner {
		width: 860px;
		padding: 0;
		margin: 0 auto;
	}

	.feature-section .section-inner {
		width: 1440px;
		margin: 0 auto;
	}
	.section-body-text.feature-body-text,
	.creator-item-body-text {
		width: auto;
	}

	.all_chars_illustration_img {
		width: 1350px;
	}
	.hp-creators-section h2,
	.creators-section-subtitle {
		width: 1350px;
		margin: 0 auto;
	}
	.hp-creators-items-cont {
		width: 1187px;
		margin-left: auto;
		margin-right: auto;
	}
	.creator-item-body-text {
		margin: 0 0 2.636em;
	}
}

@media all and (max-width: 1023px) {
	h2 {
		font-size: 2.5em;
	}
	h3 {
		font-size: 2.25em;
	}
    .section-title-hr {
        width: 50%;
    }
    .section-subtitle {
        line-height: 1.35em;
    }
    footer .social-cont {margin: 1.5em auto 3em;}

	.announcement-section {
		padding: 3.75em 0;
	}
        .announcement-section .section-inner {
            margin: 0 12.5%;
        }
            .announcement-section-btn-cont {
                margin-top: 2em;
            }

	.feature-content-cont {
		padding: 4.5% 3% 4.5% 4.5%;
	}
	.feature-section-btn-cont {
		margin: 2em 0 0;
	}
}

@media all and (max-width: 937px) {
	.hp-creators-items-cont {
		width: 50%;
		margin: 2em auto;
	}
		.creator-item {
			flex-direction: column;
			padding-bottom: 3em;
			margin-bottom: 3em;
		}
			.hp-creators-items-cont .creator-item .creator-content-cont {
				order: 2;
				margin: 0;
				width: 100%;
				text-align: center;
			}
				.creator-item-body-text {
					text-align: left;
					margin-bottom: 1.5em;
				}
			.hp-creators-items-cont .creator-item .creator-item-img {
				order: 1;
				width: 100%;
				margin: 0 0 1em;
			}
}

@media all and (max-width: 850px) {
	.feature-graphic-cont {
		align-self: flex-start;
	}
}

@media all and (max-width: 850px) and (orientation: landscape) {
	.hp-creators-items-cont {
		width: 75%;
	}
		.hp-creators-items-cont .creator-item .creator-item-img {
			width: 50%;
			margin: 0 auto 1em;
		}
}

@media (max-width: 768px) {
    h1 {
        font-size: 2.5em;
    }
    h2 {
        font-size: 2.35em;
    }
    h4 {
        font-size: 1.5em;
        line-height: 1.5em;
    }
    .section-title-hr {
        margin: .5em auto 1.25em;
    }
    .section-subtitle {
        margin-bottom: 1rem;
    }
    header .header-inner {
        justify-content: center;
    }
        #nav_burger {
            position: absolute;
            left: 1.5em;
            height: 25%;
        }
            #mobile_nav {
                font-family: var(--groo-font-albertus);
                background-color: #000;
                justify-content: flex-start;
                padding: 9vh 17% 17%;
                box-sizing: border-box;
                width: 100%;
                height: 100%;
                top: 0;
            }
                #mobile_nav > * {
                    margin-top: 1.5em;
                }
                    #mobile_nav > *:first-child {
                        margin-top: 0;
                    }
                #mobile_nav a {
                    color: #E5DAC6;
                    font-size: 1.375em;
                    padding: 0;
                }
                    #mobile_nav a.nav-item-mobile-search {
						display: none;
					}
                    #mobile_nav a:hover {
                        text-decoration: underline;
                        color: var(--groo-yellow);
                    }
                    #mobile_nav a.social-link {
						margin: 0 10% 0 0;
						width: 42px;
						height: 42px;
					}
						#mobile_nav a.social-link:last-child {
							margin-right: 0;
						}
    a.btn {
        padding: 1em 2.5em .9em;
        font-size: 1em;
    }
    footer .social-cont {
        margin: 1.25em auto 2em;
    }

	.announcement-section {
		padding: 3em 0;
	}
		.announcement-section-btn-cont {
			margin-top: 1.75em;
		}

	.feature-section .section-inner {
		flex-direction: column;
		align-items: center;
		padding: 0 0 4em;
	}
		.feature-content-cont {
			width: 70%;
			padding: 0;
			margin: 0 auto;
			text-align: center;
			order: 2;
		}
			.feature-content-cont .section-title-hr {
				margin-left: auto;
			}
		.feature-graphic-cont {
			align-self: unset;
			width: 100%;
			order: 1;
			margin-bottom: 4em;
		}
    .hp-creators-items-cont {
        width: 75%;
    }
        .hp-creators-items-cont .creator-item .creator-item-img {
            width: 75%;
            margin: 0 auto 1em;
        }
}


@media (max-width: 768px) and (orientation: landscape) {
    #mobile_nav {
        padding: 5vh 17%;
        justify-content: space-between;
    }
        #mobile_nav > * {
            margin-top: 1em;
        }
}

@media all and (max-width: 699px) {
    .footer-inner {
        padding: 2em 0 1em;
    }
	.feature-section .section-inner {
		padding-bottom: 3em;
	}
		.feature-graphic-cont {
			margin-bottom: 3em;
		}
}

@media all and (max-width: 599px) {
	h2 {
		font-size: 2.25em;
	}
	.hp-creators-section .section-title-hr {
		margin: .35em auto 1em;
	}
	.hp-creators-items-cont {
		width: 85%;
		margin: 1em auto;
	}
		.creator-content-cont h3 {
			margin-bottom: .25em;
		}
}

@media all and (max-width: 499px) {
	h1 {
		font-size: 2em;
	}
    .section-title-hr {
        width: 65%;
    }
    a.btn {
        font-size: 1em;
    }
	.social-cont {
		height: 48px;
        min-width: 246px;
	}
        a.social-link {
            width: 48px;
            height: 48px;
        }

    .footer-copyright {
        font-size: .85em;
    }
    .announcement-section .section-inner {
        margin: 0 7%;
    }
        .announcement-section-btn-cont {
            margin-top: 1.5em;
        }
    .feature-graphic-cont {
        margin-bottom: 2.5em;
    }
    .feature-content-cont {
        width: 75%;
    }
        .feature-section-btn-cont a.btn {
            padding: 1em 1.5em;
        }
}

@media all and (max-width: 399px) {
	#mobile_nav {
		padding: 70px 7% 10%;
	}
	.social-cont {
		height: 44px;
		min-width: unset;
		width: 100%;
	}
        a.social-link {
            width: 44px;
            height: 44px;
        }
    .feature-section .section-inner {
        padding-bottom: 2.5em;
    }
	.hp-creators-items-cont {
		width: 90%;
	}
		a.btn.creators-item-btn {
			padding: 1em 2em;
			max-width: calc(85% - 4em);
		}
}

@media all and (max-width: 315px) {
    h2 {
        font-size: 2em;
    }
    .section-subtitle {
        line-height: 1.15em;
        margin-bottom: .75em;
    }
    .section-body-text {
        font-size: 1em;
    }

    .announcement-section .section-inner {
        margin: 0 5%;
    }
        .announcement-section-btn-cont {
            margin-top: 1.25em;
        }
}

@media all and (max-height: 320px) {
    #mobile_nav > * {
        margin-top: .5em;
    }
}
