/* ----- 	Reset    ----- */

*:not(li), *:before, *:after {
    margin: 0 auto;
    padding: 0;
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
            box-sizing: border-box;
}

.invisible {
    display: none;
}

sub, sup {
    line-height: 0.8;
}

figure {
	line-height: 0.1;
}

img {
	width: auto;
    max-width: 100%;
    height: auto;
    max-height: 100%;
}

/*body.galerie.quer .ce_gallery li img {
	max-width: inherit;
}*/

/* ----- 	Image Replacement    ----- */

#navitoggle, #naviclose, #wortmarke {
	text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    background-size: contain;
    background-repeat: no-repeat;
}


/* ----- 	Justify    ----- */

#container-header #navitoggle, #container-header .navi.portfolio, #container-header li,
#container-footer #copyright, #container-footer .navi.service, #container-footer li,
.mod_article.text2spaltig .ce_text,
.mod_article.text2spaltig .content-text {
	display: inline-block;
}

#container-header .inner-inner, #container-header .level_1,
#container-footer .inner-inner, #container-footer .level_1,
.mod_article.text2spaltig {
    text-align: justify;
    font-size: 0.1px;
}

#container-header .inner-inner:after, #container-header .level_1:after,
#container-footer .inner-inner:after, #container-footer .level_1:after,
.mod_article.text2spaltig:after
 {
    content: "";
    width: 100%;
    display: inline-block;
}


/* ----- 	Layout    ----- */

body,
#container-header .inner,
#container-footer .inner,
#container-navi-komplett .inner,
#container-naviclose .inner {
	max-width: 1920px;
}

#wrapper {
    overflow: hidden;
}

#header, body.startseite #container,
#container-header .inner-inner,
#container-footer .inner-inner,
#container-navi-komplett .inner-inner,
#container-naviclose .inner-inner,
.mod_article.text2spaltig {
	padding-left: 5.208%;			/* = 100px bei Eltern-Breite 1920px */
	padding-right: 5.208%;
}


/* -----    Header + Footer   ----- */

#container-header  {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
    z-index: 5;
}

body.no-portfolio-navi #container-header .inner-inner {
    height: 0;
}

#container-header .inner-inner, #container-naviclose .inner-inner {
	padding-top: 7px;
}

#container-header .navi.portfolio {
	width: 83%;
	vertical-align: top;
}

#container-footer .navi.service {
    width: 60%;
    width: calc(73% - 130px);
}

@media (max-width: 650px) {
	#container-footer .navi.service {
	    width: 100%;
	    /*max-width: 560px;*/
	}
}

#copyright, .navi.service {
    vertical-align: middle;
}

#copyright {
	text-align: left;
}

body.no-portfolio-navi #container-header .navi.portfolio {
    width: 0;
    overflow: hidden;
    white-space: nowrap;
}


#container-header .navi.portfolio a, #container-header .navi.portfolio strong {
	display: block;
	line-height: 1.5;
}

#navitoggle {
    width: 1.6em;                   /* = 40px, 2.35em = 60px bei font-size 25px */
    height: 1.3em;
    background-image: url('css-img/Burger-Icon_schmaler.svg');
}

body.active #navitoggle {
	opacity: 0;
}

#naviclose {
    width: 1.6em;                   		/* = 40px, 2.35em = 60px bei font-size 25px */
    height: 1.3em;
    background-image: url('css-img/X-Icon.svg');
    margin-left: 0;
}

#wortmarke {
	margin-top: 4em;
	margin-bottom: 2.26em;
	margin-right: calc(26.43% - 84.57px);	/* = 370px bei 1720px Elternelement, 0 bei 320px Bildschirmbreite */
    width: 16em;
    height: 3em;							/* = 70px bei font-size 25px */
    background-image: url('css-img/Wortmarke_neutralgrau.svg');
}

#wortmarke h1 {
	padding-bottom: 1.5em;
}

#footer .inner-inner {
    padding-top: 7px;
    padding-bottom: 2px;
}


/* -----   	Navi komplett    ----- */

#container-navi-komplett {
	opacity: 0;
	position: fixed;
    z-index: 10;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	text-align: center;
	-webkit-transform: scaleY(0);
			transform: scaleY(0);
	-webkit-transition: transform 0s 0.5s, opacity 0.5s;
			transition: transform 0s 0.5s, opacity 0.5s;
}

#container-naviclose {
    opacity: 0;
    position: fixed;
    z-index: 15;
    top: 0;
    left: 0;
    width: 100%;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transition: transform 0s 0.5s, opacity 0.5s;
            transition: transform 0s 0.5s, opacity 0.5s;
}

#navitoggle {
	-webkit-transition: opacity 0.5s;
			transition: opacity 0.5s;
}

body.active #container-navi-komplett,
body.active #container-naviclose {
	-webkit-transform: scaleY(1);
			transform: scaleY(1);
	opacity: 1;
	-webkit-transition: transform 0s 0s, opacity 0.5s;
			transition: transform 0s 0s, opacity 0.5s;
}

body.active {
	overflow: hidden;
}

.navi.komplett ul {
	display: inline-block;
	width: 100%;
	max-width: 1720px;
	text-align: left;
	list-style-type: none;
}

.navi.komplett ul ul.level_2 {
	display: none;
}

.navi.komplett li {
	margin-left: 11.628%;
	line-height: 2;
}

.navi.komplett {
	padding-top: 50px;
    padding-bottom: 2em;
}

body:not(.sf6):not(.sf7) .navi.komplett {
    padding-top: 11vh;
}

.navi.komplett li.no-portfolio-navi + li.portfolioseite,
.navi.komplett li.portfolioseite + li.no-portfolio-navi {
	margin-top: 1em;
}

/* -----   	Content    ----- */

    /* -----    Slider    ----- */

.slider {
    margin-bottom: 4.07%;           /* = 100px - 30px Slider-Control-Dots bei Eltern-Breite 1720px */
}

@media (max-width: 700px) {
	.slider {
		margin-left: -5.813%;		/* = -100px bei Eltern-Breite 1720px */
	    margin-right: -5.813%;
	 }
}

.slider-control a.slider-prev, .slider-control a.slider-next {
    display: none;
}


	/* -----   	Teaser    ----- */

.teaser {
	overflow: hidden;
	position: relative;				/* Bezugspunkt für .teaser a:after */;
}

.teaser.bild-breit, .teaser.bild-links, .teaser.breiter {
	margin-bottom: 5.813%;			/* = 100px bei Eltern-Breite 1720px */
}

.teaser.breiter {
    margin-left: -5.813%;			/* = -100px bei Eltern-Breite 1720px */
    margin-right: -5.813%;
}

.teaser.breiter .ce_text,
.teaser.breiter .content-text {
	margin-left: 5.208%;			/* = 100px bei Eltern-Breite 1920px */
	margin-right: 5.208%;
    padding: 1.8em 0.8em 2.4em;     /* = 50px 120px 60px bei font-size 25px */
}

.teaser.bild-breit, .teaser.bild-links {
	text-align: right;
}

@media (min-width: 1921px) {
	.teaser.bild-breit .ce_text,
	.teaser.bild-breit .content-text,
	body:not(.duisburger-family) .teaser.bild-links .ce_text,
	body:not(.duisburger-family) .teaser.bild-links .content-text {
		min-height: 400px;
	}
}

@media (max-width: 1920px) {
    .teaser.bild-breit .ce_text,
    .teaser.bild-breit .content-text,
    body:not(.duisburger-family) .teaser.bild-links .ce_text,
    body:not(.duisburger-family) .teaser.bild-links .content-text {
        min-height: 20.83vw;
    }
}

.teaser.bild-breit .ce_text, .teaser.bild-links .ce_text,
.teaser.bild-breit .content-text, .teaser.bild-links .content-text {
    display: inline-block;
    max-width: 34.4em;              		/* = 860px bei font-size 25px */
    padding: 1.8em 0.8em;           		/* = 50px 20px bei font-size 25px */
}

@media (min-width: 521px) {
    .teaser.bild-links .ce_image,
    .teaser.bild-links .content-image {
        float: left;
        width: 50%;
    }

    body:not(.duisburger-family) .teaser.bild-links .ce_text,
    body:not(.duisburger-family) .teaser.bild-links .content-text {
        max-width: 50%;
    }
}

.teaser:not(.breiter) a:after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


	/* -----   	Portfolioseiten    ----- */


body.portfolioseite #main > .inside {
	font-size: 0.01em;
	text-align: center;
}


body.portfolioseite .mod_article {
	display: inline-block;
	vertical-align: top;
	text-align: right;
}

body.portfolioseite.foto .mod_article {
	width: 26.04%;							/* 500px bei 1920px Elternelement-Breite */
	min-width: 287px;
    margin: 0 2.86% 370em 2.86%;			/* 55px bei 1920px Elternelement-Breite */
}

body.portfolioseite.video .mod_article {
	width: 36.46%;							/* 700px bei 1920px Elternelement-Breite */
	min-width: 287px;
    margin: 0 4.17% 370em 4.17%;			/*  55px bei 1920px Elternelement-Breite */
}

body.portfolioseite .ce_text {
	padding-top: 70em;
}

    /* -----    Galerien    ----- */

body:not(.galerie):not(.textseite):not(.mit-seitentitel) .galerie-ueberschrift {
    display: none;
}

.galerie-ueberschrift {
    margin-left: 5.208%;            /* = 100px bei Eltern-Breite 1920px */
    margin-right: 5.208%;
    margin-bottom: 1em;
}

body.duisburger-family .galerie-ueberschrift {
    margin-left: -3.75%;            /* = 60px bei Eltern-Breite 1600px */
    margin-right: -3.75%;
    margin-bottom: 2.2em;
    text-align: left;
}

	/* -----   	Galerie quer, auch aus Einzelelementen    ----- */

body.galerie.quer .ce_gallery,
body.galerie.quer .content-gallery,
.mod_article.galerie-einzelelemente {
	overflow-x: scroll;
	-webkit-overflow-scrolling: touch;
  margin-top: 2em;
  margin-bottom: 6.7rem
}

body.galerie.quer .ce_gallery:not(.nosnap),
body.galerie.quer .content-gallery:not(.nosnap),
.mod_article.galerie-einzelelemente:not(.nosnap) {
  scroll-snap-type: x mandatory;
}

body.galerie.quer .ce_gallery:after,
body.galerie.quer .content-gallery:after,
.mod_article.galerie-einzelelemente:after {
  content: "\2192";
  display: block;
  margin-left: 5.208%;
  margin-top: 0.8em;
  margin-bottom: 0.6em;
}

body.galerie.quer .ce_gallery ul,
body.galerie.quer .content-gallery ul,
.mod_article.galerie-einzelelemente {
	font-size: 0.01em;
	white-space: nowrap;
}

body.galerie.quer .ce_gallery li,
body.galerie.quer .content-gallery li,
.mod_article.galerie-einzelelemente > * {
	display: inline-block;
	vertical-align: middle;
  scroll-snap-align: center;
  font-size: 1rem;
}

body.galerie.quer .ce_gallery li,
body.galerie.quer .content-gallery li {
	margin-left: 5.208%;					/* 100px von 1720px */
	margin-right: 5.208%;					/* 100px von 1720px */
}

.mod_article.galerie-einzelelemente > * {
	margin-left: 5.21%;						/* 100px von 1920px */
	margin-right: 5.21%;					/* 100px von 1920px */
}

.mod_article.galerie-einzelelemente.enger > * {
	margin-left: 2.605%;					/* 50px von 1920px */
	margin-right: 2.605%;					/* 50px von 1920px */
}

.mod_article.galerie-einzelelemente > *:first-child {
	margin-left: 5.21%;						/* 100px von 1920px */
}

.mod_article.galerie-einzelelemente > *:last-child {
	margin-right: 5.21%;					/* 100px von 1920px */
}

body.galerie.quer .ce_gallery.villafrance li:not(:first-child),
body.galerie.quer .content-gallery.villafrance li:not(:first-child) {
	margin-left: 0.52%;
}

body.galerie.quer .ce_gallery.villafrance li:not(:last-child),
body.galerie.quer .content-gallery.villafrance li:not(:last-child) {
	margin-right: 0.52%;
}

body.galerie.quer .ce_gallery img,
body.galerie.quer .content-gallery img {
	max-height: 80vh;
}

.mod_article.galerie-einzelelemente img {
	max-height: 80vh;
}

body.galerie.quer .ce_gallery.gielen img,
body.galerie.quer .content-gallery.gielen img {
	max-width: 1132.85%;
}

.mod_article.galerie-einzelelemente .ce_image.hochformat {
	max-width: 39.835%;
}

.mod_article.galerie-einzelelemente .ce_text,
.mod_article.galerie-einzelelemente .content-text {
	white-space: normal;
}

@media (max-width: 561px) {
	.mod_article.galerie-einzelelemente .ce_text {
		width: 189vw;
    max-width: 89.58vw;
		/* column-count: 2;
		column-gap: 10vw; */
	}

	.mod_article.galerie-einzelelemente > * {
		vertical-align: top;
	}
}

	/* -----   	Galerie Kacheln    ----- */

body.galerie-kacheln .ce_gallery ul,
body.galerie-kacheln .content-gallery ul {
  width: 89.58%;
  columns: 3 370.5px;
  column-gap: 0.5vh;
  list-style-type: none;
}

body.galerie-kacheln .ce_gallery li,
body.galerie-kacheln .content-gallery li {
  margin-bottom: 0.5vh;
}

body.galerie-kacheln .ce_gallery .image_container,
body.galerie-kacheln .content-gallery figure {
  position: relative;
}

body.galerie-kacheln .ce_gallery .image_container figcaption,
body.galerie-kacheln .content-gallery figure figcaption {
  position: absolute;
  top: 42%;
  width: 100%;
  padding: 0 4%;
  pointer-events: none;
  text-align: center;
  line-height: 1.24;
  opacity: 0;
  transform: scale(0.1);
  transition: opacity,transform 0.5s;
}

body.galerie-kacheln .ce_gallery .image_container a:hover figcaption,
body.galerie-kacheln .ce_gallery .image_container a:focus figcaption,
body.galerie-kacheln .ce_gallery .image_container a:active figcaption,
body.galerie-kacheln .content-gallery figure:hover figcaption,
body.galerie-kacheln .content-gallery figure:focus-within figcaption,
body.galerie-kacheln .content-gallery figure a:hover figcaption,
body.galerie-kacheln .content-gallery figure a:focus figcaption,
body.galerie-kacheln .content-gallery figure a:active figcaption {
  opacity: 1;
  transform: scale(1);
}

body.galerie-kacheln .ce_gallery .image_container img,
body.galerie-kacheln .content-gallery figure img {
  transition: 0.8s opacity;
}

body.galerie-kacheln .ce_gallery .image_container a:hover img,
body.galerie-kacheln .ce_gallery .image_container a:focus img,
body.galerie-kacheln .ce_gallery .image_container a:active img,
body.galerie-kacheln .content-gallery figure:hover img,
body.galerie-kacheln .content-gallery figure:focus-within img,
body.galerie-kacheln .content-gallery figure a:hover img,
body.galerie-kacheln .content-gallery figure a:focus img,
body.galerie-kacheln .content-gallery figure a:active img {
  opacity: 0.3;
}


	/* -----   	Galerie Lightbox    ----- */

body.galerie.lightbox .ce_gallery,
body.galerie.lightbox .content-gallery {
	text-align: center;
	margin-bottom: 3.7em;
}

body.galerie.lightbox .ce_gallery ul,
body.galerie.lightbox .content-gallery ul {
	display: inline-block;
	font-size: 0px;
	text-align: left;
}

body.galerie.lightbox .ce_gallery li,
body.galerie.lightbox .content-gallery li {
    display: inline-block;
    position: relative;                     /* Bezugspunkt für img */
    /*background-color: #ddd;*/
}

@media (min-width: 1921px) {
    body.galerie.lightbox .ce_gallery ul,
    body.galerie.lightbox .content-gallery ul {
        width: 1780px;
    }
}


@media (max-width: 1920px) and (min-width: 801px) {
    body.galerie.lightbox .ce_gallery ul,
    body.galerie.lightbox .content-gallery ul {
        width: 92.71vw;                         /* 1780px von 1920px */
    }
}


@media (min-width: 801px) {
    body.galerie.lightbox .ce_gallery li,
    body.galerie.lightbox .content-gallery li {
    	width: 21.63%;				    		/* 385px von 1780px */
        margin: 1.685%;                 		/*  30px von 1780px */
    }

    /* bei weniger als 8 Fotos Thumbnails immer nur 2spaltig */
    body.galerie.lightbox .ce_gallery li:nth-last-child(-n+7):first-child,
    body.galerie.lightbox .ce_gallery li:nth-last-child(-n+7):first-child ~ li:nth-child(2n+1),
    body.galerie.lightbox .content-gallery li:nth-last-child(-n+7):first-child,
    body.galerie.lightbox .content-gallery li:nth-last-child(-n+7):first-child ~ li:nth-child(2n+1) {
    	margin-left: 26.68%;
    }

    body.galerie.lightbox .ce_gallery li:nth-last-child(-n+7):first-child ~ li:nth-child(2n),
    body.galerie.lightbox .content-gallery li:nth-last-child(-n+7):first-child ~ li:nth-child(2n) {
        margin-right: 26.68%;
    }
}


@media (max-width: 800px) {
    body.galerie.lightbox .ce_gallery ul,
    body.galerie.lightbox .content-gallery ul {
        width: 95.83vw;                         /* 1840px von 1920px */
    }

    body.galerie.lightbox .ce_gallery li,
    body.galerie.lightbox .content-gallery li {
        width: 43.48%;                          /* 800px von 1840px */
        margin: 3.260%;                         /*  60px von 1840px */
    }
}


body.galerie.lightbox .ce_gallery figure,
body.galerie.lightbox .content-gallery figure {
    padding-bottom: 100%;
}

body.galerie.lightbox .ce_gallery img,
body.galerie.lightbox .content-gallery img {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
}

a[class*="lightcase-icon-"], a[class*="lightcase-icon-"]:focus {
	color: rgb(140, 140, 140) !important;
	opacity: 0.5 !important;
	text-shadow: 0 0 0.05em rgb(254, 252, 250);    /* Schatten wie Burger-Icon */
}

a[class*="lightcase-icon-"]:hover {
	opacity: 1 !important;
}

a[class*="lightcase-icon-"].lightcase-icon-pause,
a[class*="lightcase-icon-"].lightcase-icon-play {
	display: none !important;
}

/* größere klick-Fläche bei Bedienelementen */
	a[class*="lightcase-icon-"].lightcase-icon-close {
		right: 0;
		padding-right: 2em;
	}

	a[class*="lightcase-icon-"].lightcase-icon-prev {
	    left: 0;
	    padding: 1em 2em 1em 1em;
	}

	a[class*="lightcase-icon-"].lightcase-icon-next {
	    right: 0;
	    padding: 1em 2em 1em 1em;
	}
/*  */

#lightcase-overlay {
	cursor: auto !important;
}

@media (min-width: 641px) {
	a[class*="lightcase-icon-"] {
		margin-bottom: -1.5em;
	}
}

@media (max-width: 640px) {
    #lightcase-info {
        display: none !important;
    }
}

#lightcase-case {
	text-shadow: none;
}

#lightcase-case #lightcase-content {
	-webkit-box-shadow: none;
	   -moz-box-shadow: none;
		 -o-box-shadow: none;
			box-shadow: none;
}


	/* -----   	Galerie Sonderformat Duisburger Family    ----- */

body.duisburger-family #container {
	padding-left: 8.333%;
	padding-right: 8.333%;
}

body.duisburger-family .teaser {
		margin-bottom: 6.25%;
	}

@media (max-width: 1330px) {
	body.duisburger-family #container {
		text-align: center;
	}

	body.duisburger-family .teaser {
		display: inline-block;
	}

	body.duisburger-family .teaser .ce_image,
	body.duisburger-family .teaser .content-image {
	    float: none;
	    width: 100%;
	}

	body.duisburger-family .teaser .ce_text,
	body.duisburger-family .teaser .content-text {
		padding-left: 2.5%;
		padding-right: 2.5%;
	}
}

body.duisburger-family .teaser p {
	font-family: vollkorn-bold, serif;
	font-size: 0.94em
}

body.duisburger-family .teaser p em{
	font-family: vollkorn-semibolditalic, serif;
	font-size: 1.064em
}

body.duisburger-family .teaser figure {
	padding: 2.5%;
}

@media (min-width: 1331px) {
	body.duisburger-family .teaser.bild-links:nth-child(2n+1) .ce_image,
	body.duisburger-family .teaser.bild-links:nth-child(2n+1) .content-image {
		float: right;
	}

	body.duisburger-family .teaser .ce_text,
	body.duisburger-family .teaser .content-text {
		position: absolute;
		right: 0;
		bottom: 0;
		width: 41%;
	}

	body.duisburger-family .teaser.bild-links:nth-child(2n+1) .ce_text,
	body.duisburger-family .teaser.bild-links:nth-child(2n+1) .content-text {
		left: 0;
		right: auto;
	}
}

body.duisburger-family .teaser.infotext {
	margin-bottom: 3.7em;
}

@media (max-width: 1330px) {
	body.duisburger-family .teaser.infotext {
		max-width: 760px;
	}
}

body.duisburger-family .teaser.infotext .ce_text,
body.duisburger-family .teaser.infotext .content-text {
	position: relative;
	width: 100%;
	padding: 1.8em 0.8em;
	text-align: left;
}


	/* -----   	Video    ----- */


/*Angaben für mejs responsive*/
.mejs__container {
  width: 100% !important;
  height: auto !important;
  padding-top: 56.25%;
}
.mejs__overlay, .mejs__poster {
  width: 100% !important;
  height: 100% !important;
}
.mejs__mediaelement video {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  width: 100% !important;
  height: 100% !important;
}
/*Ende der Angaben für mejs responsive*/

body.portfolioseite.video .content-player figure {
	margin: 0;
	position: relative;
	aspect-ratio: 16 / 9;
}

body.portfolioseite.video .content-player figure:after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 80px;
	height: 80px;
	background-image: url("css-img/mejs-controls.svg");
	background-position: -80px -39px;
	opacity: 0;
	pointer-events: none;
	transform: translate(-50%, -50%);
	transition: opacity 0.3s;
}

body.portfolioseite.video .content-player figure.is-video-hover:after {
	opacity: 0.7;
}

body.portfolioseite.video .content-player video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

body.portfolioseite.video .content-player audio {
	width: 100%;
}


.mejs__overlay-button {
	opacity: 0;
	-webkit-transition: opacity 0.3s;
			transition: opacity 0.3s;
}

.mejs__overlay:hover > .mejs__overlay-button {
	opacity: 0.7;
}


	/* -----   	Textseiten    ----- */

.mod_article.text2spaltig:after {
	content: "";
	margin-bottom: 3.7em;
}

.mod_article.text2spaltig .ce_text,
.mod_article.text2spaltig .content-text {
	vertical-align: top;
	text-align: left;
}

@media (min-width: 801px) {
	body:not(.datenschutz) .mod_article.text2spaltig .ce_text,
	body:not(.datenschutz) .mod_article.text2spaltig .content-text {
		width: 46.51%;
	}
}


/* -----   	Farben    ----- */

html, a,
#container-header .navi.portfolio a.trail {		/* aktive Rubrik highlighten */
  color: rgb(41, 41, 41);
}

.teaser.breiter p, .teaser.breiter p a {
	color: rgb(90, 90, 90);
}

#container-header a, #container-footer a,
#lightcase-info #lightcase-title,
.galerie-ueberschrift,
body.duisburger-family .teaser {
	color: rgb(140, 140, 140);
}

.navi.komplett a {
	color: rgb(255, 255, 255)
}

.navi.komplett strong {
	color: rgba(255, 255, 255, 0.3);
}


/* -----    Rahmen    ----- */

#container-header .inner,
#container-footer .inner {
	border: 0 solid rgb(254, 252, 250);
}

body:not(.no-portfolio-navi) #container-header .inner {
	border-bottom-width: 1px;
}

#container-footer .inner {
	border-top-width: 1px;
}


/* -----    Hintergründe    ----- */

html {
	background-color: #fff;
}

#wrapper, #lightcase-overlay {
	background-color: rgb(254, 252, 250);
}

/*body.galerie.quer #wrapper,
body.duisburger-family #wrapper {
	background-color: rgb(235, 235, 235);
}*/

.teaser.bild-breit, .teaser.bild-links, .teaser.breiter,
body:not(.no-portfolio-navi) #container-header .inner,
#container-footer .inner,
body.galerie.quer #wrapper,
body.duisburger-family #wrapper {
	background-color: rgb(245, 243, 241);
}

body.duisburger-family .teaser {
	background-color: rgb(255, 255, 255);
}

#container-navi-komplett {
	background-color: rgba(0, 0, 0, 0.83);
}

#navitoggle {
	filter: drop-shadow(0 0 0.05em rgb(254, 252, 250));
}


/* -----   	Typo    ----- */

html, p, li,
#navitoggle, #copyright, #lightcase-case {
	font-family: gothic_a1regular, sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
}

html, p, li,
#navitoggle, #copyright,
.mod_article.text2spaltig .ce_text, .mod_article.text2spaltig:after,
.mod_article.text2spaltig .content-text,
.mod_article.galerie-einzelelemente:after {
	font-size: 25px;
	line-height: 1.24;
}

@media (min-width: 501px) and (max-width: 1920px) {
    html, p, li,
    #navitoggle, #copyright,
    .mod_article.text2spaltig .ce_text, .mod_article.text2spaltig:after,
    .mod_article.text2spaltig .content-text,
    .mod_article.galerie-einzelelemente:after {
        font-size: 18px;
        font-size: calc(0.682vw + 11.9px);      /* = 25px bei 1920px Breite, 16px bei 600px Breite */
    }
}

@media (max-width: 500px) {
    html, p, li,
    #navitoggle, #copyright,
    .mod_article.text2spaltig .ce_text, .mod_article.text2spaltig:after,
    .mod_article.text2spaltig .content-text,
    .mod_article.galerie-einzelelemente:after {
        font-size: 16px;
    }
}

h1, h2 {
	font-size: 1.12em;
	padding-bottom: 1.25em;
}

h2 {
	font-family: gothic_a1_mediumregular;
	padding-top: 2.5em;
}

h3 {
	font-family: gothic_a1_mediumregular;
	font-size: 1em;
	padding-top: 1.24em;
}

p + p, ol + p, p + ol,
.mod_article.text2spaltig .ce_text,
.mod_article.text2spaltig .content-text {
	padding-top: 1.24em;
}

#container .ce_text li + li,
#container .content-text li + li {
  padding-top: 0.62em;
}

ol {
	padding-left: 1.3em;
}

.mod_article li {
  list-style-position: inside;
}

em {
	font-style: normal;
}

.navi.portfolio li a, .navi.portfolio li strong,
.navi.service li a, .navi.service li strong,
#copyright span {
	font-size: 0.8em;
}

.navi strong {
	font-weight: normal;
}

a {
	text-decoration: none;
}

a:hover, .a:focus, a:active {
	text-decoration: underline;
}

.teaser:not(.breiter) a:hover, .teaser:not(.breiter) a:focus, .teaser:not(.breiter) a:active,
a[class*="lightcase-icon-"]:hover, a[class*="lightcase-icon-"]:focus, a[class*="lightcase-icon-"]:active {
	text-decoration: none;
}

a[class*="lightcase-icon-"]:hover, a[class*="lightcase-icon-"]:focus, a[class*="lightcase-icon-"]:active


/*! Generated by Font Squirrel (https://www.fontsquirrel.com) on October 12, 2018 */

/*@font-face {
    font-family: 'gothic_a1_blackregular';
    src: url('fonts/gothica1-black-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'gothic_a1bold';
    src: url('fonts/gothica1-bold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'gothic_a1_extraboldregular';
    src: url('fonts/gothica1-extrabold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'gothic_a1_extralightregular';
    src: url('fonts/gothica1-extralight-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'gothic_a1_lightregular';
    src: url('fonts/gothica1-light-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}*/

@font-face {
    font-family: 'gothic_a1_mediumregular';
    src: url('fonts/gothica1-medium-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'gothic_a1regular';
    src: url('fonts/gothica1-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/*@font-face {
    font-family: 'gothic_a1_semiboldregular';
    src: url('fonts/gothica1-semibold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'gothic_a1_thinregular';
    src: url('fonts/gothica1-thin-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}*/


@font-face {
    font-family: 'vollkorn-bold';
    src: url('fonts/_vollkorn-bold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'vollkorn-semibolditalic';
    src: url('fonts/_vollkorn-semibolditalic-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}


/*@font-face {
  font-family: 'fontawesome';
  src: url('fonts/fontawesome-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}*/
