/* based on cyanobacteria from https://ribo.zone/free/layouts/ */

@font-face{
  font-family: 'TimesNewPixel';
  src: url('http://goob.spot/media/assets/TimesNewPixel.ttf');
}

@font-face{
  font-family: 'ChiKareGo';
  src: url('http://goob.spot/media/assets/ChiKareGo.ttf');
}

@keyframes marquee-content {
	from {
		transform: translateX( 0% );
	}
	to {
	  /* -(number of buttons) x 100 */
		transform: translateX(-2200%);
	}
}

@keyframes colorShift {
  from {background-color: rgba(0,0,55,0.6)}
  50% {background-color: rgba(0,0,55,0.1)}
  to {background-color: rgba(0,0,55,0.6)}
}

.rainbowGradient {
  background: linear-gradient(to right, #ef5350, #f48fb1, #7e57c2, #2196f3, #26c6da, #43a047, #eeff41, #f9a825, #ff5722);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; 
}

.ascii-art {
  white-space: pre;
}

.marquee {
  display: flex;
	overflow: hidden;
	white-space: nowrap;
	width: 100%;
}

.marquee_item {
  width:88px;
	height:31px;
  flex-shrink: 0;
  display: flex;
  justify-content: space-around;
	animation-duration: 30s;
	animation-iteration-count: infinite;
	animation-name: marquee-content;
	animation-timing-function: linear;
	padding: 0px 0px 0px 0px;
}

.marquee:hover .marquee_item {
	animation-play-state: paused;
}

.photo {
  border: 10px solid transparent;
  border-image: url('/media/assets/border2.png') round 8;
}

img.photo:hover {
  cursor: url('/media/assets/cursor2.png'), pointer;
}

:root {
	--text: #D0DFF7;
	--border: DodgerBlue;
	--accent: #5fcbff;
	--bg: rgba(0,10,50,.4);
	--gradientBottom: midnightblue;
	--gradientTop: DarkSlateBlue;
}

textarea {
  font-family: 'TimesNewPixel';
  background-color: var(--bg);
  color: var(--text); 
  border: 1px solid #61afef;
}

a:link { 
  color: lightblue 
}

a:hover, a:focus {
	font-style: italic;
	cursor: url('/media/assets/cursor2.png'), pointer;
}

a:visited {
	color: var(--accent);
}

input:hover {
  cursor: url('/media/assets/cursor2.png'), pointer;
}


header {
	background: url('/media/assets/header.gif');
	font-family: 'ChiKareGo';
}

* { 
	box-sizing: border-box;
}

body {
	font-family: 'TimesNewPixel', sans-serif;
	letter-spacing: -1px;
	transform: translateX(0.25px);
	margin:0;
	padding:0;
	font-size: 16px;
	font-weight: normal;
	color: var(--text);
	background-color: rgba(0,0,0,0.1); 
	background-blend-mode: multiply;
	background-image: url('/media/assets/cloud tiles.gif');
	background-position: 0 0, 0 0, 10px 18px, 10px 18px, 0 0, 10px 18px;
	cursor: url('/media/assets/cursor.png'), default;
	animation: colorShift 60s infinite;
}

.darkBG {
  background-color: rgba(0,0,0,0.7);
  background-blend-mode: multiply;
  animation: none;
}

.brokenBG {
  background-image: url('/media/assets/cloud tiles broken.gif');
  background-color: rgba(0,0,255,0.6);
  background-blend-mode: difference;
  animation: colorShift 40s infinite;
}
.container {
	max-width: 880px;
	margin: 48px auto 12px auto;
	border: 6px ridge var(--border);
	outline: 3px solid rgba(100, 150, 245, 0.5);
	outline-offset: 4px;
	border-radius: 10px;
	display: flex;
	flex-wrap: wrap;
	padding: 5px;
	gap: 5px;

	/* container background pattern */
	background-color: var(--gradientBottom);
	background-image:  repeating-radial-gradient( circle at 0 0, transparent 0, var(--gradientBottom) 9px ), repeating-linear-gradient( var(--bg), var(--bg));
	background-blend-mode: multiply;
}

/* these control the column widths */
.small { flex: 1 1 9%; }
.large { flex: 1 1 69%; }
.full { flex: 1 1 100%; }
.half { flex: 1 1 49%; }

header {
	background-size: cover;
	background-position: center;
	width: 100%;
	height: 120px; /* change banner height here*/
	border: 2px ridge var(--border);
	border-radius: 5px;
	position: relative;
}

header span {
	font-size: round(up, 2rem);
	position: absolute;
	bottom: 0;
	right: 8px;
	margin: 8px;
	font-weight: bold;
	text-shadow: 1px 1px var(--text),
		-1px 1px var(--text),
		1px -1px var(--accent),
		-1px -1px var(--accent);
	color: var(--gradientTop);
}

nav {
	border: 2px ridge var(--border);
	border-radius: 4px;
	padding: 4px;
	background: linear-gradient(var(--gradientTop),var(--gradientBottom));
}
nav div {
	text-align: center;
	font-family: ChiKareGo;
	font-size: 24px;
}

.horNav a {
  display: inline-block;
}

nav a {
	display: block;
	margin: 4px;
	background: linear-gradient(to right,var(--bg),var(--gradientBottom));
	border-radius: 4px;
	padding: 2px 7px;
	text-decoration: none;
}

nav a:link, nav a:visited { 
	color: var(--text);
}

nav a:hover, nav a:focus {
	background: linear-gradient(to right,var(--bg), var(--gradientBottom), var(--gradientTop));
}

div.small > img {
	display: block;
	margin: 4px auto;
	border:2px ridge var(--border);
	border-radius: 4px;
}

section {
	border: 2px ridge var(--border);
	border-radius: 4px;
	background: linear-gradient(var(--gradientTop),var(--gradientBottom));
	padding:8px;
}

footer {
	text-align: center;
	padding-bottom:4px;
	font-size: 16px;
}

footer a { 
	text-decoration: none;
}

h1, h2, h3, h4, h5, h6, p { 
	margin: 4px;
	line-height: 1;
}

h1 { 
  font-family: ChiKareGo;
	font-size: 32px;
	font-weight: normal;
	text-align: center;
	border-bottom: 2px ridge var(--border);
	padding-bottom: 8px;
}

h2 { 
  font-family: ChiKareGo;
	font-size: 24px;
	font-weight: normal;
	text-align: center;
}

h3 { 
  font-family: ChiKareGo;
	font-size: 22px;
}

h4 { 
  font-family: ChiKareGo;
	font-size: round(up, 1rem);
	color: var(--accent);
	padding-left: 12px;
}

img { 
  max-width: 100%; 
}

pre { 
  overflow-x: auto; 
}