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

body
{
	/* background: linear-gradient(to bottom, #1c1c42 0%, #24114a 100%); */
	min-height: 100%;
	/* background:
	radial-gradient(circle at 2.01% 42.91%, #1b4e8b, transparent 100%),
	radial-gradient(circle at 97.99% 67.91%, #201971, transparent 100%),
	radial-gradient(circle at 50% 50%, #255c72, #10586b 100%); */
	font-family: "Outfit", serif;
	font-size: 20px;
	background-repeat: no-repeat;
	background-attachment: fixed;


  background: linear-gradient(to top, #000066 0%, #167096FF 100%);
  background-size: 100%;
  background-attachment: fixed;

}



/************ DOCUMENT FORMATTING ************/


p, li
{
	font-weight: 300;
	line-height: 1.3;
}

li
{
	margin-bottom: 8px;
}

pre
{
	font-size: .9rem;
	background: linear-gradient(30deg, rgba(255, 255, 192, 0.12) 0%, rgba(255, 255, 255, 0.18) 100%);
    padding: 8px 30px;
    /*border-radius: 10px;*/
    box-shadow: 1px 3px 8px rgba(0, 0, 0, 0.13);
    border-left: 3px solid rgba(255, 255, 255, 0.2);
    /*border-top-right-radius: 10px;*/
	line-height: 1.2rem;
}

code
{
	font-size: .9rem;
}


.document
{
	background: #eeeee8;
	padding: 1rem 3rem;
	backdrop-filter: blur(8px);
	margin-top: none;
	min-height: 100vh;
}


.main-container
{
	max-width: 60rem;
	margin-left: auto;
	margin-right: auto;
	box-shadow: 6px 6px 18px rgba(26, 24, 75, 0.3);
}

blockquote
{
	border-left: 3px solid black;
	font-style: italic;
	background-color: #fdfdfd;
	padding: 1px 12px 1px 16px;
	margin-left: 0;
	box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.1);
}



.container
{
    display: inline-block;
    text-align: left;
    width: 60rem;
    /*border-radius: 4px;*/
    z-index: 0;
	padding-bottom: 2rem;
}


h1
{
	font-weight: 900;
}

h2
{
	font-weight: 700;
}




/************ HEADERS ************/



.header-top
{
	padding: 0.6rem 3rem;
	/* background: linear-gradient(45deg, #512d18 0%, #4b3b0f 100%); */
	background-color: rgb(0, 75, 173);
	color: white;
	font-size: 32px;
	font-weight: 600;
	text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
	margin-top: 0.5rem;
}

.header-bottom
{
	padding: 0.3rem 3rem;
	/* background: linear-gradient(45deg, #683e26 0%, #6f5a1f 100%); */
	background-color: rgb(22, 100, 189);
	color: white;
	font-size: 18px;
	font-weight: 300;
	text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
}


.header-bottom a, .header-admin a
{
	color: white;
	text-decoration: none;
	margin-right: 16px;
}

.header-top a
{
	color: white;
	text-decoration: none;
}


.portfolio-category
{
	color: white;
	margin-top: 4rem;
	text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.2),
	1px 1px 4px rgba(0, 0, 0, 0.3);
}



/************ TABLES ************/

table
{
	border: 1px solid rgb(255, 252, 222);
	border-collapse: collapse;
	background-color: white;
	font-weight: 300;
	box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.1);
}

thead
{
	padding: 1rem;
	background: linear-gradient(45deg, #145a9c 0%, #1b7193 100%);
	color: white;
	font-size: 18px;
	font-weight: 300;
	text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
	text-align: left;
}

th
{
	font-weight: 600;
	border: 1px solid #4f96a6;
}

td
{
	border: 1px solid rgb(209, 199, 169);
}

th, td
{
	padding: 8px 12px;
}


td:has(> .red)
{
	background-color: #f77272;
	font-weight: 700;
	text-shadow: 0 0 5px #f3adad;
}

td:has(> .yellow)
{
	background-color: #f1a548;
	font-weight: 700;
	text-shadow: 0 0 5px #f2c48b;
}


td:has(> .lime)
{
	background-color: #d2fb40;
	font-weight: 700;
	text-shadow: 0 0 5px #e4f79e;
	
}

td:has(> .green)
{
	background-color: #40fb4a;
	font-weight: 700;
	text-shadow: 0 0 5px #b1f5b4;
}



/************ TOPMENU ************/

.topmenu
{
    width: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    color: white;
    
    display: block;
    overflow: hidden;
    padding-top: 1em;
    padding-bottom: 1em;
    box-shadow: .3em .3em .3em rgba(0, 0, 0, 0.1);
    z-index: 1000;
	border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}


.topmenu a
{
    color: inherit;
    text-decoration: inherit;
}

.topmenu a:hover
{
    text-decoration: underline;
}

.topmenuitem
{
    display: inline-block;
    font-size: 1em;
    margin-right: 2em;
    text-shadow: 0.1em 0.1em 0 rgba(0, 0, 0, 0.4);
    font-weight: 300;
}

.topmenuheader
{
    float: left;
    font-size: 2em;
    font-weight: 700;
    text-shadow: 0.05em 0.05em 0 rgba(0, 0, 0, 0.4);
    margin-top: -0.2em;
}

.topmenuoptions
{
    display: inline-block;
    color: white;
    position: relative;
    top: 0.5em;
    margin-right: 2em;
}




/************ PORTFOLIO ************/

.portfolio
{
	padding: 1rem 2rem;
	margin-top: 2rem;
	background-color: #efeeee;
	box-shadow: 2px 2px 14px rgba(0, 0, 0, 0.205);
	border: 1px solid white;
}

a.portfolio-link:link, a.portfolio-link:visited
{
	color: black;
	text-decoration: none;
}





/************ DEV ************/

.dev-warning
{
	color: red;

	animation-name: devwarning;
	animation-duration: 1s;
	animation-iteration-count: infinite;
}

@keyframes devwarning
{
	0%
	{
		color: red;
		text-shadow: 0 0 0 #00000000;
	}
	25%
	{
		color: yellow;
		text-shadow: 0 0 12px #ffff00ff;
	}
	50%
	{
		color: red;
		text-shadow: 0 0 0 #00000000;
	}
	100%
	{
		color: red;
		text-shadow: 0 0 0 #00000000;
	}
}



.dev-border
{
	border: 2px solid red;

	animation-name: devborder;
	animation-duration: 1s;
	animation-iteration-count: infinite;
}

@keyframes devborder
{
	0%
	{
		border: 2px solid red;
	}
	25%
	{
		border: 2px solid rgb(234, 255, 0);
	}
	50%
	{
		border: 2px solid red;
	}
	100%
	{
		border: 2px solid red;
	}
}


h2.comingsoon, p.comingsoon
{
	filter: blur(2px);
}

div.comingsoon
{
	background-color: #ccc;
	position: relative;
}

.comingsoon-banner
{
	position: absolute;
	z-index: 1000;
	font-size: 48px;
	color: yellow;
	left: 50px;
	top: 50px;
	transform: rotateZ(-10deg);
	text-shadow: 2px 2px 3px black;
}