.preload-no-transition * {
	-webkit-transition: none!important;
	-moz-transition: none!important;
	-ms-transition: none!important;
	-o-transition: none!important;
	transition: none!important;
}



html { font-size: 62.5%; }
html, body { height: 100%; }
body { font-family: 'Fira Sans', Arial, Helvetica, sans-serif; font-size: 1.6rem; line-height: 1.75; font-weight: 300; color: #e5e0da; background: #262421 url(../img/skin-texture.svg) repeat-x center top; margin: 0; }

header { grid-column: 2 / 4; position: relative; }
aside { grid-column: 2 / 3; grid-row: 2 / 4; z-index: 10; }
main { background: linear-gradient(#322f2c 40px, #262421 440px); grid-column: 2 / 4; grid-row: 3 / 4; padding: 30px 30px 0 270px; }
section { display: flow-root; margin: 0 0 60px; }
footer { background: #131210; grid-column: 1 / -1; padding: 30px; }



a { font-weight: 400; color: #96cc29; text-decoration: none; outline: 0; border-bottom: 2px solid transparent; transition: all .2s linear; }
	a:hover { color: #b2f230; color: #bf3; border-color: #70991f; }
	a:active { color: #fb3; border-color: #a67a20; transition: none; }
form + h2, main form + ul, .credits + h2 { margin-top: 40px; }
form + p { margin-top: 20px; }
h1, h2, h3 { font-size: 3.4rem; line-height: 1.2; font-weight: 500; color: #96cc29; text-shadow: 2px 2px 4px rgba(0,0,0,.4); margin: 0 0 20px; }
h2 { font-size: 2.4rem; line-height: 1.25; margin: 0 0 15px; }
h3 { font-size: 2rem; line-height: 1.3; margin: 25px 0 10px; }
hr { margin: 25px 0; border: 0; border-bottom: 1px solid #5c5753; }
img { display: block; max-width: 100%; height: auto; }
main ul { margin: 0 0 20px; }
	main li { margin: 0 0 5px; padding-left: 20px; }
		main li:last-child { margin: 0; }
		main ul li::before { content: ''; background: #5c5753; display: inline-block; width: 10px; height: 10px; margin: 0 10px 0 -20px; border-radius: 50%; }
ol { padding: 0 0 0 18px; margin: 0 0 20px;}
	ol li { margin: 0 0 5px; padding-left: 10px; }
	ol li::marker { font-weight: 500; color: #807973; }
p { margin: 0 0 20px; }
p:last-child, ul:last-child, .module:last-child { margin: 0; }
p + h2, form.float-right + h2 { margin-top: 25px; }
strong { font-weight: 600; }
ul { list-style: none; padding: 0; margin: 0; }



/* GLOBAL CLASSES */
a.button { display: inline-flex; }
.button { cursor: pointer; font-size: 1.6rem; font-weight: 500; line-height: 1; color: #000; background-color: #96cc29; background-image: linear-gradient(rgba(255,255,255,.4), transparent 50%); display: flex; align-items: center; gap: 10px; padding: 3px 16px 3px 3px; border: 0; border-radius: 20px; box-shadow: 2px 2px 4px rgba(0,0,0,0.4); transition: background-color .2s linear; }
.button::before { content: ''; font-size: 1.8rem; font-weight: 400; color: #fff; background: #403b36; display: flex; justify-content: center; align-items: center; width: 26px; height: 26px; border-radius: 50%; }
.button.add-cart::before { background: #403b36 url(../img/button-icons-sprite.svg); }
.button.view-cart::before { background: #403b36 url(../img/button-icons-sprite.svg) 0 -26px; }
.button.print-form::before { background: #403b36 url(../img/button-icons-sprite.svg) 0 -52px; }
.button.icon4::before { content: '4'; }
.button.icon8::before { content: '8'; }
.button.icon4i::before { content: '4i'; }
.button:hover { color: #000; background-color: #bf3; }
.button:active { background-color: #ff9500; transition: none; }

.container-right { font-size: 1.4rem; text-align: right; float: right; margin: 0 0 10px 30px; }
.container-right.align-center { text-align: center; }
	.container-right img { margin: 0 0 5px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
	.container-right.silo img { box-shadow: none; filter: drop-shadow(4px 4px 8px rgba(0,0,0,.4)); }
.dotted { border-bottom: 2px dotted #5c5753; }
.float-right { float: right; margin: 0 0 10px 20px; }
.h1-archive { color: #99826b; }
.hl-green { color: #96cc29; white-space: nowrap; }
.hl-orange { color: #ff9500; }
.img-left { float: left; margin: 0 30px 10px 0; box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
.img-right { float: right; margin: 0 0 10px 30px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
.large { font-size: large; }
.no-wrap { white-space: nowrap; }
.normal { font-weight: 300; }
.wrap { white-space: initial; }



/* SITE FRAMEWORK AND NAVIGATION */
.container { display: grid; grid-template-columns: 1fr 250px minmax(auto, 850px) 1fr; grid-template-rows: auto auto 1fr auto; min-height: 100%; }
.logo-link { display: table; margin: 20px 0; border: 0; }
	.logo { filter: drop-shadow(2px 2px 4px rgba(0,0,0,.4)); }
.nav-button { display: none; }
.header-nav { line-height: 1.625; background: linear-gradient(#5c5753, #403b36); border-radius: 4px 4px 0 0; position: relative; z-index: 100; }
	.header-nav > ul { display: flex; }
		.header-nav > ul > li { flex: 1 1 auto; position: relative; transition: background-color .2s linear; }
		.header-nav > ul > li:first-child { overflow: hidden; border-radius: 4px 0 0 0; }
		.header-nav > ul > li:last-child { overflow: hidden; border-radius: 0 4px 0 0; }
			.header-nav > ul > li:first-child a { padding-left: 17px; }
			.header-nav > ul > li:last-child a { padding-right: 17px; }
		.header-nav > ul > li:hover { background-color: #70991f; background-image: linear-gradient(180deg, rgba(255,255,255,.2), transparent 20px); }
		.header-nav > ul > li > a:active { background-color: #5e801a; background-image: linear-gradient(180deg, rgba(255,255,255,.2), transparent 20px); }
		.header-nav li:hover ul { opacity: 1; visibility: visible; }
			.header-nav a { font-size: 1.7rem; font-weight: 400; color: #fff; text-shadow: 2px 2px 2px rgba(0,0,0,.3); text-decoration: none; text-align: center; display: block; padding: 6px 0 4px; border: 0; }

		li.current span { padding: 0 0 4px; border-bottom: 4px solid #96cc29; }
		li.current:hover span { border-bottom: 0; }

		.dropdown { background: linear-gradient(#add957, #96cc29); columns: 2; column-rule: dotted 2px rgba(0,0,0,.4); gap: 0; opacity: 0; visibility: hidden; overflow: hidden; min-width: 330px; border-radius: 0 0 4px 4px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); position: absolute; transition: opacity .2s linear, visibility .2s linear; }
		.dropdown.one-column { columns: 1; min-width: 165px; }
			.dropdown li:first-child a, .twelve-li li:nth-child(6n+1) a, .ten-li li:nth-child(5n+1) a, .six-li li:nth-child(3n+1) a { padding-top: 6px; }
			.dropdown li:last-child a, .twelve-li li:nth-child(6n) a, .ten-li li:nth-child(5n) a, .six-li li:nth-child(3n) a { padding-bottom: 6px; }
				.dropdown a { font-size: 1.6rem; color: #000; text-align: left; text-shadow: none; padding: 4px 0 4px 32px; transition: background-color .2s linear, padding-left .2s linear; }
				.dropdown a:hover { font-weight: 500; background: rgba(255,255,255,.4); padding-left: 38px; }
				.dropdown a:active { background: rgba(255,255,255,.6); transition: none; }
				.dropdown a.current, .sidebar a.current { background: rgba(255,255,255,.4); }
	


/* SIDEBAR */
.sidebar { line-height: 1.625; font-weight: 400; color: #000; background: linear-gradient(#add957, #96cc29); overflow: hidden; padding: 15px; margin: 20px; border-radius: 4px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
.sidebar.latest-issue { text-align: center; } 
	.sidebar-top { font-size: 1.8rem; font-weight: 500; color: #fff; text-shadow: 2px 2px 2px rgba(0,0,0,.3); text-align: center; background: linear-gradient(#92b350, #70991f); padding: 6px 6px 4px; margin: -15px -15px 0; }
	.archive { background: linear-gradient( #806c59, #664f38); }
	.latest-issue img { margin: 15px auto; box-shadow: 2px 2px 4px  rgba(0,0,0,.3); }
	.sidebar p { margin: 0 0 15px; }
	.sidebar-button { font-weight: 500; color: #fff; text-shadow: 2px 2px 2px rgba(0,0,0,.3); background-color: #403b36; background-image: linear-gradient(0deg, transparent 50%, rgba(255,255,255,.2)); display: block; max-width: 180px; padding: 4px 0 3px; margin: auto; border: 0; border-radius: 20px; box-shadow: 2px 2px 4px rgba(0,0,0,.3); }
	.sidebar-button:hover { color: #fff; background-color: #5d8c00; box-shadow: 0 0 0 1px #fff, 2px 2px 4px rgba(0,0,0,.3); }
	.sidebar-button:active { background-color: #ff9500; }

	.sidebar ul { margin: 0 -15px -15px; }
		.sidebar li a { font-weight: 400; color: #000; display: block; padding: 4px 0 4px 26px; border: 0; transition: background-color .2s linear, padding-left .2s linear; }
		.sidebar li:first-child a { padding-top: 6px; }
		.sidebar li:last-child a { padding-bottom: 6px; }
		.sidebar li a:hover { font-weight: 500; background: rgba(255,255,255,.4); padding-left: 32px; }
		.sidebar li a:active { background: rgba(255,255,255,.6); transition: none; }



/* HERO IMAGES */
.hero-band { background: #131210; grid-column: 1 / -1; grid-row: 2 / 3; display: grid; grid-template-columns: 1fr 250px minmax(auto, 850px) 1fr; position: relative; }
.hero-band::after { content: ''; background: #252320; grid-column: 2 / 3; width: 100%; height: 100%; position: absolute; }

.hero-container { background: #252320; grid-column: 3 / 4; grid-row: 2 / 3; display: grid; grid-template-columns: 1fr; position: relative; aspect-ratio: 850 / 300; }

	.hero { display: none; grid-column: 1 / 1; grid-row: 1 / 1; }
	.hero::before { content: ''; background: linear-gradient(90deg, #252320, transparent 20%); width: 100%; height: 100%; position: absolute; }
	.hero::after { content: ''; font-size: 1.4rem; color: #fff; background: linear-gradient(90deg, transparent, rgba(0,0,0,.3) 100px); padding: 6px 10px 4px 110px; position: absolute; right: 0; bottom: 0; }
	.hero.ardiente::after { content: 'Artwork by Elden Ardiente'; }
	.hero.eggleton::after { content: 'Artwork by Bob Eggleton'; }
	.hero.gardea::after { content: 'Artwork by Rudy Gardea'; }
	.hero.ite::after { content: 'Artwork by Casper Ite'; }
	.hero.jones::after { content: 'Artwork by Mark Jones'; }
	.hero.lewis::after { content: 'Artwork by Matt Lewis'; }
	.hero.mcintosh::after { content: 'Artwork by Gabe McIntosh'; }
	.hero.modstoon::after { content: 'Artwork by Modstoon'; }
	.hero.pazenski::after { content: 'Photography by Stephen Pazenski'; }
	.hero.pazenski2::after { content: 'Artwork by Stephen Pazenski'; }
	.hero.potts::after { content: 'Artwork by Tara Potts'; }
	.hero.roche::after { content: 'Artwork by Paul Roche'; }
	.hero.roche-scalf::after { content: 'Artwork by Paul Roche and Chris Scalf'; }
	.hero.scalf::after { content: 'Artwork by Chris Scalf'; }
	.hero.strate::after { content: 'Artwork by Jim Strate'; }
	.hero.tennant::after { content: 'Artwork by Todd Tennant'; }
	.hero.trammell::after { content: 'Artwork by Tony Trammell'; }
	.hero.tvrdik::after { content: 'Artwork by Tom Tvrdik'; }
	.hero.whalen::after { content: 'Artwork by Tom Whalen'; }
	.hero.yang::after { content: 'Artwork by Lung Yang'; }
	.hero.yates::after { content: 'Artwork by Jolyon Yates'; }



.jd-signature { margin: 30px 0 10px; }
.latest-news { font-size: 2rem; line-height: 1; font-weight: 500; color: #fff; text-shadow: 2px 2px 2px rgba(0,0,0,0.3); background: linear-gradient(#5c5753, #403b36); display: flex; align-items: center; gap: 15px; padding: 4px; margin: 0 -6px -20px; border: 6px solid #262421; border-radius: 30px; position: relative; z-index: 10; }
.rad-icon { background: url(../img/rad-icon.svg), linear-gradient(#add957, #96cc29); width: 30px; height: 30px; border-radius: 50%; }

.module.news-first { padding-top: 40px; }
.module { background: rgba(255,255,255,.05); display: flex; align-items: flex-start; gap: 30px; padding: 20px; margin: 0 0 20px; border-radius: 4px; }
	.module img { margin: 0 auto; box-shadow: 2px 2px 4px  rgba(0,0,0,.4); }
.subscriptions { justify-content: space-between; align-items: center; }



.note { background: rgba(255,255,255,.05); padding: 14px 20px; margin-top: 25px; border-radius: 4px; }
.fanzine-stack { display: grid; padding: 15px 20px 5px 50px; }
	.fanzine-stack img { grid-column: 1; grid-row: 1; }
	.fanzine-stack img:nth-child(1) { margin: 45px 0 0 -45px; z-index: 30; transform: rotate(-2deg); }
	.fanzine-stack img:nth-child(2) { margin: 30px 0 0 -30px; z-index: 20; transform: rotate(2deg); }
	.fanzine-stack img:nth-child(3) { margin: 15px 0 0 -15px; z-index: 10; transform: rotate(6deg); }
	.fanzine-stack img:nth-child(4) { transform: rotate(10deg); }



.back-issues-container { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 20px; }
	.back-issues-container > div { text-align: center; background: rgba(255,255,255,.05); display: grid; justify-items: center; gap: 10px; padding: 20px; border-radius: 4px; }
		.back-issues-container img { box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
		.back-issues-container p { margin: 0 0 15px; }



.index-columns { columns: 3 150px; }
.index ul { margin: 0; }
.index ul.credits { margin: 0 0 30px; }
.container-index { display: flex; align-items: center; float: right; margin: 0 10px 10px 40px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); position: relative; }
.last-index { margin-right: 0; }
	.container-index img { z-index: 10; }
	.previous-next { color: transparent; display: grid; align-items: center; width: 30px; height: 50px; border: 0; border-radius: 4px 0 0 4px; position: absolute; left: -30px; }
	.previous-next:hover { color: transparent; background: #70991f; box-shadow: 2px 2px 4px rgb(0,0,0,.4); }
	.previous-next:active { color: transparent;	 background: #5e801a; }
		.previous-next::before { content: ''; width: 20px; height: 20px; border: 2px solid #fff; border-top: 0; border-right: 0; border-radius: 0 4px; box-sizing: border-box; position: relative; left: 10px; transform: rotate(45deg); }
	.next { left: 100%; border-radius: 0 4px 4px 0; }
		.previous-next.next::before { left: 0; transform: rotate(-135deg); }



.guest-legend { display: inline; width: 20px; position: relative; top: 5px; left: 5px; }
.guest { background: url(../img/guest-icon.svg) no-repeat 0 2px; padding-left: 28px; margin-left: -28px; }
.covid { font-weight: 400; color: #000; background: url(../img/mask-icon.svg) no-repeat 16px 16px, linear-gradient(#add957, #96cc29); padding: 14px 20px 14px 90px; margin: 0 0 20px; border-radius: 4px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
.kawase { font-size: 1.4rem; line-height: 1.5; text-align: center; min-width: 120px; margin: 0 auto; }
	.module .kawase img { margin: 0 auto 10px; }
.vendors-columns { columns: 2 220px; }



.fan-fiction p { text-align: justify; text-indent: 25px; margin: 0; }
.ff-divider { background: linear-gradient( 90deg, rgba(255,255,255,0), #96cc29, rgba(255,255,255,0)); height: 1px; border: 0; }
.the-end { text-align: center; margin: 50px auto; }



.site-map-layout { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 30px 50px; margin-right: 30px; }
	.site-map-layout h3 { color: #fff; margin-top: 0; }



.error404 { padding-left: 30px; border-radius: 4px; }
	.error404 .site-map-layout { max-width: 800px; margin-top: 30px; }



.footer-container { max-width: 1040px; margin: auto; }
	.address-social-container { display: flex; justify-content: space-between; align-items: center; gap: 30px; margin: 0 0 30px; }
		.dke { font-weight: 500; padding-right: 14px; margin-right: 14px; border-right: 1px solid #96cc29;}
		.social-media-container { display: flex; gap: 20px; }
			.social-media { background: #403b36; width: 40px; height: 40px; border: 0; border-radius: 50%; }
				.social-media:hover { background-color: #70991f; }
				.social-media:active { background-color: #5e801a; }
			.site-map { background-image: url(../img/site-map-icon.svg); }
			.email { background-image: url(../img/email-icon.svg); }
			.twitter { background-image: url(../img/twitter-icon.svg); }
			.facebook { background-image: url(../img/facebook-icon.svg); }
		.disclaimer { font-size: 1.4rem; color: #807973; }
		.credit-container { display: flex; justify-content: center; align-items: baseline; gap: 20px; }
			.sp-icon { background: #70991f url(../img/sp-icon.svg); display: inline-block; width: 24px; height: 24px; margin-right: 10px; border-radius: 50%; position: relative; top: 6px; transition: background-color .2s linear; }
			.sp-studio { font-size: 1.4rem; font-weight: 300; border: 0; }
				.sp-studio:hover .sp-icon { background-color: #bf3; }
				.sp-studio:active .sp-icon { background-color: #fb3; transition: none; }
			.version { padding: 0 8px; border-radius: 4px; box-shadow: 0 0 0 1px #807973; }



@media (max-width: 1100px) {
	.logo-link { margin-left: 20px; }
	.header-nav, .header-nav > ul > li:first-child, .header-nav > ul > li:last-child, .error404 { border-radius: 0; }
	.dropdown a { padding-left: calc((100vw - 594px) / 16); }
	.dropdown a:hover { padding-left: calc((100vw - 594px) / 16 + 6px); }
}

@media (max-width: 850px) {
	.logo-link { margin-left: 30px; }
	.header-nav a { font-size: 1.6rem; }
	.dropdown { min-width: 310px; }
		.dropdown a { padding-left: calc((100vw - 561px) / 16); }
		.dropdown a:hover { padding-left: calc((100vw - 561px) / 16 + 6px); }

	.hero-container { grid-column: 2 / 4; }
		.hero { padding: 0; }
		.hero::before { display: none; }

	main { padding-left: 30px; }
	.guest { padding-left: 28px; margin-left: 0; }
	aside {  display: grid; grid-template-columns: 1fr 1fr; grid-column: 2 / 4; grid-row: 4; gap: 20px; margin: 0 30px 60px; }
		.sidebar { margin: 0; }
	aside.no-sublinks { grid-template-columns: 1fr minmax(auto, 385px) 1fr; }
		aside.no-sublinks .sidebar { grid-column: 2 / 3; }

	.address-social-container { text-align: center; flex-direction: column; }
}

@media (min-width: 768px) {
	.header-nav { display: block!important; }
}

@media (max-width: 767px) {
	.nav-button { background-color: #403b36; background-image: linear-gradient(0deg, transparent, rgba(255,255,255,.15)); display: flex; justify-content: center; align-items: center; flex-direction: column; width: 44px; height: 44px; border-radius: 50%; box-shadow: 2px 2px 4px  rgba(0,0,0,.4); position: absolute; top: 43px; right: 30px; }
		.nav-button:active { background-color: #ff9500; }
			.nav-button:active div { background: #fff; }
			.nav-button div { background: #96cc29; width: 50%; height: 3px; margin: 2px; border-radius: 3px; transition: transform .2s linear; }
			.nav-button.active div:nth-child(2) { display: none; }
			.nav-button.active div:nth-child(1) { transform: rotate(45deg) translate(2.5px, 2.5px); }
			.nav-button.active div:nth-child(3) { transform: rotate(-45deg) translate(2.5px, -2.5px) }

	.header-nav { display: none; overflow: hidden; width: calc(100% - 60px); border-radius: 0 0 4px 4px; box-shadow: 2px 2px 4px rgba(0,0,0,.4); position: absolute; left: 30px; }
		.header-nav > ul { flex-direction: column; gap: 10px; padding: 10px 20px; }
			.header-nav > ul > li, .header-nav > ul > li:first-child, .header-nav > ul > li:last-child { overflow: hidden; border-radius: 4px; }
			.header-nav > ul > li:hover { box-shadow: 2px 2px 4px rgba(0,0,0,.4); }
			.header-nav > ul > li:nth-child(n+2):nth-child(-n+3) { overflow: visible; }
			.header-nav > ul > li:nth-child(n+2):nth-child(-n+3):hover { background: none; box-shadow: none; }
				.header-nav > ul > li:nth-child(n+2):nth-child(-n+3) > a { display: none; }

				.header-nav > ul > li:first-child a { padding-left: 0; }
				.header-nav > ul > li:last-child a { padding-right: 0; }

				.dropdown { opacity: initial; visibility: initial; border-radius: 4px; position: initial; }
					.dropdown.one-column { columns: 2; }
					.dropdown li a { padding: 4px 0 4px 16px; }
						.dropdown li a:hover { padding-left: 22px; }

	.hero::after, .container-right, .kawase { font-size: 1.2rem; }

	.img-right, .container-index img { width: 200px; }

	.container-right.mobile-hide { display: none; }

	.dke { display: block; padding: 0; margin: 0; border: 0; }
}

@media (max-width: 500px) {
	body { font-size: 1.5rem; line-height: 1.6; }
	.logo-link { margin-left: 20px;}
	.nav-button { right: 20px; }
	.header-nav { width: 100%; left: 0; border-radius: 0; }

	main { padding: 20px 20px 0; }
	h1 { font-size: 3rem; }
	h2 { font-size: 2.2rem; line-height: 1.27272727; }
	h3 { font-size: 1.8rem; line-height: 1.44444444; }
	hr { margin: 20px 0; }
	hr + h3 { margin-top: 20px; }

	.module { flex-direction: column; gap: 20px; }
	.subscriptions { text-align: center; }
	aside, aside.no-sublinks { grid-template-columns: 1fr; margin: 0 20px 60px; }
		aside.no-sublinks .sidebar { grid-column: 1 / 2; }

	.mobile-grid { display: grid; }
	.img-right { grid-row: 3; width: 240px; margin: 0 auto 30px; }
	.container-index { grid-row: 4; margin: 0 auto 30px; }
		.container-index img { width: 240px; }
	.credits + h2 { margin-top: 0; }
	form.float-right { float: none; margin: 0; }
	form + h2, form.float-right + h2, main form + ul { margin-top: 30px; }

	.button { margin: auto; }
	.large { font-size: initial; }

	.container-right { display: table; float: none; margin: 0 auto 20px; }
	.covid { padding: 14px 20px; background: linear-gradient(#add957, #96cc29); }

	footer { padding: 20px 20px 30px; }
}


@media (max-width: 439px) {
.back-issues-container > div { grid-template-columns: auto 1fr;
    text-align: left;
    justify-items: start;
    gap: 20px; }
.back-issues-container img { width: 80px; }
.jd-lees { width: 120px; }
.print-form { float: none; }
}
