/*
-----------------------------------------------
	www.dannien-roller-architekten-partner.de
 by www.christinaschmid.de
and www.claraneumann.fr
and www.lichtsignale.de
----------------------------------------------- */


/*		R E S E T
----------------------------------------------- */

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    font-feature-settings: "liga" 0, "clig" 0;
	-moz-font-feature-settings: "liga" 0, "clig" 0;
	-ms-font-feature-settings: "liga" 0, "clig" 0;
	-o-font-feature-settings: "liga" 0, "clig" 0;
	-webkit-font-feature-settings: "liga" 0, "clig" 0;
	font-variant-numeric: proportional-nums; 
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

html {
	height: 100%;
	-ms-text-size-adjust: none;
	-webkit-text-size-adjust: none;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section { 
    display: block;
}

blockquote, q {
    quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content: "";
    content: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    outline: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

input, select {
    vertical-align: middle;
}


/*		W E B F O N T S
----------------------------------------------- */

/**
* @license
* MyFonts Webfont Build ID 3932539, 2020-08-04T13:49:04-0400
* 
* The fonts listed in this notice are subject to the End User License
* Agreement(s) entered into by the website owner. All other parties are 
* explicitly restricted from using the Licensed Webfonts(s).
* 
* You may obtain a valid license at the URLs below.
* 
* Webfont: NeueHaasUnicaW1G-Regular by Linotype
* URL: https://www.myfonts.com/fonts/linotype/neue-haas-unica/regular/
* Copyright: Copyright &amp;#x00A9; 2016 Monotype Imaging Inc. All rights reserved.
* 
* 
* 
* © 2020 MyFonts Inc
*/


/* @import must be at top of file, otherwise CSS will not work */
@import url("//hello.myfonts.net/count/3c017b");

@font-face {
	font-family: "NeueHaasUnicaW1G-Regular";
	src: url("fonts/font.woff2") format("woff2"),
	url("fonts/font.woff") format("woff");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}


/*		B A S I C S
----------------------------------------------- */

body {
	color: #000;
	background: #fff;
	font-family: "NeueHaasUnicaW1G-Regular", "Helvetica Neue", Helvetica, "Roboto", Arial, sans-serif;
	font-size: 17px;
	line-height: 24px;
	letter-spacing: 0.025em;
	text-align: left;
}

*:focus {
	outline: none;
}

img {
	max-width: 100%;
	height: auto;
}

h1, h2, h3, h4, h5, h6, strong, em, b, i {
	font-weight: normal;
	font-style: normal;
}

a:link, a:visited {
	text-decoration: none;
	color: #000;
}

a:hover, a:active {
	color: #999;
}

.active a:link, .active a:visited {
	text-decoration: none;
	color: #999;
}

.active a:hover, .active a:active {
	color: #000;
}

main span a:link, main span a:visited {
	border-bottom: 1px solid #999;
	position: relative;
	z-index: 3000;
}

#wrapper {
	margin: 8px 12px 0 12px;
}

#wrapper::after, header::after, .entry::after {
	content: "";
	clear: both;
	display: table;
}

img {
	position: relative;
	z-index: 20;
}


/*		H E A D E R
----------------------------------------------- */

header {
	margin-bottom: 24px;
}

header a {
	display: block;
	white-space: nowrap;
}

header h1 {
	background: #fff;
	position: relative;
	z-index: 20;
}

header h1 span {
	padding-left: 3px;
	white-space: nowrap;
}

nav {
	margin-top: 6px;
	margin-bottom: 24px;
	background: #fff;
	position: relative;
	z-index: 20;
}

nav li {
	list-style: none;
	display: inline-block;
	margin-right: 6px;
}

#secondary {
	background: #fff;
	position: relative;
	z-index: 20;
}

#secondary li {
	list-style: none;
	display: inline-block;
	margin-right: 6px;
	margin-bottom: 6px;
}


/*		M A I N
----------------------------------------------- */

main span {
	background: #fff;
	position: relative;
	z-index: 20;
	display: inline-block;
}

main#buero span {
}

main {
	margin-top: 48px;
}

main::after {
	content: "";
	clear: both;
	display: table;
}

h2 {
	font-size: 150%;
	font-size: 1.7rem;
	letter-spacing: -0.005em;
	line-height: 1.2;
	margin-bottom: 24px;
	position: relative;
	left: -1px;
	z-index: 250;
}

h2.htitle {
	background: #fff;
	display: block;
}

h2.htitle:after {
	content: " ";
	display: block;
}

h2.htitle span {
	background: transparent;
}

main #lefthalf h2, main #righthalf h2 {
	background: #fff;
}

main #lefthalf h2 span, main #righthalf h2 span {
	background: transparent;
}

aside {
	margin-bottom: 48px;
}


/*		H O M E
----------------------------------------------- */

#home {
	position: relative;
	z-index: 20;
}

#home a {
	display: block;
	border-bottom: none;
	margin-bottom: 48px;
}

#home a:last-child {
	margin-bottom: 12px;
}


/*		A K T U E L L
----------------------------------------------- */

.entry {
	margin-bottom: 72px;
}

.entry:last-child {
	margin-bottom: 12px;
}

.meta {
	font-size: 80%;
	letter-spacing: 0.065em;
	line-height: 1.2;
	position: relative;
	z-index: 1000;
}

.meta br {
	display: none;
}

.contcont {
	padding-top: 22px;
}

.images {
	padding-top: 36px;
	position: relative;
	z-index: 100;
}

.cycle-slideshow img {
	cursor: pointer;
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
}

.numbers {
	margin-top: 6px;
}

.numbers a {
	display: inline-block;
	border-bottom: none !important;
	padding-right: 12px;
	color: #999;
	background: #fff;
}

.numbers a:hover {
	color: #000;
}

.numbers .cycle-pager-active {
	color: #000;
}


/*		P R O J E K T E
----------------------------------------------- */

#projekte #filter {
	background: #fff;
	position: relative;
	z-index: 15;
}

#projekte #filter li {
	display: inline-block;
	margin: 0 6px 6px 0;
	position: relative;
	z-index: 20;
}

#projekte #filter a {
	border-bottom: none;
}

#projekte #overview a {
	position: relative;
	display: block;
	margin-bottom: 48px;
	border-bottom: none;
}

#projekte #overview a:last-child {
	margin-bottom: 12px;
}

#projekte #overview a br:nth-child(2), #projekte #overview a br:nth-child(3) {
	display: none;
}

#projekte #overview em {
	font-style: normal;
}

#projekt aside {
	margin-bottom: 48px;
}

#projekt h2 {
	margin-bottom: 24px;
}

#projekt aside h2 {
	margin-bottom: 0;
	margin-top: 24px;
}

#images {
	margin-top: 24px;
	margin-bottom: 40px;
}

#images img {
	margin-bottom: 7px;
}

.onlydesktop {
	display: none;
}

.onlymobile {
	position: relative;
	z-index: 100;
}


/*		B Ü R O
----------------------------------------------- */

#lefthalf {
	margin-bottom: 48px;
}

#lefthalf img, #righthalf img {
	margin-bottom: 18px;
}

#righthalfimg {
	margin-bottom: 11px !important;
}

.buerotext {
	margin-bottom: 48px;
}

.person {
	margin-bottom: 48px;
}

.person:last-child {
	margin-bottom: 12px;
}


/*		F O O T E R
----------------------------------------------- */

footer, #internav {
	padding: 48px 0 12px 0;
	clear: both;
	position: relative;
	z-index: 200;
}

#internav li {
	list-style: none;
}

#internav li:first-child {
	float: left;
}

#internav li:last-child {
	float: right;
}

footer a, #internav a {
	background: #fff;
}


/*		P L U S S E S
----------------------------------------------- */

#plus {
	position: fixed;
	left: 12px;
	top: 8px;
	z-index: 10;
	width: calc(100vw - 24px);
	height: 100vh;
}

#plus ul {
	display: flex;
	justify-content: space-between;
}

#plus li {
	list-style: none;
	display: inline-block;
}

#p2, #p3, #p4 {
	margin-top: 22vh;
}

.p4, .p5 {
	display: none !important;
}


/*		R E S P O N S I V E
----------------------------------------------- */

@media screen and (min-width: 350px) {

header h1 span {
	padding-left: 12px;
	white-space: nowrap;
}

}


@media screen and (min-width: 450px) {

#wrapper {
	margin: 19px 24px 0 24px;
	padding-bottom: 12px;
}

#plus {
	left: 24px;
	top: 19px;
	width: calc(100vw - 48px);
}

}


@media screen and (min-width: 550px) {

#projekte #overview a {
	width: 45%;
	width: calc(50% - 24px);
	float: left;
}

#projekte #overview a:nth-child(odd) {
	margin-right: 48px;
}

}


@media screen and (min-width: 600px) {

.person {
	width: 45%;
	width: calc(50% - 24px);
	float: left;
}

.person:nth-child(even) {
	margin-right: 48px;
}

}


@media screen and (min-width: 720px) {

.onlydesktop {
	display: block;
}

.onlymobile {
	display: none;
}

header {
	margin-bottom: 80px;
}

#buero, #team {
	position: relative;
	margin-top: -36px !important;
}

header h1 {
	display: inline-block;
}

nav {
	display: inline-block;
	float: right;
	margin: 0;
	position: relative;
	margin-right: -7px;
	padding-bottom: 10px;
	margin-bottom: -10px;
}

#secondary {
	float: right;
	margin-top: 6px;
	position: relative;
	margin-right: -7px;
	clear: both;
}

#projekt h2, #projekt aside, #lefthalf, .entry .meta, .entry .content, .buerotext {
	float: left;
	width: 45%;
	width: calc(50% - 24px);
}

#projekt h2, #lefthalf h2, #projekte #filter, .buerotext h2 {
	position: relative;
	margin-top: -7px;
}

#projekt #images, #righthalf, .entry .images {
	float: right;
	width: 45%;
	width: calc(50% - 24px);
}

#lefthalf.bc-left {
	float: left;
	width: 30%;
	width: calc(100% / 3 - 24px);
}

#righthalf.bc-right {
	float: right;
	width: 60%;
	width: calc(100% / 3 * 2 - 24px);
}

.buerotext {
	margin-right: 48px;
	position: relative;
	margin-top: -5px;
}

.person:nth-child(even) {
	margin-right: 0;
}

.person:nth-child(odd) {
	margin-right: 48px;
}

.entry .content {
	clear: left;
}

.entry .images {
	padding-top: 0;
	margin-top: -12px;
	position: relative;
}

#projekt aside h2 {
	float: none;
	width: 100%;
}

#images {
	margin-top: 0;
}

}


@media screen and (min-width: 960px) {

#projekt aside, #projekte #overview em, .buerotext, .person span, #lefthalf, #righthalf, #home a, .entry .content, .entry .meta, .numbers, footer {
	font-size: 90%;
	line-height: 20px;
	letter-spacing: 0.04em;
	display: block;
}

#projekt h2, #projekt aside, #projekte aside {
	float: left;
	width: 30%;
	width: calc(100% / 3 - 24px);
}

#projekt #images, #projekte #overview {
	float: right;
	width: 60%;
	width: calc(100% / 3 * 2 - 24px);
}

#projekte #filter {
	background: transparent;
	position: inherit;
}

#projekte #filter li {
	display: block;
	margin: 0;
}

#projekte #filter a {
	background: #fff;
}

#projekte #overview em {
	display: none;
	position: absolute;
	left: 0;
	top: -5px;
}

#projekte #overview a br:nth-child(2), #projekte #overview a br:nth-child(3) {
	display: inline;
}

#projekte #overview a:hover img {
	opacity: 0;
}

#projekte #overview a:hover em {
	display: block;
	width: 100%;
	height: 300px;
	height: calc(100vw / 3 - 144px);
	color: #000;
	background: transparent;
}

.buerotext {
	width: 60%;
	width: calc(100% / 3 * 2 - 16px);
}

.person {
	float: left;
	width: 30%;
	width: calc(100% / 3 - 32px);
}

.person:nth-child(odd) {
	margin-right: 0;
}

.person:nth-child(3n), .person:nth-child(3n+1) {
	margin-right: 48px;
}

.person:nth-child(3n) {
	clear: both;
}

#home {
	position: absolute;
	left: 0;
	top: 43px;
	height: calc(100% - 91px);
	overflow-x: scroll;
	white-space: nowrap;
	padding: 0 6px 0 24px;
}

#home a {
	display: inline-block;
	white-space: normal;
	margin-right: 18px;
	width: auto;
}

#home img {
	width: auto;
	max-height: 75vh;
}

.entry .meta {
	display: inline-block;
	vertical-align: top;
	float: none;
	width: 15%;
	width: calc(100% / 8 + 24px);
	margin-top: 1px;
}

.entry .meta br {
	display: inherit;
}

.entry .content {
	display: inline-block;
	vertical-align: top;
	float: none;
	width: 50%;
	width: calc(50% - 48px);
}

.entry .images {
	float: right;
	width: 30%;
	width: calc(100% / 3 + 16px);
	margin-top: 6px;
}

.p4, .p5 {
	display: inline-block !important;
}

header h1 {
	width: 40%;
}

nav {
	padding-left: 20%;
}

}


@media screen and (min-width: 1200px) {

#projekte aside {
	width: 25%;
	width: calc(25% - 24px);
}

#projekte #overview {
	width: 70%;
	width: calc(75% - 12px);
}

#projekte #overview a {
	width: 30%;
	width: calc(100% / 3 - 32px);
	float: left;
}

#projekte #overview a:nth-child(odd) {
	margin-right: 0;
}

#projekte #overview a:nth-child(3n+1) {
	margin-right: 48px;
}

#projekte #overview a:nth-child(3n+2) {
	margin-right: 48px;
}

#projekte #overview a:hover span {
	height: 400px;
	height: calc(25vw - 120px);
}

.buerotext {
	width: 45%;
	width: calc(50% - 24px);
}

.person {
	width: 22%;
	width: calc(25% - 36px);
	margin-right: 48px !important;
}

.person:nth-child(4n+3) {
	margin-right: 0 !important;
}

.person:nth-child(3n) {
	clear: inherit;
}

.person:nth-child(4n) {
	clear: both;
}

}


@media screen and (min-width: 1400px) {

body {
	font-size: 22px;
	line-height: 30px;
	letter-spacing: 0.02em;
}

main span a {
	line-height: 25px;
}

.contcont {
	padding-top: 30px;
}

#projekt aside, #projekte #overview em, .buerotext, .person span, #lefthalf, #righthalf, #home a, .entry .content, .entry .meta, .numbers, footer {
	font-size: 16px;
	line-height: 23px;
	letter-spacing: 0.025em;
}

#wrapper {
	margin: 25px 45px 0 45px;
	padding-bottom: 25px;
}

#plus {
	left: 45px;
	top: 25px;
	width: calc(100vw - 90px);
}

header {
	margin-bottom: 80px;
}

#buero, #team {
	margin-top: -33px !important;
}

header h1 span {
	padding-left: 15px;
}

nav, #secondary {
	margin-right: -17px;
}

nav li, #secondary li {
	margin-right: 15px;
}

main {
	margin-top: 90px;
}

h2 {
	font-size: 200%;
	font-size: 2.25rem;
	letter-spacing: -0.01em;
	line-height: 1.2;
	margin-bottom: 30px;
	left: -2px;
}

.entry {
	margin-bottom: 90px;
	width: 100%;
}

.entry:last-child {
	margin-bottom: 12px;
}

#projekt h2 {
	margin-bottom: 30px;
}

#projekt aside h2 {
	margin-bottom: 0;
	margin-top: 30px;
}

#projekt h2, #lefthalf h2, #projekte #filter, .buerotext h2 {
	margin-top: -10px;
}

#images img {
	margin-bottom: 15px;
}

#lefthalf img, #righthalf img {
	margin-bottom: 24px;
}

#righthalfimg {
	margin-bottom: 14px !important;
}

#home {
	top: 43px;
	height: calc(100% - 133px);
	padding: 0 0 0 45px;
}

#home a {
	margin-right: 24px;
}

#home a:last-child {
	margin-right: 45px;
}

#projekte aside {
	width: 25%;
	width: calc(25% - 45px);
}

#projekte #overview {
	width: 70%;
	width: calc(75% - 45px);
}

#projekte #overview a {
	width: calc(100% / 3 - 60px);
	margin-bottom: 70px;
}

#projekte #overview a:nth-child(odd) {
	margin-right: 0;
}

#projekte #overview a:nth-child(3n+1), #projekte #overview a:nth-child(3n+2) {
	margin-right: 90px;
}

#projekte #overview a:hover span {
	height: calc(25vw - 175px);
}

.buerotext {
	width: 45%;
	width: calc(50% - 24px);
	margin-right: 69px;
}

.person {
	width: 22%;
	width: calc(25% - 67.5px);
	margin-right: 90px !important;
}

.person:nth-child(4n+3) {
	margin-right: 0 !important;
}

#projekt h2, #projekt aside, #lefthalf.bc-left {
	width: calc(100% / 3 - 45px);
}

#projekt #images, #righthalf.bc-right {
	width: calc(100% / 3 * 2 - 45px);
}

#lefthalf, #righthalf {
	width: calc(50% - 45px);
}

.entry .meta {
	width: calc(100% / 8 + 45px);
	margin-top: 3px;
}

.entry .content {
	width: calc(50% - 90px);
}

.entry .images {
	width: calc(100% / 3 + 16px);
	margin-top: 8px;
}

footer {
	padding: 60px 0 15px 0;
}

}


@media screen and (min-width: 1900px) {

body {
	font-size: 26px;
	line-height: 35px;
	letter-spacing: 0.01em;
}

#buero, #team {
	margin-top: -37px !important;
}

#projekt aside, #projekte #overview em, .buerotext, .person span, #lefthalf, #righthalf, #home a, .entry .content, .entry .meta, .numbers, footer {
	font-size: 20px;
	line-height: 27px;
	letter-spacing: 0.025em;
}

#projekte #overview a:hover span {
	height: calc(25vw - 215px);
}

.contcont {
	padding-top: 25px;
}

}