/* =================================================================== */
/*
		Template: Sony CSL Paris
*/
/* =================================================================== */


/* =================================================================== */
/* Import */

@import url("base.css");

/* =================================================================== */


/* =================================================================== */
/* Structure */

#wrapper {
	position: relative;
	width: 980px;
	padding: 0;
	margin: 20px auto 0 auto;
}
#leftcol {
	position: fixed;
	top: 20px;
	height: 100%;
	width: 220px;
}
#logo-main {
	padding: 0;
	margin: 0;
}
#logo-sub {
	font-size: 30px;
	line-height: 27px;
	color: #999;
	padding: 0;
	margin: 10px 0 0 0;
	height: 60px;
	font-family: Helvetica;
	font-weight: bold;
}
#social {
	margin-bottom: 80px;
}
#youtube {
	margin-top: 30px;
	margin-bottom: 10px;
}
.nav {
	display: block;
}
#toggle, .toggle {
	display: none;
	z-index: 2;
}
.menu {
	margin: 0;
	padding: 0;
	width: 220px;
	display: block;
	list-style: none;
	border-bottom: 1px solid #000;
}
.menu > li {
	list-style: none;
}
.menu > li > a {
	color: #999;
	font-family: 'texgyreherosbold';
	padding: 2px 0 3px 0;
	text-transform: uppercase;
	text-decoration: none;
	border-top: 1px solid #000;
	display: block;
	font-weight: normal;
	font-size: 14px;
	line-height: 20px;
	-webkit-transition: all 0.25s linear;
	-moz-transition: all 0.25s linear;
	-o-transition: all 0.25s linear;
	transition: all 0.25s linear;
}
.menu > li.active > a {
	color: #000;
}
.menu > li > a:hover, .menu > li > a:focus {
	color: #000;
}
.menu > li > ul {
        display: none;
}
.menu > li.active > ul {
	display: block;
	margin: -1px 0 4px 0;
	padding: 0;
	list-style: none;
}
.menu > li > ul > li {
	list-style: none;
	margin: 0;
	padding: 0 0 0 20px;
}
.menu > li > ul > li:last-child {
	padding-top: 3px;
}
.menu > li > ul > li > a {
	margin: 0;
	padding: 0;
	font-family: 'texgyreherosregular';
	font-size: 14px;
	line-height: 16px;
}
div.copyright {
	position: fixed;
	bottom: 20px;
	width: 220px;
}
div.copyright a {
	font-family: 'texgyreherosregular';
	font-size: 11px;
	color: #999;
}
div.copyright a:hover {
	color: #000;
}
#page {
	background: #fff;
	width: 740px;
	padding: 0;
	margin: 0 0 40px 240px;
}
div.hidden {
    display: none;
}
div.visible {
    display: block;
}
#home-title-wrapper {
	margin: -2px 0 100px 0;
	padding: 0;
	height: 10px;
}
#home-title-wrapper p {
	font-size: 18px;
	line-height: 24px;
}

div.openhouse a {
	font-size: 18px;
	line-height: 80px;
	color: green;
}

.openhouse {
	margin-bottom: 30px;
}

.openhouse-table{
	width: 100%;
	text-align: left;
}
.banner-frame {
	border: 5px solid green;
	margin-bottom: 10px;
}
#area-wrapper {

}
.area {
	padding: 0;
	margin: 0 20px 20px 0;
	float: left;
	width: 360px;
}
.area:nth-child(even) {
	margin-right: 0;
}
.area-title-wrapper {
	height: 33px;
	width: 100%;
	margin: 0 0 14px 0;
	padding: 0;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
}
a.area-title {
	margin: 0;
	padding: 0;
	font-family: 'texgyreherosbold';
	text-transform: uppercase;
	font-size: 23px;
	line-height: 30px;
	font-weight: normal;
	font-style: normal;
        -webkit-transition: all 0.25s linear;
        -moz-transition: all 0.25s linear;
        -o-transition: all 0.25s linear;
        transition: all 0.25s linear;

}
a.area-title:hover {
	color: #999;
}
img.area-title-img {
	border: none;
	margin: 0 0 14px 0;
	padding: 0;
	width: 100%;
}
a img.area-title-img {
        opacity: 1
	-webkit-transition: opacity 0.25s linear;
        -moz-transition: opacity 0.25s linear;
        -o-transition: opacity 0.25s linear;
        transition: opacity 0.25s linear;
	backface-visibility: hidden;
}
a:hover img.area-title-img {
        opacity: 0.8;
	backface-visibility: hidden;
}
.home-menu {
	margin: 0;
	padding: 0;
	width: 360px;
	display: block;
	list-style: none;
	border-bottom: 1px solid #000;
}
.home-menu > li {
	margin: 0;
	padding: 0;
	list-style: none;
	height: 32px;
	width: 100%;
}
.home-menu > li > a {
	display: inline-block;
	color: #000;
	font-family: 'texgyreherosbold';
	margin: 0;
	padding: 0;
	text-transform: uppercase;
	text-decoration: none;
	border-top: 1px solid #000;
	font-weight: normal;
	font-size: 23px;
	line-height: 30px;
	width: 100%;
	-webkit-transition: all 0.25s linear;
	-moz-transition: all 0.25s linear;
	-o-transition: all 0.25s linear;
	transition: all 0.25s linear;
}
.home-menu > li > a.active {
	color: #999;
}
.home-menu > li > a:hover, .home-menu > li > a:focus {
	color: #999;
}
#title-wrapper {
	display: inline-block;
	height: 38px;
	width: 500px;
	margin: 0 0 180px 0;
	padding: 0;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
}
#title-wrapper-full {
	display: inline-block;
	height: 38px;
	width: 100%;
	margin: 0 0 20px 0;
	padding: 0;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
}
h1.title {
	font-family: 'texgyreherosbold';
	text-transform: uppercase;
	font-size: 23px;
	line-height:normal;
	line-height: 34px;

	padding: 0;
	margin: 0;
	font-weight: normal;
	font-style: normal;
}
#title-img-wrapper {
	width: 220px;
        margin: 0;
        padding: 0;
        float: right;
}
img.title-img {
	width: 100%;
	height: auto;
}
.content {
	width: 500px;
	margin: 0;
	padding: 0;
}
.content-full {
	width: 100%;
	margin: 160px 0 0 0;
}
#members {
	margin: 0 0 20px 0;
}
h2.subtitle {
	font-family: 'texgyreherosbold';
	font-size: 15px;
	line-height: 20px;
	margin: 0 0 20px 0;
	font-weight: normal;
	font-style: normal;
}
h2.people {
	font-family: 'texgyreherosbold';
	font-size: 15px;
	line-height: 20px;
	margin: 28px 0 14px 0;
	font-weight: normal;
	font-style: normal;
}
h3 {
        font-family: 'texgyreherosbold';
        font-size: 15px;
        line-height: 20px;
        margin: 0 0 20px 0;
        font-weight: normal;
        font-style: normal;
}
#vision {
	margin: 20px 0 0 0;
}
#projects-wrapper {
	margin: 35px 0 0 0;
}
#projects-header {
	font-family: 'texgyreherosbold';
	text-transform: uppercase;
	font-size: 23px;
	line-height: 23px;
	font-weight: normal;
	font-style: normal;
	margin: 0 0 20px 0;
}
.project-title-wrapper {
	display:inline-block;
	width: 500px;
	margin: 0;
	padding: 0;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
}
h4.project-title {
	font-family: 'texgyreherosbold';
	text-transform: uppercase;
	font-size: 15px;
	line-height: 20px;
	margin: 0 0 0 0;
	padding: 2px 0 2px 0;
	font-weight: normal;
	font-style: normal;
}
img.title-img-proj {
	width: 220px;
	height: auto;
	border: none;
	margin: 0 0 20px 0;
	padding: 0;
	float: right;
}
.project-desc {
	margin: 20px 0 20px 0;
}
#publications {

}
#bibtex {

}
#publications-header {
	font-family: 'texgyreherosbold';
	text-transform: uppercase;
	font-size: 23px;
	line-height: 23px;
	font-weight: normal;
	font-style: normal;
	margin: 35px 0 20px 0;
}
.bibentry {
	display: block;
	width: 100%;
	border-top: 1px solid #000;
	padding: 6px 0px 8px 0;
}
.bibentry:first-child {
	border-top: none;
}
.bibauthors {
	float: left;
	width: 89%;
	padding: 0 8px 0 0;
	display: inline;
	line-height: 18px;
}
.bibtitle {
	float: left;
	width: auto;
	padding: 0 8px 0 0;
        display: inline;
}
.bibref {
	float: left;
	width: auto;
	padding: 0 4px 0 0;
        display: inline;
}
.bibyear {
	float: left;
	text-align: right;
	width: 7%;
}
.bibdoc {
	float: left;
	text-align: right;
	width: 4%;
}
a.title:link {
    color: rgb(4, 122, 139);
    text-decoration: none;
}
.bibdetails {
	margin: 10px 0 10px 0;
	width: 100%;

}
p.abstract > span {
	display: block;
	margin: 0 0 4px 0;
	font-family: 'texgyreherosbold';
	font-weight: normal;
	font-style: normal;
}
span.bibtex-line {
	display: block;
	margin: 0;
}
span.indent {
	padding-left: 36px;
}
.centertext {
	width: 500px;
}
table.stafflist {
	border: 0px none;
	border-spacing: 0px;
	width: 100%;
}
table.stafflist td.name {
	border: 0px none;
	margin: 0;
	padding: 0 0 8px 0px;
	width: 42%;
}
table.stafflist td.staffrole {
	border: 0px none;
	margin: 0;
	padding: 0 0 8px 0px;
	width: 58%;
}
.linkmorepeople {
	margin: 36px 0 0 0;
}
#people_left {
	width: 500px;
	float: left;
	margin: 0;
	padding: 0;
}
#people_right {
	width: 220px;
	float: right;
	margin: 0;
	padding: 0;
}
p.staff_desc {
	margin: 10px 0;
	padding: 0;
}
p.disclaimer {
	margin: -14px 0 14px 0;
	padding: 0;
	font-size: 12px;
}
.formfield {
	height: 185px;
	border-bottom: 1px solid #000;
}
.left { float: left; }
.right { float: right; }

.clearfix:before, .clearfix:after { display: table; content: ""; }
.clearfix:after { clear: both; }

footer.footer {
        display: none;
}

/* =================================================================== */

@media only screen and (max-width: 1030px) {

	#wrapper {
		margin: 0;
		padding: 0 4%;
		width: 100%;
	}
	#page {
		width: auto;
		margin-top: 20px;
	}
	.area {
		width: 100%;
	}
	.home-menu {
		width: 100%;
	}
	#title-img-wrapper {
		margin-left: 20px;
		margin-bottom: 20px;
	}
	#title-wrapper {
		display: block;
		width: 100%;
		margin-bottom: 20px;
	}
	.content {
		width: 100%;
	}
	.project-title-wrapper {
		width: 100%;
		margin-bottom: 20px;
	}
	.project-desc {
		float: left;
		width: 42%;
	}
	img.title-img-proj {
		float: right;
		margin-bottom: 20px;
		width: 42%;
	}
}

@media only screen and (max-width: 780px) {

	#wrapper {
		margin: 4% 0 0 0;
		padding: 0 4%;
		width: 100%;
	}
	#leftcol {
		position: relative;
		width: 100%;
		height: 210px;
		top:inherit;
	}
	#logo-main {
		position: absolute;
		top: 0;
		left: 0;
	}
	#logo-sub {
		position: absolute;
		top: 46px;
		left: 0;
	}
	#social {
		position: absolute;
		top: 82px;
		right: 0;
	}
	.nav {
		width: 220px;
		position: absolute;
		top: 0;
		right: 0;
	}
	.menu {
		display: none;
		opacity: 0;
		width: 100%;
		position: absolute;
		top: 38px;
		right: 0;
		background: #FFFFFF;
		border-bottom: none;
		-webkit-box-shadow:0 6px 6px -2px rgba(0, 0, 0, 0.4);
		-moz-box-shadow: 0 6px 6px -2px rgba(0, 0, 0, 0.4);
		box-shadow: 0 6px 6px -2px rgba(0, 0, 0, 0.4);
	}
	.menu > li {
		display: block;
		width: 100%;
		margin: 0;
	}
	.menu, .menu > li, .menu > li > a {
		height: auto;
	}
	.menu > li > a {
		display: block;
		width: 100%;
		text-decoration: none;
		text-align: center;
		padding: 4px 0 5px 0;
		border-bottom: 1px solid #000;
		border-top: none;
	}
	.menu > li > a:hover, .menu > li > a:focus {
		/*background: #F2F2F2;*/
		/*box-shadow: inset 5px 0px #51C1F1;*/
		/*padding: 15px 15px 15px 25px;*/
	}
	.menu > li > ul {
		display: none;
	}
	.menu > li.active > ul {
        	display: none;
	}
	.toggle {
		display: block;
		position: relative;
		cursor: pointer;
		-webkit-touch-callout: none;
		-webkit-user-select: none;
		user-select: none;
	}
	.toggle:after {
		content: 'Main Menu';
		display: block;
		width: 220px;
		margin: 0;
		/*padding: 10px 50px;*/
		border-top: 1px solid #000;
		border-bottom: 1px solid #000;
		font-family: 'texgyreherosbold';
		text-align: center;
		font-size: 15px;
		line-height: 36px;
		text-transform: uppercase;
		color: #999;
		-webkit-transition: all 0.5s linear;
		-moz-transition: all 0.5s linear;
		-o-transition: all 0.5s linear;
		transition: all 0.5s linear;
	}
	.toggle:hover:after {
		color: #000;
	}
	#toggle:checked ~ .menu { display: block; opacity: 1;}
	#toggle:checked + .toggle:after{
		content: 'Close Menu';
	}
	div.copyright {
		display: none;
	}
	.area-title-wrapper {
		height: auto;
	}
	#page {
		margin: 0;
		width: 100%;
	}
	#home-title-wrapper {
		height: auto;
		margin-bottom: 30px;
	}
	.area {
		width: 48%;
		margin: 0 4% 4% 0;
	}
	.home-menu {
		width: 100%;
	}
	#title-wrapper {
		display: block;
		width: 100%;
		margin-bottom: 20px;
	}
	.content {
		width: 100%;
	}
	#members {
		margin-top: 20px;
	}
	img.title-img {
		float:none;
	}
	.project-title-wrapper {
		display: block;
		width: 100%;
		margin-bottom: 14px;
	}
	.project-desc {
		height: inherit;
		margin-bottom: 14px;

	}
	footer.footer {
		margin: 36px 0 20px 0;
        display: block;
		text-align: center;
	}
	footer.footer a {
		font-family: 'texgyreherosregular';
		font-size: 11px;
	}
}


@media only screen and (max-width: 560px) {

	#leftcol {
		height: auto;
	}
	#logo-main {
		position: relative;
		top: inherit;
		left: inherit;
		text-align: center;
		height: auto;
	}
	#logo-sub {
		position: relative;
		top: inherit;
		left: inherit;
		text-align: center;
		height: auto;
		margin: 14px 0;
	}
	.nav {
		width: 100%;
		position: relative;
		top: inherit;
		left: inherit;
	}
	#social {
		position: relative;
		top: inherit;
		right: inherit;
		text-align: center;
		height: auto;
		margin-bottom: 14px;
	}
	#title-wrapper {
		height: auto;
	}
        #title-img-wrapper {
		float: none;
                margin-left: 0px;
                margin-bottom: 20px;
        }
	.toggle:after {
		float: none;
		width: 100%;
		text-align: center;
		margin: 14px 0 20px 0;
	}
	#home-title-wrapper {
		height: auto;
		margin-bottom: 30px;
	}
	.area {
		width: 100%;
		float: none;
	}
	.home-menu {
		width: 100%;
	}
	.project-desc {
		float: none;
		width: 100%;
		margin: 14px 0 36px 0;
	}
	img.title-img-proj {
		float: none;
		margin: 0;
		width: 100%;
	}
	.bibauthors {
		float: none;
		display: block;
		width: 100%;
	}
	.bibyear {
		float: none;
		display: none;
		visibility: hidden;
	}
	.bibdoc {
		float: right;
	}
}

#logo-sub a { color: #999; }
.headline {
	font-size: 18px;
	color: green;
	font-weight: bold;
	margin-bottom: 30px;
}
