@import url("themes.css");
@import url("fonts.css");
@import url("cursors.css");
@import url("animations.css");

:root {
	--pattern-grid-image:
		repeating-linear-gradient(
			to top,
			transparent 0px,
			transparent 18px,
			var(--theme-accent-color--secondary--c0) 18px,
			var(--theme-accent-color--secondary--c0) 19px
		),
		repeating-linear-gradient(
			to right,
			transparent 0px,
			transparent 18px,
			var(--theme-accent-color--secondary--c0) 18px,
			var(--theme-accent-color--secondary--c0) 19px
		);
	--pattern-tile-image:
		linear-gradient(
			63.435deg,
			var(--theme-surface-color--c1) 25%,
			transparent 25%,
			transparent 75%,
			var(--theme-surface-color--c1) 75%
		),
		linear-gradient(
			-63.435deg,
			var(--theme-surface-color--c1) 25%,
			transparent 25%,
			transparent 75%,
			var(--theme-surface-color--c1) 75%
		);
}

* {
	box-sizing: border-box;
}

body {
	background-color: var(--theme-surface-color--c0);
	font-family: "Orange Kid", "Unifont", Arial, Helvetica, sans-serif;
	font-size: 14pt;
	line-height: 1.4;
	color: var(--theme-reference-color--inverted);
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

body::before {
	content: "";
	position: fixed;
	top: -200px;
	left: 0;
	right: -100px;
	bottom: 0;
	background-image: var(--pattern-tile-image);
	background-size: 100px 200px, 100px 200px;
	/*animation: BackgroundDrift 8s linear infinite;*/
	will-change: background-position;
	z-index: -8;
	filter: drop-shadow(4px 8px 2px var(--theme-shadow-color--hard));
}

.pop-cntn {
	width: 100%;
	margin: 0 auto;
	align-items: start;
	padding: 0;
	flex: 1;
}

marquee.ribbon {
	display: block;
	margin: 0;
	background: var(--theme-surface-color--c2);
	border: ridge var(--theme-accent-color--primary--c1);
	border-width: 3px 0;
	padding: 5px 0;
	font-family: "Pixel Operator Mono 8", "Unifont", monospace;
	font-weight: bold;
	font-size: 9px;
	text-transform: uppercase;
	color: var(--theme-accent-color--secondary--c2);
	letter-spacing: 0.1em;
	z-index: 5;
	box-shadow: 0 0 32px var(--theme-shadow-color--hard);
}

marquee.ribbon:nth-of-type(even) { border-color: var(--theme-accent-color--secondary--c1); }

marquee.ribbon em {
	font-weight: normal;
	font-style: normal;
	color: var(--theme-reference-color--inverted);
	background: none;
	border: none;
	padding: none;
	animation: none;
}

marquee > span { margin: 0 4em; }
marquee > span:first-of-type { margin-left: 0; }
marquee > span:last-of-type { margin-right: 0; }

fieldset > marquee {
	margin: -9px -12px;
}

header, footer {
	padding: 16px 20px;
	display: grid;
	align-items: center;
	background: var(--theme-accent-color--primary--c0);
	background-image: var(--pattern-grid-image);
	box-shadow:
		0 4px 16px var(--theme-shadow-color--hard),
		inset 0 1px 0 var(--theme-shadow-color--soft);
	color: var(--theme-accent-color--secondary--c2);
	font-family: "Pixel Operator Mono", "Unifont", monospace;
	font-size: 13pt;
	gap: 1rem;
	position: relative;
	overflow: hidden;
}

header {
	border-bottom: 3px ridge var(--theme-accent-color--secondary--c1);
	grid-template-columns: auto 1fr;
}

footer {
	border-top: 3px ridge var(--theme-accent-color--primary--c1);
	text-align: right;
	grid-template-columns: 1fr auto;
}

header .title {
	font-family: "Pixel Operator 8", "Unifont", sans-serif;
	font-size: 18px;
	font-weight: bold;
	text-shadow: 3px 3px 0 var(--theme-shadow-color--hard);
	text-transform: uppercase;
	margin: 0 0 6px;
}

main {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 0;
}

fieldset {
	background: var(--theme-accent-color--primary--c0);
	background-image: var(--pattern-grid-image);
	border: 3px ridge var(--theme-accent-color--primary--c1);
	padding: 9px 12px;
	line-height: 1.6;
	box-shadow:
		3px 3px 0 var(--theme-shadow-color--hard),
		0 4px 12px var(--theme-shadow-color--hard);
}
fieldset > fieldset {
	border-color: var(--theme-accent-color--secondary--c1);
}
fieldset:nth-child(even) {
	border-color: var(--theme-accent-color--secondary--c1);
}
fieldset:nth-child(even) > fieldset {
	border-color: var(--theme-accent-color--secondary--c1);
}
fieldset > fieldset legend {
	font-size: 16pt;
}
fieldset:not(:has(legend)) {
	margin-top: 1rem;
}

legend {
	/*background: var(--theme-accent-color--primary--c1);*/
	color: var(--theme-reference-color--inverted);
	font-family: "Pixel Operator Mono", "Unifont", monospace;
	font-size: 20pt;
	font-weight: bold;
	padding: 2px 8px;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-shadow: 0 1px 0 var(--theme-shadow-color--soft);
	white-space: nowrap;
}

nav > a, nav > b {
	display: block;
	text-align: center;
	padding: 3px 4px;
	font-size: 16pt;
	text-decoration: none;
	border: 2px solid transparent;
}

nav > a {
	color: var(--theme-accent-color--primary--c2);
}

nav > b {
	color: var(--theme-reference-color--inverted);
}

nav a:hover {
	--theme-nav-color--hover: color-mix(
		in srgb,
		var(--theme-warning-color--c1) 4%,
		transparent
	);
	border: 2px dotted var(--theme-link-color--hover);
	color: var(--theme-link-color--hover);
	background: var(--theme-nav-color--hover);
	text-decoration: none;
}

table {
	--theme-tableheader-color: color-mix(
		in srgb,
		var(--theme-accent-color--primary--c1) 55%,
		var(--theme-accent-color--primary--c0)
	);
	width: calc(100% + 24px);
	border-collapse: collapse;
}

fieldset table {
	margin: -9px -12px;
}

table caption {
	background: var(--theme-accent-color--primary--c1);
	color: var(--theme-accent-color--primary--c0);
	font-family: "Pixel Operator Mono", "Unifont", monospace;
	font-size: 20pt;
	font-weight: bold;
	padding: 3px 9px;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-shadow: 0 1px 0 var(--theme-shadow-color--soft);
	border-bottom: 1px solid var(--theme-accent-color--primary--c1);
}

fieldset:nth-child(even) table caption {
	border-color: var(--theme-accent-color--secondary--c1);
}

table tr {
	border-top: 1px solid var(--theme-accent-color--primary--c1);
}

table tr:first-child {
	border-top: none;
}

table th {
	background-color: var(--theme-tableheader-color);
	color: var(--theme-accent-color--primary--c0);
	font-family: "Pixel Operator Mono 8", "Unifont", monospace;
	font-weight: bold;
	font-size: 10px;
	padding: 8px 12px;
	text-align: center;
	text-transform: uppercase;
	vertical-align: middle;
	text-shadow: 0 1px 0 var(--theme-shadow-color--soft);
	line-height: 1.6;
}

table td {
	padding: 8px 12px;
	font-size: 13pt;
	line-height: 1.4;
}

.float-right {
	float: right;
}

.clear {
	clear: both;
}

.fill-width {
	width: 100%;
}

.fill-height {
	width: 100%;
}

.infobox {
	float: right;
	width: clamp(20%, 50%, 200px);
	margin: 0 0 10px 20px;
}

.badges {
	display: grid;
	grid-template-columns: repeat(2, 50%);
	grid-auto-flow: row;
	gap: 4px;
	padding: 2px;
}

.badges > * {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 31px;
	border: 1px solid var(--theme-accent-color--primary--c1);
	font-family: "Pixel Operator Mono 8", "Unifont", monospace;
	font-size: 5px;
	font-weight: bold;
	text-align: center;
	line-height: 1.5;
	padding: 2px 4px;
	text-decoration: none;
	box-shadow: 2px 2px 0 var(--theme-shadow-color--hard);
}

.badges > *:hover {
	text-decoration: none;
}

.red { color: var(--theme-danger-color--c1); }
a.red:hover { color: var(--theme-danger-color--c2); }
.badges > .red { background: var(--theme-danger-color--c0); color: var(--theme-danger-color--c1); border-color: var(--theme-danger-color--c1); }
.badges > .red:hover { color: var(--theme-danger-color--c2); border-color: var(--theme-danger-color--c2); }

.gold { color: var(--theme-warning-color--c1); }
a.gold:hover { color: var(--theme-warning-color--c2); }
.badges > .gold { background: var(--theme-warning-color--c0); color: var(--theme-warning-color--c1); border-color: var(--theme-warning-color--c1); }
.badges > .gold:hover { color: var(--theme-warning-color--c2); border-color: var(--theme-warning-color--c2); }

.green { color: var(--theme-success-color--c1); }
a.green:hover { color: var(--theme-success-color--c2); }
.badges > .green { background: var(--theme-success-color--c0); color: var(--theme-success-color--c1); border-color: var(--theme-success-color--c1); }
.badges > .green:hover { color: var(--theme-success-color--c2); border-color: var(--theme-success-color--c2); }

.blue { color: var(--theme-info-color--c1); }
a.blue:hover { color: var(--theme-info-color--c2); }
.badges > .blue { background: var(--theme-info-color--c0); color: var(--theme-info-color--c1); border-color: var(--theme-info-color--c1); }
.badges > .blue:hover { color: var(--theme-info-color--c2); border-color: var(--theme-info-color--c2); }

.gallery {
	display: flex;
	flex-wrap: wrap;
	padding: 4px;
	box-shadow: none;
	justify-content: center;
}

/* credit for the polaroid photo effect
https://www.w3docs.com/snippets/css/how-to-create-polaroid-image-with-css.html
https://codepen.io/Wandersonsc/pen/RMerRy
*/
figure {
	background: var(--theme-figure-color--c0);
	display: inline-flex;
	margin: 12px 8px 2px;
	padding: 5px 5px 18px;
	font-size: 6pt;
	font-family: "Pixel Operator Mono 8", "Unifont", monospace;
	text-align: center;
	text-wrap: balance;
	text-decoration: none;
	-webkit-box-shadow: 0 0 3px var(--theme-shadow-color--hard);
	-moz-box-shadow: 0 0 3px var(--theme-shadow-color--hard);
	box-shadow: 0 0 3px var(--theme-shadow-color--hard);
	-webkit-transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
	-moz-transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
	transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
	flex-direction: column;
	align-items: center;
	width: fit-content;
	gap: 0;
	z-index: 0;
	position: relative;
}
 
figcaption {
	color: var(--theme-figure-color--c2);
	position: absolute;
	bottom: 4px;
	left: 0;
	width: 100%;
}
 
figure:hover {
	-webkit-transform: translateY(-12px) rotate(0deg) scale(1.1) !important;
	-moz-transform: translateY(-12px) rotate(0deg) scale(1.1) !important;
	transform: translateY(-12px) rotate(0deg) scale(1.1) !important;
	-webkit-box-shadow: 1px 6px 2px var(--theme-shadow-color--hard);
	-moz-box-shadow: 1px 6px 2px var(--theme-shadow-color--hard);
	box-shadow: 1px 6px 2px var(--theme-shadow-color--hard);
	z-index: 1;
}

figure:nth-child(8n) { transform: rotate(0.78deg); }
figure:nth-child(8n+1) { transform: rotate(-0.81deg); }
figure:nth-child(8n+2) { transform: rotate(1.32deg); }
figure:nth-child(8n+3) { transform: rotate(-1.02deg); }
figure:nth-child(8n+4) { transform: rotate(0.86deg); }
figure:nth-child(8n+5) { transform: rotate(-1.25deg); }
figure:nth-child(8n+6) { transform: rotate(0.05deg); }
figure:nth-child(8n+7) { transform: rotate(-0.79deg); }
 
figure img {
	border: none;
	display: block;
	height: 112px;
	width: auto;
	min-width: calc(112px * 4/5);
	max-width: calc(112px * 16/9);
	object-fit: contain;
	object-position: center;
	filter: none;
	transition: none;
	image-rendering: pixelated;
}

img {
	image-rendering: pixelated;
}

a {
	--theme-link-color--hover: color-mix(
		in srgb,
		var(--theme-accent-color--primary--c2) 60%,
		var(--theme-accent-color--primary--c1)
	);
	color: var(--theme-accent-color--primary--c2);
	text-decoration: none;
}
a:hover { color: var(--theme-link-color--hover); text-decoration: underline; }
a:active { color: var(--theme-reference-color--inverted); }
a:visited { color: var(--theme-accent-color--tertiary--c1); }
a:visited:hover { color: var(--theme-accent-color--tertiary--c2); }

a img {
	display: block;
	transition:
		transform 0.2s ease,
		filter 0.2s ease;
	-webkit-filter: drop-shadow(0 0 3px var(--theme-shadow-color--hard));
	filter: drop-shadow(0 0 3px var(--theme-shadow-color--hard));
}

a:hover img {
	transform: scale(1.08) rotate(3deg);
	-webkit-filter: drop-shadow(4px 6px 2px var(--theme-shadow-color--hard));
	filter: drop-shadow(4px 6px 2px var(--theme-shadow-color--hard));
}

a:hover figure {
	background: var(--theme-figure-color--c1);
}

a:hover figcaption {
	color: var(--theme-figure-color--c3);
	text-decoration: 1px solid;
}

a:hover figure img {
	transition: transform none, filter none;
	-webkit-filter: none;
	filter: none;
	transform: none;
}

h1, h2, h3, h4 {
	color: var(--theme-accent-color--secondary--c2);
	font-family: "Pixel Operator Mono", "Unifont", monospace;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.2;
	text-shadow: 0 1px 0 var(--theme-shadow-color--soft);
	padding-left: 8px;
	border-bottom: 1px solid;
	border-image: linear-gradient(to right, var(--theme-accent-color--secondary--c2), transparent) 1;
}

h1, h2 {
	margin-top: 14px;
	margin-bottom: 12px;
	text-transform: uppercase;
	padding-bottom: 2px;
	border-bottom-width: 2px;
}

h1 {
	font-size: 20pt;
}

h2 {
	font-size: 16pt;
}

h3, h4 {
	margin-top: 10px;
	text-transform: lowercase;
	padding-bottom: 1px;
	border-bottom-width: 1.5px;
}

h3 {
	font-size: 16pt;
	margin-bottom: 8px;
}

h4 {
	font-size: 12pt;
	margin-bottom: 6px;
}

hr {
	border: none;
	border-bottom: 2px solid;
	border-image: linear-gradient(to right, var(--theme-reference-color--inverted) 50%, transparent) 1;
}

p {
	margin: 6px;
	text-align: justify;
    text-justify: inter-word;
}

p + p {
	margin-top: 12px;
}

ul, menu, ol {
	margin: 0;
	padding: 0;
}

ul > li, menu > li {
	font-size: 12pt;
	margin-bottom: 1px;
	margin-left: 16px;
}

ul > li::marker, menu > li::marker {
	content: "- ";
	color: var(--theme-accent-color--secondary--c2);
}

dl {
	list-style: none;
	padding: 0;
	margin: 0;
}

dt {
	font-family: "Pixel Operator 8", "Unifont", sans-serif;
	font-weight: bold;
	line-height: 0.8;
	padding: 4px 0 2px 0;
	border-bottom: 1px solid;
	border-image: linear-gradient(to right, var(--theme-accent-color--secondary--c2), transparent) 1;
	color: var(--theme-accent-color--secondary--c2);
	font-size: 6pt;
}

dd {
	font-size: 12pt;
	margin-bottom: 1px;
	margin-left: 16px;
}

strong, .wavy {
	font-weight: inherit;
}


em, .shaky {
	display: inline-block;
	font-style: inherit;
}

s, .blink {
	display: inline-block;
	text-decoration: inherit;
}

u, abbr {
	text-decoration-thickness: 2px;
}

mark, .marked {
	background-color: var(--theme-marker-color--c0);
	color: var(--theme-marker-color--c1);
}

.redacted {
	background-color: var(--theme-reference-color);
	color: transparent;
	user-select: none;
	white-space: nowrap;
}

rt {
	font-family: "Pixel Operator 8", "Unifont", sans-serif;
	font-size: 35%;
}

tag-[type="new"] {
	font-family: "Pixel Operator 8", "Unifont", monospace;
	font-size: 5pt;
	background: var(--theme-warning-color--c1);
	color: var(--theme-reference-color--inverted);
	padding: 2px 4px;
	margin-right: 0.25em;
	vertical-align: middle;
	box-shadow: 1px 1px 0 var(--theme-warning-color--c0);
}

tag-[type="new"]::before {
	content: "NEW";
}