@font-face {
	font-family: 'main-font';
	src: url('../fonts/Oswald-Regular.ttf')
	/*src: url('../fonts/Teko-Regular.ttf');*/
}

@font-face {
	font-family: 'main-font-bold';
	src: url('../fonts/Oswald-Bold.ttf')
	/*src: url('../fonts/Teko-Regular.ttf');*/
}

* {
	scroll-behavior: smooth;
}

body {
	margin: 0px;
	background-color: rgb(0,0,0);
	
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	background-image: url('../images/bg_0.jpg');
	
	font-family: 'main-font';
	font-size: 1em;
}

a {
	text-decoration: none;
}
a:link {
	
}
a:visited {
	
}
a:focus {
	
}
a:hover {
	
}
a:active {
	
}

.box {
	background-color: rgb(240,240,240);
	border-radius	: 4px;
	border-width: 1px;
	border-style: solid;
	border-color: rgb(150,150,150);
	min-width: 100px;
	min-height: 200px;
	/*max-width: 400px;*/
	max-height: 300px;
	padding: 10px;
	margin: 50px;
	box-sizing: border-box;
}

.bg_grad {
	background-image: url('../images/gradient.png');
	background-repeat: repeat-x;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 200px;
	/*z-index: -1;*/
}

.bg_grad_hl {
	background-image: url('../images/gradient_hl.png');
	background-repeat: repeat-x;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 200px;	
	z-index: -1;
}

.panel_master {
	display: flex;
	flex-direction: column;
	position: relative;
	/*height: calc((4 * 100vh) - 50vh);*/
}

.panel {
	background-color: rgb(220,220,220);
	width: 100%;
	height: 100vh;
	box-sizing: border-box;
	position: relative;
	top: 50vh;
}

.cover {
	width: 100%;
	height: calc(100vh - 50px);
	position: absolute;
	top: 0px;
	left: 0px;
	background-color: #132234;
	z-index: 99;
	/*transition: top 0.5s;*/
}

.cover_animation {
	animation-name: cover_bump;
	animation-timing-function: ease-in-out;
	animation-duration: 1.25s;
	animation-delay: 1.3s;
	animation-iteration-count: 1;
	animation-direction: normal;
	animation-fill-mode: both;
}

@keyframes cover_bump {
	0% {
		top: 0px;
	}	
	25% {
		top: -30px;
	}
	50% {
		top: -15px;
	}
	70% {
		top: -25px;
	}
	100% {
		top: 0px;
	}
}

.cover_shadow {
	top: calc(100vh - 50px);
	height: 100px;
	background-size: contain;
}

#cover_bottom {
	position: absolute;
	bottom: -50px;
	height: 54px;
	left: 0px;
	width: calc(100% - 50px);
	background-color: #132234;
	z-index: 99;
}

#cover_dog_ear {
	position: absolute;
	bottom: -50px;
	height: 52px;
	right: 0px;
	width: 50px;
	z-index: 100;
	background-image: url('../images/dog_ear@2x.png');
	background-position:top left;
	background-size: cover;
	background-repeat: no-repeat;
	
	cursor: pointer;
}

#gregcopin {
	width: 100%;
	color: rgb(250,250,250);
	position: relative;
	left: 5px;
}

#gregcopin::after {
	content: ' ';
	width: 15px;
	height: 15px;
	
	/*border-radius: 10px;*/
	/*border-width: 1px;*/
	/*border-style: solid;*/
	
	color: rgb(200,200,200);
	background-image: url('../images/more_info@2x.png');
	background-size: cover;
	background-repeat: no-repeat;
	/*background-color: rgb(70,120,30);*/
	position: relative;
	top: -10px;
	right: -5px;
	font-size: 14px;
	display: inline-block;
	/*font-family: 'main-font-bold';*/
	
	animation-name: contact_alert;
	animation-timing-function: ease-in-out;
	animation-duration: 1s;
	animation-delay: 1.25s;
	animation-iteration-count: 1;
	/*animation-direction: alternate;*/
	animation-fill-mode: backwards;
}

@keyframes contact_alert{
	0% {
		opacity: 0%;
	}
	1% {
		opacity: 100%;
		top: -10px;
		transform: scale(.1,.1);
	}
	10% {
		transform: scale(1.2,1.2);
	}
	25% {
		transform: scale(1,1);
		top: -25px;
	}
	50% {
		top: -10px;
	}
	75% {
		top: -12.5px;
	}
	100% {
		top: -10px;
	}
}

.panel_first {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	padding-top: 100px;
	margin-top: -100px;
	height: calc(100vh + 50px);
}

.panel_image {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

:root {
	--info_box_text_height: 1.25em;
}

.info_box_master {
	display: flex;
	flex-direction: column;
	align-items: center;
	
	width: 50vw;
	/*min-width: 250px;*/
	/*height: 0px;*/
	/*min-height: 175px;*/
	top: 15vh;
	left: 25vw;
	border-radius: 4px;
	/*border-color: rgba(230 230 230 / .25);
	border-style: solid;
	border-width: 1px;*/
	position: absolute;
	box-sizing: border-box;
	padding: 4px;
	z-index: 99;
}

.info_item_master {
	display: flex;
	flex-direction: row;
	align-items: center;
	
	width: 200px;
	height: 40px;
	padding: 5px;
	
	cursor: pointer;
}

.info_item_text {
	color: rgb(240,240,240);
	font-size: var(--info_box_text_height);
	width: 100px;
	/*padding-top: var(--info_box_text_height);*/
	position: relative;
	left: -10px;
}

.info_box_icon {
	position: relative;
	width: 45%;
	min-width: 50px;
	height: 45%;
	min-height: 40px;
	max-height: 65px;
	border-radius: 4px;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	
	/*transition: top .5s, transform .5s;*/
}

.info_box_ani {
	animation-name: icon_ani;
	animation-timing-function: ease-in-out;
	animation-duration: .25s;
	/*animation-delay: 2.5s;*/
	animation-iteration-count: 1;
	animation-direction: normal;
	animation-fill-mode: forwards;
}

@keyframes icon_ani {
	0% {
		top: 0px;
		transform: scale(1);
	}
	40% {
		/*top: -4px;*/
		transform: scale(1.08);
	}
	100% {
		top: 0px;
		transform: scale(1.04);
	}
}

.contact_icon {
	height: calc(45% - var(--info_box_text_height));
	width: 100px;
	min-height: 50px;
	max-height: 75px;
	background-image: url('../images/icon_contact@2x.png');
	cursor:pointer;
}

.contact_icon_ani {
	animation-name: contact_ani;
	animation-timing-function: ease-in-out;
	animation-duration: .7s;
	animation-iteration-count: 1;
	animation-direction: normal;
	animation-fill-mode: forwards;
}

.contact_icon_ani2 {
	animation-name: contact_ani2;
	animation-timing-function: ease-out;
	animation-duration: .5s;
	animation-iteration-count: 1;
	animation-direction: normal;
	animation-fill-mode: forwards;
}

@keyframes contact_ani {
	0% {
		transform: translateY(0px) rotate(0deg);
	}
	30% {
		transform: translateY(5px) rotate(5deg);
	}
	50% {
		transform: translateY(1px) rotate(2deg);
	}
	70% {
		transform: translateY(3px) rotate(6deg);
	}
	100% {
		transform: translateY(0px) rotate(0deg);
	}
}

@keyframes contact_ani2 {
	0% {
		transform: translateY(0px);
	}
	15% {
		transform: translateY(5px);
	}
	50% {
		transform: translateY(-30px);
	}
	100% {
		transform: translateY(0px);
	}
}

.user_icon {
	height: 100%;
	background-image: url('../images/icon_contact@2x.png');	
}

.resume_icon {
	height: 100%;
	background-image: url('../images/icon_resume@2x.png');	
}

.promo_icon {
	height: 100%;
	background-image: url('../images/icon_promo@2x.png');	
}

.code_icon {
	height: 100%;
	background-image: url('../images/icon_code@2x.png');	
}

.info_box_top {
	width: 100%;
	height: calc(5px + var(--info_box_text_height));
	text-align: center;
	color: rgb(250,250,250);
	font-size: var(--info_box_text_height);
	font-style: bold;
	
	padding-bottom: 20px;
}

#info_item_master_0 {
	padding-top: 20px;
}

#resume_master {
	padding-top: 20px;
}

.half_rad_grad {
	background-image: url('../images/half_gradient@2x.png');
	background-repeat: no-repeat;
	background-size: 100%;
	background-origin: center;
	background-position-y: bottom;
	background-position-x: center;
	padding-top: 655px;
	margin-top: -655px;
	/*opacity: 85%;*/
	/*position: absolute;*/
	/*top: -15%;*/
	left: -5vw;
	width: 75vw;
	/*height: 60%;*/
	z-index: -1;
	/*overflow: hidden;*/
}

.rad_grad {
	background-image: url('../images/radial_gradient.png');
	background-repeat: no-repeat;
	background-size: 25vw;
	background-position: center;
	opacity: 75%;
	position: absolute;
	top: 75vh;
	right: -25vw;
	width: 25vw;
	height: 25vh;
	z-index: 99;
}

@media (min-height: 499px) {
	.info_box_master {
		top: 30vh;
	}
}