/* Box sizing rules */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	border: 0;
	list-style-type: none;}

/* Prevent font size inflation */
html {
	-moz-text-size-adjust: none;
	-webkit-text-size-adjust: none;
	text-size-adjust: none;
	font-size: 10px;}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role='list'], ol[role='list'] {
	list-style: none;}

/* Set core body defaults */
body {
	min-height: 100%;
	line-height: 1.4;
	font-size: 100.01%;
	width: 100%;
	-webkit-font-smoothing: subpixel-antialiased;
	display: flex;
	flex-direction: column;}
	
html, body {
	height: 100%;
	width: 100%;}

/* Set shorter line heights on headings and interactive elements */
h1, h2, h3, h4 {
	line-height: 1.1;}

/* A elements that don't have a class get default styles */
a:not([class]) {
	text-decoration-skip-ink: auto;
	color: currentColor;}

/* Make images easier to work with */
img, picture {
	max-width: 100%;
	max-height: 100%;
	display: block;}

/* Inherit fonts for inputs and buttons */
input, button, textarea, select {
	font-family: inherit;
	font-size: inherit;}

/* Anything that has been anchored to should have extra scroll margin */
:target {
	scroll-margin-block: 5ex;}
	
.hideit {
	visibility: hidden;
	height: 0 !important;
	margin: 0 !important;}
	
/*------------------------------------------------------------------------------------------*/
/*                                       PROJECT'S CSS                                      */
/*------------------------------------------------------------------------------------------*/


/* lato-300 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Lato';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/lato-v24-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* lato-regular - latin */
@font-face {
  font-display: swap; 
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/lato-v24-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* lato-700 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/lato-v24-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}


html, body {
	height: 100%;
	width: 100%;}
	
body {
	font-size: 100.01%;
	width: 100%;
	-webkit-font-smoothing: subpixel-antialiased;
	border-top: solid 15px #6a9598;}
	
h1 {
	font-family: Lato, Arial, sans-serif;
	font-size: 5rem;
	font-weight: 700;
	color: #1e5f6b;
	margin: 0 0 3rem 0;
	width: 100%;}
	
h2 {
	font-family: Lato, Arial, sans-serif;
	font-weight: 700;
	font-size: 3rem;
	color: #1e5f6b;
	margin: 0 0 2rem 0;}
	
h3 {
	font-family: Lato, Arial, sans-serif;
	font-size: 2.8rem;
	font-weight: 400;
	color: #484847;
	margin: 3rem 0 2rem 0;}
	
h4 {
	font-family: Lato, Arial, sans-serif;
	font-size: 2.8rem;
	font-weight: 700;
	color: #1e5f6b;}
	
p, li, a {
	font-family: Lato, Arial, sans-serif;
	font-weight: 300;
	font-size: 2rem;
	color: #484847;}
	
a {
	font-weight: 400;
	color: #1e5f6b;
	text-decoration: none;}
a:hover {
	color: #1e5f6b;
	text-decoration: underline;
	text-decoration-color: #1e5f6b;
	text-decoration-thickness: 1px;
	text-underline-offset: 4px;}
.boldlink {
	font-weight: 700;}
	
b {
	font-family: Lato, Arial, sans-serif;
	font-weight: 400;}
	
/*------------------------------------------------------------------------------------------*/
/*                                     NAVIGATION                                           */
/*------------------------------------------------------------------------------------------*/

nav {
	position: absolute;
	height: 150px;
	width: 90vw;
	max-width: 1600px;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;}
	
.logo {
	position: absolute;
	height: 65px;
	width: auto;
	top: 50px;
	left: 0;
	z-index: 9888;}

.menue {
	position: absolute;
	width: auto;
	height: auto;
	top: 15px;
	right: 0;}
	
.menue li {
	cursor: pointer;
    display: block;
    float: left;
	padding: 30px 15px 10px 15px;
	margin-right: 5px;
	border-radius: 0 0 10px 10px;}
	
.menue li:last-child {
	margin-right: 0;}
	
.menue .current > a, .menue .current > a:hover {
    color: #fff;
	font-weight: 700;
	border-bottom: none !important;
	padding: 0 !important;}
	
.current, .current:hover {
    background-image: linear-gradient(rgba(106,149,152), rgba(30,95,107));}
	
.menue .current > a span {
	background-position: bottom center;}
	
.menue li:hover > a {
	border-bottom: solid 2px #1e5f6b;
	border-radius: 0;
	padding-bottom: 7px;}
	
.menue a {
    display: block;
    text-decoration: none;
	font-size: 20px;
	font-weight: 400;}
	
.menueicon {
	display: block;
	width: 100%;
	height: 26px;
	margin-bottom: 5px;
	background-size: 39px auto;
	background-repeat: no-repeat;
	background-position: top center;}	
	
.menuestart {
	background-image: url(../img/hausaerzte-am-campus-icon-start.svg);}
.menueteam {
	background-image: url(../img/hausaerzte-am-campus-icon-team.svg);}
.menuespektrum {
	background-image: url(../img/hausaerzte-am-campus-icon-spektrum.svg);}
.menuekarriere {
	background-image: url(../img/hausaerzte-am-campus-icon-karriere.svg);}
.menuetermin {
	background-image: url(../img/hausaerzte-am-campus-icon-termin.svg);}
.menuekontakt {
	background-image: url(../img/hausaerzte-am-campus-icon-kontakt.svg);}
	
/*------------------------------------------------------------------------------------------*/
/*                                       HEADER                                             */
/*------------------------------------------------------------------------------------------*/

header {
	position: relative;
	width: 90vw;
	max-width: 1600px;
	height: auto;	
	margin: 135px auto 65px auto;}
	
header img {
	border-radius: 12px;
	min-height: 350px;
	object-fit: cover;}

/*------------------------------------------------------------------------------------------*/
/*                                        CONTENT                                           */
/*------------------------------------------------------------------------------------------*/

main {
	position: relative;
	width: 90vw;
	max-width: 1600px;
	margin: 0 auto;}
	
.contentbox {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 65px;
	row-gap: 2vw;}
	
.col2 {
	width: 15%;} /* (6.5 x 2) + (2 x 1) */
	
.col3 {
	width: 23.5%;} /* (6.5 x 3) + (2 x 2) */	
	
.col4 {
	width: 32%;} /* (6.5 x 4) + (2 x 3) */
	
.col6 {
	width: 49%;} /* (6.5 x 6) + (2 x 5) */
	
.col8 {
	width: 66%;} /* (6.5 x 8) + (2 x 7) */
	
.col12 {
	width: 100%;}
	
.kachel {
	background-color: #1e5f6b;
	border-radius: 12px;
	padding: 3rem 4rem 4rem 4rem;}
	
.kachel .tableft, .col4 .tableft {
	position: absolute;
	display: inline;
	font-weight: 700;}
	
.kachel .tabright, .col4 .tabright {
	position: relative;
	display: inline; 
    margin-left: 50px;
	font-weight: 400;}
	
.col4 .tabright {
	font-weight: 300;}
	
.col6 li, .more li {
	list-style-type: disc;
	margin-left: 22px;}
	
.boxitem {
	background-color: #f5f5f5;
	border-radius: 12px;
	overflow: hidden;
	text-align: center;
	padding-bottom: 5rem;}
	
.boxitem p, .boxitem a {
	padding: 3rem 3rem 0 3rem;}
	
.boxitem h2 {
	padding: 3rem 3rem 0 3rem;
	margin: 0;}
	
.kachel h2, .kachel p, .kachel li, .kachel h3, .kachel a:hover {
	color: #fff;}
	
.kachel h3 {
	font-weight: 700;
	margin: 0 0 2rem 0;}
	
.kachel p {
	font-weight: 400;}
	
.buttonmore {
	display: inline-block;
	padding: 4px 25px 8px 25px !important;
	margin: 4rem 3rem 0 3rem;
	border: 1px solid #1e5f6b;
	border-radius: 6px;
	background-color: none;
	color: #1e5f6b;
	font-weight: 400;
	-webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    -ms-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;}
	
.buttonmore:hover {
	background-color: #1e5f6b;
	color: #fff;
	text-decoration: none;}
	
.pdf {
	background-image: url("../img/hausaerzte-am-campus-icon-download.svg");}
.pdf, .extlink {
	display: block;
	font-weight: 400;
	border-radius: 10px;
	width: 100%;
	background-size: 23px auto;
	background-position: right 30px center;
	background-repeat: no-repeat;
	padding: 17px 20px 20px 30px;
	margin: 0 0 10px 0;
	text-decoration: none;
	border: 1px solid #ebeced;
	-webkit-transition: all 0.9s ease;
	-moz-transition: all 1s ease;
	-ms-transition: all 1s ease;
	-o-transition: all 1s ease;
	transition: all 1s ease;}
	
.pdf:hover, .extlink:hover {
	color: #1e5f6b;
	text-decoration: none;
	border: 1px solid #1e5f6b;
	-webkit-transition: all 0.9s ease;
	-moz-transition: all 1s ease;
	-ms-transition: all 1s ease;
	-o-transition: all 1s ease;
	transition: all 1s ease;}
  
 .read_more {
	cursor: pointer;}

.more {
    display: none;
	text-align: left;
	margin: 3rem;}
	
video {
	width: 100%;
	border: 1px solid #ebeced;
	margin: 10px 0 15px 0;}

.clearer {
	clear: both;}
	
/*------------------------------------------------------------------------------------------*/
/*                                       MAPS                                               */
/*------------------------------------------------------------------------------------------*/
	
.map-placeholder {
	position: relative;
	display: block;
	width: 100%;
	height: 700px;
	max-height: 100vh;
	margin-bottom: 50px;
	box-sizing: border-box;
	background-color: #f5f6f7;
	background-image: url("../img/platzhalter-maps.png");
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	padding: 25px 35px;}
	
.map-placeholder p {
	text-align: center;
	font-size: 2rem;
	top: 0;
	transform: translateY(0);}
	
.map-placeholder a, .map-placeholder a:hover {
	text-decoration: underline;
	text-underline-offset: 4px;}
	
.googlemapcontent {
	position: relative;
	display: block;
	width: 100%;
	top: 40%;
	transform: translateY(-50%);}

button {
	position: relative;	
	background-color: transparent;
	transition: all .3s ease-in-out;
	font-family: Lato, Arial, sans-serif;
	font-weight: 700;
	font-size: 2.2rem;
	color: #1e5f6b;	
	font-weight: 700;
	display: block;
	border: 1px solid #1e5f6b;
	padding: 10px 25px 12px 25px;
	border-radius: 10px;
	margin: 25px auto;}
	
button:hover {	
	cursor: pointer;
	background-color: #1e5f6b;
	color: #fff;
	transition: all .3s ease-in-out;}
	
/*------------------------------------------------------------------------------------------*/
/*                                       MODAL                                              */
/*------------------------------------------------------------------------------------------*/

.modal button {
position: relative;
display: inline;}

.modal p, .modal h4 {
	top: 0;
	box-sizing: border-box;
	width: 49%;
	transform: translateY(0);
	padding: 20px;
	margin: 0;}
	
.modal h4 {
	padding: 20px;
	font-size: 28px;}
	
.modal p {
	padding: 0 20px 20px 20px;}
	
#myBtn {
	font-weight: 400;
	cursor: pointer;}
	
#myBtn:hover {
	color: #003d8a;
	text-decoration: underline;}

.modal {
	display: none;
	position: fixed;
	z-index: 10000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgb(0,0,0);
	background-color: rgba(0,0,0,0.6);}

.modal-content {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	background-color: #fff;
	margin: 10% auto;
	width: 90%;
	padding: 2vw;
	max-width: 1200px;
	border-radius: 12px;
	webkit-animation-name: zoom;
	-webkit-animation-duration: 0.6s;
	animation-name: zoom;
	animation-duration: 0.6s;}
	
.modal2-content {
	position: relative;
	box-sizing: border-box;
	border-radius: 12px;
	background-color: #fff;
	margin: 5vw auto;
	width: 90%;
	max-width: 1200px;
	padding: 3vw 3vw 0 3vw;
	-webkit-animation-name: zoom;
	-webkit-animation-duration: 0.6s;
	animation-name: zoom;
	animation-duration: 0.6s;}

@-webkit-keyframes zoom {
	from {-webkit-transform:scale(0)} 
	to {-webkit-transform:scale(1)}
}

@keyframes zoom {
	from {transform:scale(0)} 
	to {transform:scale(1)}
}

.modalimg {
	box-sizing: border-box !important;
	width: 49% !important;
	height: auto;
	border-radius: 10px;
	overflow: hidden;}
	
.modaldiv {
	box-sizing: border-box !important;
	width: 49%;}
	
.modaldiv p, .modaldiv h4 {
	width: 100%;
	transform: translateY(0);}

.closebtn {
	position: absolute;
	right: 20px;
	top: 20px;}

.close {
	position: absolute;
	width: 40px;
	height: 40px;
	opacity: 0.5;}
	
.close:before, .close:after {
	position: absolute;
	left: 19px;
	content: ' ';
	height: 40px;
	width: 2px;
	background-color: #000;}
	
.close:before {
	transform: rotate(45deg);}
	
.close:after {
	transform: rotate(-45deg);}

.close:hover,
.close:focus {
	opacity: 1;
	color: black;
	text-decoration: none;
	cursor: pointer;} 

#ueberweisung, #dauerrezept {
	display: inline-block;
	padding: 4px 25px 8px 25px;
	margin: 4rem 3rem 0 3rem;
	border: 1px solid #1e5f6b;
	border-radius: 6px;
	background-color: none;
	color: #1e5f6b;
	font-weight: 400;
	-webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    -ms-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;}
#dauerrezept {margin-left: 0;}
	
#ueberweisung:hover, #dauerrezept:hover {
	background-color: #1e5f6b;
	color: #fff;
	text-decoration: none;
	-webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    -ms-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;}

form {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;}
	
.formdiv {
	width: 47%;}

label {
	font-family: Lato, Arial, sans-serif;
	font-weight: 400;}
	
form button {
	font-family: Lato, Arial, sans-serif;
	display: block;
	position: relative;
	width: 100%;
	background-color: #484847;
	margin: 25px auto;
	color: #fff;
	padding: 9px 20px 11px 20px;
	transition: all .3s ease-in-out;
	border: 0;}
	
form button:hover {
	cursor: pointer;
	background-color: #1e5f6b;
	color: #fff;
	transition: all .3s ease-in-out;}
	
form {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
	box-sizing: border-box;}

form.form {
	font-weight: 300;
	font-size: 20px;
	line-height: 27px;
	color: #484847;
	padding: 0 20px 50px 20px;}

form.form strong {
	font-weight: 700;}

form.form input[type="checkbox"], form.form input[type="radio"] {
	position: relative;
	left: 0;
	width: 20px;
	height: 20px;}

form#form4, .html {
	padding: 0;
	width: 100%;}

form.form label {
	display: block;
	margin-bottom: 5px;
	margin-top: 20px;}

.form .column {
	justify-content: unset;}

.modal2 p, .modal2 h4 {
	float: none;
	top: 0;
	box-sizing: border-box;
	width: 100%;
	transform: none;
	padding: 20px;
	margin: 0;}

.modal2 form.form button {
	display: block;}

.modal2 button {
	position: relative;
	display: inline;}

form.form select, form.form input[type="text"], form.form input[type="email"], form.form input[type="number"], form.form textarea {
	width: 100%;
	box-sizing: border-box;}

form.form select, form.form input[type="text"], form.form input[type="email"], form.form input[type="date"], form.form input[type="number"], form.form textarea {
	font-size: 18px;
	color: #484847;
	background-color: #fff;
	border: 1px solid #484847;
	padding: 7px 9px 9px 9px;
	margin-top: 5px;}

form.form textarea {
	display: inline-block;
	height: 120px;}

form.form .req {
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
	height: 0;
	width: 0;
	z-index: -1;}

.column.fullwidth {
	width: 100%;}

/*------------------------------------------------------------------------------------------*/
/*                                         FOOTER                                           */
/*------------------------------------------------------------------------------------------*/

footer {
	position: relative;
	width: 100vw;
	margin: 35px 0 0 0;
	background-color: #1e5f6b;}
	
#footerwrapper {
	width: 90vw;
	max-width: 1600px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	row-gap: 5vw;
	flex-wrap: wrap;
	margin: 0 auto;
	padding: 7rem 0 8rem 0;
	background-image: url("../img/hausaerzte-am-campus-footergrafik.png");
	background-repeat: no-repeat;
	background-position: bottom right;}
	
#footerwrapper p, #footerwrapper a {
	text-decoration: none;
	line-height: 1.6;
	font-weight: 300;
	color: #fff;
	transition: all .3s ease-in-out;}
	
#footerwrapper a::before {
	content: '>';
	opacity: 0;
	margin-right: -12px;
	-webkit-transition: all 250ms;
	transition: all .3s ease-in-out;}
	
#footerwrapper a:hover::before {
	opacity: 1;
	text-decoration: none;
	margin-right: 5px;
	font-weight: 700;
	transition: all .3s ease-in-out;}

	
/*------------------------------------------------------------------------------------------*/
/*                                     MEDIA QUERIES                                        */
/*------------------------------------------------------------------------------------------*/

@media only screen and (max-width: 1480px) {

#dauerrezept {
	margin: 2rem 3rem 0 3rem;}
}

@media only screen and (max-width: 1200px) {
	
.col8, .kachel {
	width: 49%;}

}

@media only screen and (max-width: 1000px) {
	
.contentbox .col4, #footerwrapper .col3 {
	width: 49%;}

}

@media only screen and (max-width: 950px) {

.menue {
	position: fixed;
	box-sizing: border-box;
	z-index: 8888;
    height: 100%;
    top: 0;
	left: 100%;
	padding: 0;
	padding-top: 140px; 
    width: 100%;
	background-color: rgba(255, 255, 255, 0.95);
	overscroll-behavior-y: contain;
    overflow-y: auto;
	-webkit-transition: all 0.4s;
	-moz-transition: all 0.4s;
	-ms-transition: all 0.4s;
	-o-transition: all 0.4s;
	transition: all 0.4s;}
	
.slidemenu {
	box-shadow: 0 0 20px 0 #000;
	transform: translateX(-100%);
	-webkit-transform: translateX(-100%);}
	
.menue li {
	position: relative;
	display: block;
	margin: auto 5%;
	padding: 0;
    border-top: 1px solid #e9e9e9;
    width: 90%;
	border-radius: 0;
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;}
	
.menue li:hover > a {
	border-bottom: 0;}
	
.menue li:hover {
	background-color: #ebeced;
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;}
	
.current, .current:hover {
	background-image: none;
    background-color: #1e5f6b !important;}
	
.menue li:hover > a {
	color: #484847;}
	
.lastli {
	border-bottom: 1px solid #e9e9e9;}
	
.menue a, .menue .current > a, .menue .current > a:hover {
	margin: 0;
	padding: 19px 40px 21px 40px !important;}
	
.menueicon {
	display: inline-block;
	width: 35px;
	height: 25px;
	margin: 0 15px -4px 0;
	background-size: auto 50px;
	background-repeat: no-repeat;
	background-position: top center;}
	
}

@media only screen and (max-width: 850px) {

.modalimg, .modaldiv, .formdiv {
	width: 100% !important;}
	
.modalimg {
	order: 2;}
	
}

@media only screen and (max-width: 750px) {
	
.col8, .contentbox .kachel {
	width: 100%;}

}

@media only screen and (max-width: 600px) {
	
.contentbox {
	row-gap: 5vw;}	
	
.contentbox .col4, .col6 {
	width: 100%;}

}
@media only screen and (max-width: 500px) {
	
#footerwrapper .col3 {
	width: 100%;
	text-align: center;}
	
#footerwrapper img {
	margin: 0 auto;}

}

