#wrap
 -6.times do
  .ticket
View Compiled
@font-face {
	font-family: "Cooper";
	src: url("https://assets.codepen.io/383755/cooper-black-webfont.woff")
		format("woff");
}

@font-face {
	font-family: "Aharoni";
	src: url("https://assets.codepen.io/383755/telefon.woff2") format("woff");
}

@font-face {
	font-family: "Bogart";
	src: url("https://assets.codepen.io/383755/bogart-semibold.woff2")
		format("woff2");
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: "Dot";
	src: url("https://assets.codepen.io/383755/Dot-Matrix.ttf.woff") format("woff");
}

@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@300;500&display=swap");

@import url("https://fonts.googleapis.com/css2?family=Coustard:wght@900&display=swap");

$noise: url("");

* {
	box-sizing: border-box;
}

@mixin flex-center() {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}

@function text-stroke($size: 2, $color: #fff, $correction: 0) {
	$radius: $size - $correction;
	$stroke: ();

	@for $i from -$size through $size {
		@for $k from -$size through $size {
			$x: $k;
			$y: $i;

			@if $k > 0 {
				$x: $k - 0.5;
			}
			@elseif $k < 0 {
				$x: $k + 0.5;
			}

			@if $i > 0 {
				$y: $i - 0.5;
			}
			@elseif $i < 0 {
				$y: $i + 0.5;
			}

			@if ($x * $x + $y * $y <= $radius * $radius) {
				$stroke: append($stroke, $i * 1px $k * 1px 0 $color, comma);
			}
		}
	}

	@return $stroke;
}

@mixin text-stroke($size: 2, $color: #fff, $correction: 0) {
	text-shadow: text-stroke($size, $color, $correction);
}

body {
	margin: 0px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100vh;
	overflow: hidden;
	font-family: "Oswald";
	cursor: pointer;
	--dark: #50303f;
	--font1: "Cooper";
	--font2: "Oswald";
	--font4: "Cooper";
	--font5: "Bogart";
	--font6: "Oswald";
	--font7: "Aharoni";
	--font8: "Coustard";
	--color1: #fe2fd9;
	--color2: #fa6c4b;
	--color3: #e5f31b;
	--color4: #5030da;
	--color5: #ff3641;
	--color6: #e5f31b;
	--color7: #fe2fd9;
	background: repeating-radial-gradient(
			circle at center,
			transparent 0px,
			#fff 0px,
			#fff 2px,
			transparent 2px,
			transparent 10px
		),
		radial-gradient(circle at center, #fff 25vw, #e5f4d1);
	&:before {
		content: "click to remix";
		position: absolute;
		bottom: 5px;
		width: 100%;
		left: 0;
		text-align: center;
		color: var(--dark);
	}
	&.active {
		#wrap {
			.ticket {
				@for $i from 1 through 6 {
					&:nth-of-type(#{$i}) {
						z-index: #{6 - $i};
						.inner {
							&:before {
								transition-delay: #{0.15 + ($i/10)}s;
								opacity: 1;
							}
							> div {
								transition-delay: #{$i/10}s;
								&:before,
								&:after {
									transition-delay: #{0.15 + ($i/10)}s;
									box-shadow: inset -100px 0px 100px -200px rgba(0, 0, 0, 0.15),
										inset 0 0 3rem -3rem var(--dark), inset 0 0 0 0.5rem var(--color1);
								}
								&:after {
									box-shadow: inset 100px 0px 100px 100px rgba(0, 0, 0, 0.15),
										inset 0 0 2rem 0.075rem var(--dark),
										inset 0 0 0 0.5rem lighten(#e5f4d1, 5%);
								}
							}
						}
					}
				}
				.inner {
					> div {
						transform: translateY(0);
					}
				}
			}
		}
	}
	&.loaded {
		#wrap {
			opacity: 1;
		}
	}
	#wrap {
		width: clamp(662.5px, 80vw, 1325px);
		min-width: 662.5px;
		height: clamp(500px, 60vw, 1000px);
		min-height: 500px;
		display: grid;
		grid-template-columns: repeat(8, 1fr);
		grid-template-rows: repeat(6, 1fr);
		grid-gap: 0rem;
		transition: 0.5s ease-in-out;
		transition-delay: 1s;
		opacity: 0;
		.ticket {
			position: relative;
			@for $i from 1 through 6 {
				&:nth-of-type(#{$i}) {
					z-index: #{8 - $i};
					.inner {
						&:before {
							transition: 0.5s cubic-bezier(0.5, 0.15, 0.35, 1);
							transition-delay: #{(6 - $i) / 10}s;
							opacity: 0;
						}
						> div {
							transition-delay: #{(6 - $i) / 10}s;
							&:before,
							&:after {
								transition-delay: #{0.15 + (6 - $i)/10}s;
							}
						}
					}
				}
			}
			.inner {
				position: absolute;
				height: 100%;
				width: 100%;
				left: 0;
				top: 0;
				padding: 1rem;
				clip-path: polygon(-10% -10%, 110% -10%, 110% 110%, -10% 110%);
				transform-style: preserve-3d;
				perspective: 900px;
				&:before {
					content: "";
					position: absolute;
					width: 90%;
					height: 90%;
					top: 10%;
					left: 5%;
					background: rgba(0, 0, 0, 0.25);
					filter: blur(15px);
				}
				&.class1 {
					.details {
						grid-row: 1 / span 1;
					}
				}
				&.class2 {
					.seat {
						grid-row: 3 / span 1;
					}
				}
				&.class2,
				&.class3 {
					.band {
						background: radial-gradient(
								circle at center,
								#e5f4d1 35%,
								transparent 35%,
								var(--color1) 75%
							),
							radial-gradient(
									circle at center,
									#e5f4d1 2px,
									var(--color1) 1px,
									var(--color1) 5px
								)
								50% 50% / 8px 8px repeat;
					}
				}
				&.class3 {
					.band {
						text-transform: uppercase;
					}
				}
				&.class5,
				&.class6 {
					> div {
						grid-template-columns: calc(33% - 0.125rem) calc(33% - 0.125rem) calc(
								33% - 0.125rem
							);
						> div {
							grid-column: span 3;

							&.band {
								strong {
									span.word {
										display: inline-block;
										margin: 0 0.15vw;
									}
								}
							}
							&.band,
							&.location {
								grid-column: 1 / span 2;
								grid-row: span 6;
								position: relative;
								strong {
									width: 200%;
									left: -50%;
									height: 50%;
									top: 25%;
									position: absolute;
									padding: 0 1rem;
									transform: rotate(90deg);
									word-break: break-word;
								}
							}
							&.location {
								grid-column: 3 / span 1;
								strong {
									width: 400%;
									height: 12.5%;
									top: 45%;
									left: -150%;
									@include flex-center();
									@include text-stroke(1, #e5f4d1);
									&:before {
										content: "";
										position: absolute;
										width: 90%;
										left: 5%;
										top: -5%;
										height: 110%;
										background: var(--color1);
										-webkit-mask: $noise;
										opacity: 0.75;
									}
									span {
										display: block;
										width: 100%;
										font-size: clamp(10px, 1vw, 1vw);
										&:first-of-type {
											font-size: clamp(12px, 1.35vw, 1.35vw);
											@include text-stroke(1, #e5f4d1);
										}
									}
								}
							}
						}
					}
				}
				&.class7 {
					.band {
						background: radial-gradient(
								circle at center,
								#e5f4d1 35%,
								transparent 35%,
								var(--color1) 75%
							),
							repeating-linear-gradient(
								var(--rotate),
								#e5f4d1 2px,
								var(--color1) 2px,
								var(--color1) 10px,
								#e5f4d1 10px,
								#e5f4d1 12px
							);
					}
				}
				&.class9 {
					.band {
						strong {
							span.word {
								transform: skew(5deg);
							}
						}
					}
				}
				&.class10,
				&.class11 {
					.band {
						background: radial-gradient(
								circle at center,
								#e5f4d1 35%,
								transparent 35%,
								var(--color1) 75%
							),
							repeating-linear-gradient(
								var(--rotate),
								#e5f4d1 2px,
								var(--color1) 2px,
								var(--color1) 10px,
								#e5f4d1 10px,
								#e5f4d1 12px
							);
					}
				}
				> div {
					display: grid;
					grid-template-columns: calc(100% - 0.25rem);
					grid-template-rows: repeat(10, 1fr);
					justify-content: center;
					height: 100%;
					background: var(--dark);
					grid-gap: 0.125rem;
					padding: 0.125rem 0;
					position: relative;
					transition: 0.5s cubic-bezier(0.5, 0.15, 0.35, 1);
					transform-style: preserve-3d;
					transform: rotateY(180deg);
					&:before,
					&:after {
						transform-style: preserve-3d;
						content: "";
						position: absolute;
						width: 100%;
						height: 100%;
						top: 0;
						left: 0;
						z-index: 2;
						box-shadow: inset -200px 0px 100px 100px rgba(0, 0, 0, 0.25),
							inset 0 0 3rem -2rem var(--dark), inset 0 0 0 0.5rem var(--color1);
						transition: box-shadow 0.5s cubic-bezier(0.5, 0.15, 0.35, 1);
					}
					&:before {
						background: #e5f4d1;
						-webkit-mask: $noise;
						opacity: 0.5;
						width: calc(100% + 0.5vw);
						height: calc(100% + 0.5vw);
						left: -0.25vw;
						top: -0.25vw;
						backface-visibility: hidden;
					}
					&:after {
						transform: rotateY(-180deg) translateZ(0.05px);
						background: lighten(#e5f4d1, 5%);
						box-shadow: inset 100px 0px 100px -200px rgba(0, 0, 0, 0.15),
							inset 0 0 6rem -6rem var(--dark), inset 0 0 0 0.5rem lighten(#e5f4d1, 5%);
					}
					> div {
						box-sizing: border-box;
						background: var(--color1);
						box-shadow: inherit;
						line-height: 1;
						grid-row: span 1;
						text-align: center;
						@include flex-center();
					}
				}
				.date {
					text-transform: uppercase;
					grid-row: span 2;
					@include flex-center();
					padding: 0.75vw 0;
					background: #e5f4d1;
					span {
						display: block;
						font-size: clamp(10px, 1vw, 1vw);
						width: 100%;
					}
					> span:nth-of-type(2) {
						font-size: clamp(16px, 2vw, 2vw);
						font-family: var(--font2);
					}
				}
				.band {
					grid-row: span 5;
					position: relative;
					font-family: var(--font1);
					overflow: hidden;
					background: radial-gradient(
							circle at center,
							#e5f4d1 37.5%,
							transparent 35%,
							var(--color1) 90%
						),
						repeating-radial-gradient(
							circle at center,
							transparent 0px,
							#e5f4d1 0px,
							#e5f4d1 2px,
							var(--color1) 2px,
							var(--color1) 10px
						);
					strong {
						@include flex-center();
						position: absolute;
						width: 102.5%;
						height: 75%;
						left: -1.25%;
						top: 12.5%;
						padding: 0 0.5rem;
						transform: rotate(90deg);
						font-size: clamp(20px, 2.35vw, 2.35vw);
						word-break: break-word;
						line-height: 0.95;
						--words: var(--word-total);
						letter-spacing: 0.15rem;
						transform: scale(calc(1 + (var(--word-total) / 20)));
						> span.word {
							display: inline-block;
						}
						> span > span.word {
							display: block;
							@include text-stroke(1, #e5f4d1);
							font-size: clamp(
								18px,
								calc(7vw - (((var(--char-total) * 1) * (var(--words) / 1.5)) * 0.35vw)),
								2.75vw
							);
						}
					}
				}
				.details {
					display: flex;
					align-items: stretch;
					strong {
						width: 100%;
						display: flex;
						span {
							width: 50%;
							box-shadow: inset 0.05vw 0 0 var(--dark), inset -0.05vw 0 0 var(--dark);
							@include flex-center();
						}
					}
				}
				.location {
					strong span {
						font-size: 1vw;
						display: block;
						font-weight: 200;
						line-height: 1.25;
						&:first-of-type {
							font-size: clamp(8px, 1.25vw, 1.25vw);
							font-weight: 900;
						}
					}
				}
				.seat {
					display: flex;
					justify-content: space-between;
					background: #e5f4d1;
					strong {
						font-size: clamp(8px, 1.25vw, 1.25vw);
						display: flex;
						justify-content: center;
						align-items: center;
						flex-wrap: wrap;
						width: 33.33%;
						padding: 0.5rem;
						&:nth-of-type(2) {
							box-shadow: 0.075rem 0 0 var(--dark), -0.075rem 0 0 var(--dark),
								inset 0.075rem 0 0 var(--dark), inset -0.075rem 0 0 var(--dark);
						}
						> span {
							display: block;
							margin: 0.25rem 0 0;
							width: 100%;
							font-size: clamp(16px, 2vw, 2vw);
							text-transform: uppercase;
							font-family: "Dot", cursive;
							font-weight: 100;
							color: var(--color2);
						}
					}
				}
			}
			&:nth-of-type(1) {
				grid-area: 3 / 1 / 7 / 3;
				.inner {
					transform-origin: 0% 0%;
					transform: rotate(-90deg);
				}
			}
			&:nth-of-type(2) {
				grid-area: 3 / 1 / 7 / 3;
			}
			&:nth-of-type(3) {
				grid-area: 3 / 3 / 7 / 5;
			}
			&:nth-of-type(4) {
				grid-area: 1 / 5 / 5 / 7;
			}
			&:nth-of-type(5) {
				grid-area: 1 / 7 / 5 / 9;
			}
			&:nth-of-type(6) {
				grid-area: 1 / 5 / 5 / 7;
				.inner {
					transform-origin: 0% 100%;
					transform: rotate(90deg);
				}
			}
		}
	}
}
View Compiled
const bands = [];
const cities = [];
const venues = [];
const row = "abcdefghijklmnopqrstuvwxyz";

let days = [
	"Sunday",
	"Monday",
	"Tuesday",
	"Wednesday",
	"Thursday",
	"Friday",
	"Saturday"
];
let months = [
	"January",
	"February",
	"March",
	"April",
	"May",
	"June",
	"July",
	"August",
	"September",
	"October",
	"November",
	"December"
];

function randomDate(start, end) {
	return new Date(
		start.getTime() + Math.random() * (end.getTime() - start.getTime())
	);
}

$(document).ready(function () {
	var lastFM =
		"https://ws.audioscrobbler.com/2.0/?api_key=5908c0487c4b5f26281c158dd83b59d6&format=json&method=user.getTopArtists&user=adamkuhn&period=overall&limit=200";
	var cityData =
		"https://random-data-api.com/api/address/random_address?size=50";
	$.getJSON(cityData, function (data) {
		$.each(data, function (i, item) {
			venues.push(data[i].community + " Theater");
			cities.push(data[i].city + ", " + data[i].state);
		});
		$.getJSON(lastFM, function (data) {
			$.each(data.topartists.artist, function (i, item) {
				bands.push(data.topartists.artist[i].name);
			});
			createTicket();
			$("body").addClass("loaded");
		});
	});
});

$(document).click(function () {
	createTicket();
});

function createTicket() {
	$("body").removeClass("active");
	setTimeout(() => {
		$(".ticket").each(function () {
			$(this).find(".inner").remove();
			let randBand = Math.floor(Math.random() * bands.length);
			let randCity = Math.floor(Math.random() * cities.length);
			let randVenue = Math.floor(Math.random() * venues.length);
			let randDate = randomDate(new Date(2021, 0, 1), new Date());
			$(this)
				.get(0)
				.style.setProperty(
					"--font1",
					"var(--font" + Math.floor(Math.random() * (7 - 1) + 4) + ")"
				);
			$(this)
				.get(0)
				.style.setProperty(
					"--font2",
					"var(--font" + Math.floor(Math.random() * (7 - 1) + 4) + ")"
				);
			$(this)
				.get(0)
				.style.setProperty(
					"--color1",
					"var(--color" + Math.floor(Math.random() * (6 - 1) + 3) + ")"
				);
			$(this)
				.get(0)
				.style.setProperty(
					"--rotate",
					Math.floor(Math.random() * (5 - 1) + 1) * 45 + "deg"
				);
			$(this).append(
				"<div class='inner class" +
					Math.floor(Math.random() * (8 - 1) + 1) +
					" class" +
					Math.floor(Math.random() * (8 - 1) + 7) +
					"'><div><div class='date'><span>" +
					days[randDate.getDay()] +
					"</span><span>" +
					months[randDate.getMonth()] +
					" " +
					randDate.getDate() +
					"</span><span>" +
					Math.floor(Math.random() * (12 - 1) + 1) +
					":00 PM</span></div><div class='band'><strong data-splitting='words'><span>" +
					bands[randBand] +
					"</span></strong></div><div class='location'><strong><span>" +
					venues[randVenue] +
					"</span><span>" +
					cities[randCity] +
					"</span></strong></div><div class='seat'><strong>Section<span>" +
					Math.floor(Math.random() * (40 - 1) + 1) +
					"</span></strong><strong>Row<span>" +
					row[Math.floor(Math.random() * row.length)] +
					"</span></strong><strong>Seat<span>" +
					Math.floor(Math.random() * (40 - 1) + 1) +
					"</span></strong></div><div class='details'><strong><span>$" +
					Math.floor(Math.random() * (20 - 5) + 5) +
					".00</span><span>All Ages</span></strong></div></div></div>"
			);
		});
		Splitting();
		$("span.word").attr("data-splitting", "chars");
		Splitting();
	}, 1000);
	setTimeout(() => {
		$("body").addClass("active");
	}, 1500);
}

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

  1. https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js
  2. https://unpkg.com/splitting@1.0.5/dist/splitting.min.js