
:root {

	--font-main-color: dimgray;
	--font-highlight-color: gray;

	--portrait-essence: #d2cbc7;
	--profession-essence: #d2cbc7;

	--portrait-below-color: #e5e6e7;
	--contact-background-color: #e5e6e7;
	--imprint-background-color: #e5e6e7;

	--font-size-title: 1.0rem;
	--font-size-normal: 0.75rem;
	--font-size-small: 0.5rem;

	--font-size-basis: min(5vh, 6vw);
	--font-size-minimum: 25px;
	--font-size-maximum: 40px;

	--portrain-margin: 250px;
	--text-margin-left: 50px;
	--map-margin-left: 150px;

	--portrait-mobile-division: 60vh;

	--text-portrait-desktop-top: 15vh;
	--text-portrait-mobile-top: 5vh;

	--text-profession-top: 15vh;
	--text-contact-top: 15vh;

	--division-bar-height: 10px;

	--link-hover-offset: 5px;

	font-family: "Quicksand", Verdana, sans-serif;

	font-size: min(
		max(var(--font-size-basis), var(--font-size-minimum)), 
		var(--font-size-maximum));
}

@keyframes fade-in {
	0% { opacity: 0; }
	100% { opacity: 1; }
}

body {

	margin: 0;

	color: var(--font-main-color);
	font-style: italic;
}

a {

	color: var(--font-main-color);
	text-decoration: none;
}


/* ~~~ portrait page ~~~ */

.portrait-container {

	display: flex;
	flex-direction: row;
	justify-content: space-between;

	background-size: auto 100%;
	background-attachment: fixed;
	background-repeat: repeat;

	height: 100vh;
	overflow: hidden;
}

.portrait-buffer {

	min-width: var(--portrain-margin);
}

.portrait-image {

	background-size: auto 100%;
	background-attachment: fixed;
	background-repeat: no-repeat;

	height: 100%;

	/* Fallback if JS fails */
	background-position: left var(--portrain-margin) top;
	width: 100%;
}

.image-hide {

	visibility: hidden;
}

.image-fadein {

	animation: fade-in ease 1s;
	visibility: visible;
}

.portrait-below {

	height: 0vh;
	overflow: hidden;

	background-color: var(--portrait-below-color);
}

.portrait-text {

	position: absolute;

	top: var(--text-portrait-desktop-top);
	left: var(--text-margin-left);
}

.portrait-name {

	position: relative;
	font-size: var(--font-size-title);

	top: 0rem;
}

.portrait-info {

	position: relative;
	font-size: var(--font-size-small);

	top: 0.5rem;
}

.profession-link {

	display: block;
	position: relative;

	font-size: var(--font-size-normal);
	top: 2.0rem;

	transition: padding-left 0.5s;
}

.contact-link {

	display: block;
	position: relative;

	font-size: var(--font-size-normal);
	top: 2.4rem;

	transition: padding-left 0.5s;
}

.profession-link:hover {

	color: var(--font-highlight-color);
	padding-left: var(--link-hover-offset);
}

.contact-link:hover {

	color: var(--font-highlight-color);
	padding-left: var(--link-hover-offset);
}

.portrait-bar {
	
	min-height: var(--division-bar-height);
	background-color: var(--portrait-essence);
}

@media screen and (max-aspect-ratio: 1.0) {

	.portrait-buffer {

		min-width: 0px;
	}

	.portrait-container {

		height: var(--portrait-mobile-division);
		background-size: auto var(--portrait-mobile-division);
	}

	.portrait-image {

		background-size: auto var(--portrait-mobile-division);

		/* Fallback if JS fails */
		background-position: left top;
	}

	.portrait-below {

		height: calc(100vh - var(--portrait-mobile-division));
		border-bottom: 2px solid var(--portrait-essence);
	}

	.portrait-text {

		top: calc(var(--portrait-mobile-division) + var(--text-portrait-mobile-top));
	}
}

/* ~~~ profession page ~~~ */

.profession-container {

	display: flex;
	flex-direction: row;
	justify-content: space-between;

	background-size: cover;
	background-attachment: fixed;
	background-repeat: no-repeat;

	height: 100vh;
	overflow: hidden;
}

.profession-text {

	margin-top: var(--text-profession-top);
	margin-left: var(--text-margin-left);
}

.profession-title {

	font-size: var(--font-size-title);
	padding-bottom: 2.0rem;
}

.profession-info {

	font-size: var(--font-size-normal);
	margin-bottom: 0.5rem;
}

.profession-bar {
	
	min-height: var(--division-bar-height);
	background-color: var(--profession-essence);
}

/* ~~~ contact page ~~~ */

.contact-container {

	display: flex;
	flex-direction: row;
	justify-content: space-between;

	background-color: var(--contact-background-color);

	height: 100vh;
	overflow: hidden;
}

.contact-text {

	margin-top: var(--text-contact-top);
	margin-left: var(--text-margin-left);
}

.contact-title {

	font-size: var(--font-size-title);
	padding-bottom: 1.0rem;
}

.contact-info {

	font-size: var(--font-size-normal);
	margin-top: 0.5rem;
}

.contact-phone {

	font-size: var(--font-size-normal);
	margin-top: 1.0rem;
}

.contact-phone div {

	font-size: var(--font-size-small);
	margin-top: 0.5rem;
}

.map-container {

	margin-left: var(--map-margin-left);
	margin-right: var(--text-margin-left);

	margin-top: var(--text-contact-top);
	margin-bottom: var(--text-contact-top);

	flex-grow: 1;

	border: 1px solid black;
	box-shadow: 5px 5px 5px gray;
}

#map {
	width: 100%;
	height: 100%;
}

@media screen and (max-aspect-ratio: 1.0) {

	.contact-container {

		flex-direction: column;
	}

	.map-container {

		margin-left: var(--text-margin-left);
		margin-right: var(--text-margin-left);
	
		margin-top: var(--text-margin-left);
		margin-bottom: var(--map-margin-left);
	}

}

.leaflet-popup-content-wrapper {
	font-size: var(--font-size-small);	
}




.imprint-link {

  position: absolute;
  bottom: -200vh;

	margin-left: var(--text-margin-left);
	font-size: var(--font-size-small);

	transition: padding-left 0.5s;
}

.imprint-link:hover {

	color: var(--font-highlight-color);
	padding-left: var(--link-hover-offset);
}



.back-link {

  position: absolute;
  bottom: -100vh;

	padding-bottom: var(--division-bar-height);

	margin-left: var(--text-margin-left);
	font-size: var(--font-size-small);

	transition: padding-left 0.5s;
}

.back-link:hover {

	color: var(--font-highlight-color);
	padding-left: var(--link-hover-offset);
}











.imprint-container {

	display: flex;
	flex-direction: column;

	background-size: auto 100%;
	background-color: var(--imprint-background-color);
	
	height: 100%;
}

.imprint-text {

	font-size: var(--font-size-small);
	font-style: normal;

	margin-top: var(--text-margin-left);
	margin-left: var(--text-margin-left);

	margin-bottom: var(--text-margin-left);
	margin-right: var(--text-margin-left);
}

.return-link {

	margin-left: var(--text-margin-left);
	margin-bottom: 20px;

	font-size: var(--font-size-small);

	transition: padding-left 0.5s;
}

.return-link:hover {

	color: var(--font-highlight-color);
	padding-left: var(--link-hover-offset);
}






/* ~~~ Dynamic image resolution ~~~ */

/* Portrait */
@media screen and (max-height: 783px) {
	.portrait-container {
		background-image: url("images/slice_m2.png");
	}
	.portrait-image {
	  background-image: url("images/portrait_m2.png");
	}
}
@media screen and (min-height: 784px) and (max-height: 1566px) {
	.portrait-container {
		background-image: url("images/slice_m1.png");
	}
	.portrait-image {
	  background-image: url("images/portrait_m1.png");
	}
}
@media screen and (min-height: 1567px) {
	.portrait-container {
		background-image: url("images/slice_m0.png");
	}
	.portrait-image {
	  background-image: url("images/portrait_m0.png");
	}
}

/* Profession */
@media screen and (max-height: 473px) {
	.profession-container {
	  background-image: url("images/profession_m2.png");
	}
}
@media screen and (min-height: 474px) and (max-height: 946px) {
	.profession-container {
	  background-image: url("images/profession_m1.png");
	}
}
@media screen and (min-height: 947px) {
	.profession-container {
	  background-image: url("images/profession_m0.png");
	}
}
