/* Portfolio Website for Sebastian Zhang */
/* Copyright 2021 Sebastian Zhang */

/* GLOBAL SETTINGS */
/* Variables */
:root {
	--primary-color: #FFFFFF;
	--background-color: #000000;
	--accent-color: #9eff36;
	--medium-accent-color: #C7C7C7;
	--light-accent-color: #121212;
	--alert-color: #FF0000;
	--highlight-color: #2c381f;

	--yellow-color: #FFD000;
	--blue-color: #00D5FF;
	--pink-color: #FF00E1;
	--purple-color: #A106FB;
	
	--font-size-default: calc(16px + .2vw);
	--font-size-fallback: 16px;
	--font-size-mono: calc(13px + .2vw);
	--default-font: jost, sans-serif;
	--mono-font: jetbrains-mono, monospace;
	
	--default-width: 60%;
	--home-logo-width: 40%;
	--logo-width: 50%;
}

/* Default Font */
body {
	font-family: var(--default-font);
	background-color: var(--background-color);
	color: var(--primary-color);
	
	background-image: url(media/background-2.jpg);
background-attachment: fixed;
background-repeat: no-repeat; 
	background-size: 100%;
	text-shadow: -1px -1px 5px black, 1px 1px 5px black, -1px 1px 5px black, 1px -1px 5px black;


}

/* Text Highlighting - Webkit/Blink Browsers Only */
::selection {
	background: var(--primary-color); 
	color: var(--background-color);
		text-shadow: none;

}

/* Text Modifiers */
.bold {
	font-weight: bold;
}
.italic {
	font-style: italic;
}
.light {
	font-weight: 300;
}
.invert {
	color: var(--background-color); 
	background-color: var(--primary-color); 
	padding: 4px;
}
.invert::selection {
	background: var(--accent-color);
}
.mark {
	background-color: var(--accent-color);
}
.color-accent {
	color: var(--accent-color);
}
.color-medium-accent {
	color: var(--medium-accent-color);
}
.color-light-accent {
	color: var(--light-accent-color);
}
.indent {
	margin-left: 4vw;
}

/* Font Loading 
@font-face {
	font-family: barlow;
	src: url(fonts/Barlow/Barlow-Regular.woff2);
}
@font-face {
	font-family: barlow;
	src: url(fonts/Barlow/Barlow-Italic.woff2);
	font-style: italic;
}
@font-face {
	font-family: barlow;
	src: url(fonts/Barlow/Barlow-Bold.woff2);
	font-weight: bold;
}
@font-face {
	font-family: barlow;
	src: url(fonts/Barlow/Barlow-BoldItalic.woff2);
	font-weight: bold;
	font-style: italic;
}
@font-face {
	font-family: barlow;
	src: url(fonts/Barlow/Barlow-Light.woff2);
	font-weight: 300;
}
@font-face {
	font-family: barlow;
	src: url(fonts/Barlow/Barlow-LightItalic.woff2);
	font-weight: 300;
	font-style: italic;
}
@font-face {
	font-family: jetbrains-mono;
	src: url(fonts/JetBrains-Mono/JetBrainsMono-Regular.woff2);
}
*/

/* Load Animation */
@keyframes fade-in {
	from {opacity: 0%;}
	to {opacity: 100%;}
}


/* Links */
a {
	text-decoration: none;
	text-decoration-color: var(--accent-color);
	text-decoration-thickness: 0px;
	text-underline-offset: 6px;
	color: var(--accent-color);
	transition: .5s;
}
a:hover {
	text-decoration: none;
	background-color: var(--highlight-color);
	text-shadow: none;

}

.buttonlink:hover {
	text-decoration: none;
	background-color: transparent;

}

/* iframes - Used for YouTube Embedded Content */
.youtube {
	border: none;
	height: 65vh;
	width: 100%;
	resize: both;
	overflow: auto;
	margin: 0 auto;
}

.youtubewrap {
	height: 100; 
	text-align: center;
}

/* Paragraphs */
p {
	line-height: 1.5;
}

/* LOCAL SETTINGS */
/* Header */
.home-header {
	padding: 20px 0 20px 0;
}
.header {
	padding: 20px 0 0 0;
}
.home-logo {
	display: block;
	margin: auto;
	width: var(--home-logo-width);
	height: 10%;
}
.logo {
	display: block;
	margin: auto;
	width: var(--logo-width);
	height: 10%;
	fill: var(--primary-color);
	transition: .5s;
}
.logo:hover {
	fill: var(--accent-color);
}
/* Navigation */
.navigation {
	display: block;
	margin: auto;
	width: var(--default-width);
	padding: 0 0 10px 0;
	text-align: center;
	
	font-size: var(--font-size-fallback);
	font-size: var(--font-size-default);
}

/* Content */
.content {
	display: block;
	width: var(--default-width);
	margin: auto;
	
	font-size: var(--font-size-fallback);
	font-size: var(--font-size-default);

	animation-name: fade-in;
	animation-duration: 1s;
}

.images {
	display: block;
	width: 100%;
	margin: auto;
}

.profile {
	display:flex;
	flex-wrap: wrap;
	text-align: center;
	justify-content: center;
}

.profile > div {
	padding: 10px;
	margin: 10px;
	text-align: center;
}
.profile-img {
	width: 200px;
    filter: drop-shadow(0px 0px 20px black);
	float:left; padding:10px 25px;
}

/* Payment Button */
.payment-button {
	border: 0;
	line-height: 1.5;
    padding: 10px 20px;
	text-align: center;
	width: auto;
	
	border-radius: 5px;
	
	font-size: var(--font-size-fallback);
	font-size: var(--font-size-default);
	
	font-family: var(--default-font);
	
	color: var(--background-color);
	background-color: var(--primary-color);
	transition: .5s;
}	
.payment-button:hover {
	background-color: var(--accent-color);
	cursor: pointer;
}

/* Focus Button */
.focus-button {
	line-height: 1.5;
	margin: 10px 10px;
    padding: 10px 20px;
	text-align: center;
	width: auto;
	
	border-style: solid;
	border-width: 2px;
	border-color: var(--primary-color);
	
	font-size: var(--font-size-fallback);
	font-size: var(--font-size-default);
	
	font-family: var(--default-font);
	
	color: var(--primary-color);
	background-color: transparent;
	transition: .5s;
}	
.focus-button:hover {
	background-color: var(--primary-color);
	color: var(--background-color);
	cursor: pointer;
}

/* For the linktree-style buttons on homepage*/
.home-button-container{
	display: flex;
	justify-content: center;
  flex-wrap: wrap;
}
.home-button {
	line-height: 1.5;
    padding: 10px 20px;
	text-align: center;
	margin: 10px 20px;

	
	border-style: solid;
	border-width: 2px;
	border-color: var(--primary-color);
	
	font-size: var(--font-size-fallback);
	font-size: var(--font-size-default);
	
	font-family: var(--default-font);
	
	color: var(--primary-color);
	background-color: transparent;
	transition: .5s;
}	
.home-button:hover {
	background-color: var(--primary-color);
	color: var(--background-color);
	cursor: pointer;
}

/* Footer */
.footer {
	padding: 25px 0 25px 0;
}
.social-icon-table {
	margin: auto;
	width: 10%;

}
.social-icon-cell {
	padding: 8px;

}
.social-icon {
	display: block;
	margin: auto;
	width: 20px;
	height: 20px;
	
	fill: var(--primary-color);
	transition: .5s;
}
.social-icon:hover {
	fill: var(--accent-color);
}

.social-icon-table-profile {
	margin: 0;
	padding-top: 2px;
	width: auto;
	display:inline-table;


}

/* 404 and 403 Errors */

.page-error {
	padding: 10px;
	margin: auto;
	width: 50%;
	text-align: center;
	border-radius: 5px;
	
	color: var(--background-color);
	background-color: var(--primary-color);
}
.page-error::selection {
	background-color: var(--accent-color);
}


/* Development Warning */
.warning {
	position: fixed;
	top: 0;
	left: 0;
	height: auto;
	width: 100%;
	padding: 10px 0 10px 0;
	
	line-height: 1.5;
	text-align: center;
	
	color: var(--background-color);
	background-color: var(--alert-color);
}
.warning::selection {
	background-color: var(--primary-color);
}

/* Redirects */
.redirect {
	text-align: center;
	padding: 40px;
}

/* RESPONSITIVITY */
/* Smartphones */
@media only screen 
and (any-hover: none) {
	.youtube {
		height: 22.5vh;
		width: 100%
	}
	.logo {
		width: 85%;
	}
	.navigation {
		width: 90%;
	}
	.content {
		width: 90%;
	}
	.home-button {
		width: 90%;
	}
	.home-button-container{
	display: block;

}
	.screenshot {
		width: 100%;
	}
	.profile-img {
	width: 85%;
	float:none; 
	padding:10px 25px;
}
body {
	background-image: url(media/background-mobile.jpg);
}


}

/* Tablets - Portrait 
@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) 
and (orientation : portrait) {
	.youtube {
		height: 37vh;
		width: 100%
	}
	.logo {
		width: 50%;
	}
	.home-logo {
		width: 50%;
	}
	.navigation {
		width: 90%;
	}
	.content {
		width: 90%;
	}
	.home-button {
		width: 50%;
	}
	body {
		background-size: 240%;
		background-position: -400px -100px;
	}
}*/

/* Tablets - Landscape 
@media only screen 
and (min-device-width : 768px) 
and (max-device-width : 1024px) 
and (orientation : landscape) {
	.youtube {
		height: 45vh;
		width: 100%
	}
	.logo {
		width: 60%;
	}
	.home-logo {
		width: 60%;
	}
	.navigation {
		width: 60%;
	}
	.content {
		width: 60%;
	}
	.home-button {
		width: 60%;
	}
}
*/