/* @import url(https://fonts.googleapis.com/css?family=Lato:100,100italic,300,400,300italic,700,900); */

@font-face {
	font-family: 'Lato';
	font-style: normal;
	font-weight: 100;
	src: url("../fonts/Lato-Thin.ttf") format("truetype");
}
@font-face {
	font-family: 'Lato';
	font-style: italic;
	font-weight: 100;
	src: url("../fonts/Lato-ThinItalic.ttf") format("truetype");
}
@font-face {
	font-family: 'Lato';
	font-style: normal;
	font-weight: 300;
	src: url("../fonts/Lato-Light.ttf") format("truetype");
}
@font-face {
	font-family: 'Lato';
	font-style: italic;
	font-weight: 300;
	src: url("../fonts/Lato-LightItalic.ttf") format("truetype");
}
@font-face {
	font-family: 'Lato';
	font-style: normal;
	font-weight: 400;
	src: url("../fonts/Lato-Regular.ttf") format("truetype");
}
@font-face {
	font-family: 'Lato';
	font-style: normal;
	font-weight: 700;
	src: url("../fonts/Lato-Bold.ttf") format("truetype");
}
@font-face {
	font-family: 'Lato';
	font-style: normal;
	font-weight: 900;
	src: url("../fonts/Lato-Black.ttf") format("truetype");
}

/* http://meyerweb.com/eric/tools/css/reset/
v2.0 | 20110126
License: none (public domain)
*/
/***** Reset - Start **********************************************************/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/***** Reset - End ************************************************************/


/***** Custom globals - Start *************************************************/

html {
	height: 100%;
}
body {
	height: 100%;
	overflow-y: scroll;
	font-family: Lato, Arial, Helvetica;
	font-size: 16px;
	line-height: 21px;
	color: #444;
	background-color: #e8e8e8;
}
body.fixed {
    overflow: hidden;
}

div {
	position: relative;
}
input, textarea, select {
	padding: 0 10px;
	color: #444;
	font-family: Lato, Arial, Helvetica;
	font-size: 16px;
	border: 1px solid #d2d2d2;
}
input, select {
	height: 30px;
	border-radius: 3px;
}
input[type="checkbox"], input[type="radio"] {
    height: auto;
}
input[type="text"], input[type="email"] {
	width: 350px;
}
input.plz {
	width: 100px;
}
input.ort {
	width: 226px;
}
input.forum_radio {
	margin-left: 20px;
	height: 40px;
}
select {
	padding: 0 4px 0 6px;
	color: #444;
}
select option {
	padding: 5px 10px;
	color: #444;
}
label {
    cursor: pointer;
}
a {
	color: #267adc;
	text-decoration: none;
	cursor: pointer;
}
a:hover {
	text-decoration: underline;
}
a:focus {
	/*outline: none;*/
}
b, strong {
	font-weight: 700;
}
p.foren-titel {
	margin-bottom: 8px;
	padding-left: 17px;
	text-indent: -17px;
}
h1 {
	margin: 0 0 32px 0;
	font-size: 35px;
}
h1.no-marg-bot {
	margin: 0;
}
h2 {
	margin: 0 0 24px 0;
	font-size: 22px;
}
h2.no-marg-bot {
	margin: 0;
}
h3 {
	margin: 0 0 16px 0;
	font-size: 18px;
}
p {
	margin: 0 0 24px 0;
}
p.info-small {
	font-size: 12px;
	line-height: 14px;
}
i {
	font-style: italic;
}
dl dt {
	/*
	float: left;
	clear: left;
	*/
	margin: 0 2px 2px 0;
	padding: 4px;
	position: relative;
}
dl dd {
	/* 
	float: left;
	*/
	margin: 0 0 2px 0;
	padding: 4px;
	position: relative;
}
dl dt.clear {
	float: none;
	clear: both;
	padding: 0;
	margin: 0;
}

ul {
	margin: 0 0 24px;
	list-style: disc;
}
ul li {
	margin: 0 0 0 20px;
}

div.wrapper {
	width: 1000px;
	margin: 0px auto;
	padding: 24px;
	background-color: #fff;
}
div.clear {
	clear: both;
}
.left {
	float: left;
}
.right {
	float: right;
}
.error {
	color: #960000;
}
.disabled {
	color: #aaa;
}
.green {
    color: #009600;
}
input.error,
select.error,
textarea.error {
	border-color: #960000;
	background-color: #eacccc;
}
.text-right {
	text-align: right;
}
.small {
	font-size: 12px;
}

.clearfix:after {
	content: "";
	display: table;
	clear: both;
}
/***** Custom globals - End ***************************************************/


/***** Overlay - Start *****/
.overlay {
	display: none;
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: rgba(0, 0, 0, 0.7);
	z-index: 100;
}
.overlay .inner {
	display: table;
	height: 100%;
}
.overlay .inner .centerer {
	display: table-cell;
	height: 100%;
	padding: 0 25%;
	vertical-align: middle;
}
.overlay .inner .centerer .text {
    padding: 20px;
    background-color: #fff;
}
.overlay .inner .centerer .text p {
    margin: 0;
    padding: 50px 20px 40px 20px;
    /*border: 1px solid #e9e9e9;*/
}

.overlay .inner .centerer .text a.close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    border: 2px solid #444;
    border-radius: 50%;
}
.overlay .inner .centerer .text a.close .lr {
    width: 2px;
    height: 20px;
    margin-left: 15px;
    margin-top: 6px;
    background-color: #444;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.overlay .inner .centerer .text a.close .lr .rl {
    width: 2px;
    height: 20px;
    background-color: #444;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
}
.overlay .inner .centerer .text a.close:hover {
    opacity: .8;
}
/***** Overlay - End *****/


/***** Header - Start *********************************************************/

header {
	position: relative;
	height: 256px;
	margin: 0 0 24px;
	border: 1px solid #e9e9e9;
}
header a.logo {
	position: absolute;
	top: 30px;
	right: 20px;
	width: 288px;
	height: 64px;
	background: url('../images/header-logo-2021.png') no-repeat right 0;
	background-size: contain;
	text-indent: -9999em;
}
header .logo-lemas {
    position: absolute;
    top: 20px;
    left: 20px;
    width: 186px;
    height: 138px;
    background: url("../images/logo-lemas.png") no-repeat;
    background-size: 186px auto;
}
header h1 {
    margin: 180px 20px 16px;
    line-height: 36px;
}
header h2 {
    margin: 0 20px 16px;
}

/***** Navi - Start *****/
nav {
	position: absolute;
	bottom: 0;
	width: 100%;
}
nav ul {
	margin: 0;
	background-color: #f3f3f3;
	border-bottom: 5px solid #1e579a;
	border-top: 1px solid #ededed;
	text-transform: uppercase;
}
nav ul li {
	margin: 0;
	display: inline-block;
	padding: 0 25px;
	font-size: 12px;
	transition: all 0.3s ease 0s;
	width: auto;
}
nav li:hover {
	color: #fff;
	background-color: #003064;
}
nav li.active {
	color: #fff;
	font-weight: 900;
	background-color: #1e579a;
}
nav ul li a {
	display: block;
	line-height: 44px;
	color: #444;
}
nav ul li.active a {
	color: #fff;
}
nav ul li:hover a {
	color: #fff;
}
/***** Navi - End *****/

/***** Header - End ***********************************************************/


/***** Content - Start ********************************************************/

div.content {
	min-height: 400px;
	padding: 30px 20px;
	border: 1px solid #e9e9e9;
}
div.fotos-start {
	margin: 0 -4px 0 0;
}
div.fotos-start img {
	display: block;
	float: left;
}
div.content.index {
	text-align: justify;
}
div.content img.logo-uk-nrw {
	position: relative;
	top: 6px;
	margin: 0 0 -30px 185px;
}
div.content img.partner {
	display: block;
	margin: 0 auto;
}
/***** Programm *****/
dl.programm dt {
	width: 120px;
}
dl.programm dd {
	width: 820px;
}

/***** Referenten *****/
div.referenten img {
	display: block;
	float: left;
	margin: 0 20px 32px 0;
	padding: 16px;
	border: 2px solid #cfcfcf;
}
div.referenten p.right {
	float: left;
	width: 730px;
	margin-bottom: 32px;
}
div.referenten p.right.w-2 {
	width: 780px;
}


/***** Anmeldung - Start *****/
dl.daten {
    padding: 15px;
    background-color: #efefef;
}
dl.daten dt {
	width: 160px;
	min-width: 160px !important;
	float: left !important;
	clear: left !important;
}
dl.daten dd {
	width: auto;
	float: left !important;
}
dl.anmeldung dt {
	width: 250px;
	padding-top: 10px;
	line-height: 20px;
}
input[type="submit"] {
	margin: 16px 0 0;
	cursor: pointer;
}
div.themenblock {
	margin: 0 0 30px;
}
div.error {
	width: 620px;
	min-width: 620px;
	margin: -10px -10px 30px;
	padding: 10px;
	border: 1px solid #960000;
	border-radius: 5px;
	background-color: #eacccc;
}
div.error.themenblock {
	width: auto;
}
.col-a {
	width: 520px;
}
.col-b {
	width: 400px;
}
table.choice {
	width: 100%;
}
table.choice tr:hover {
	background-color: #f3f3f3;
}
table.choice tr.header:hover {
	background-color: transparent;
}
table.choice tr td {
	padding: 8px 4px;
    vertical-align: top;
}
table.choice tr td:nth-child(2),
table.choice tr td:nth-child(3),
table.choice tr td:nth-child(4) {
	/*width: 20%;*/
    vertical-align: bottom;
    /*text-align: center;*/
}
table.choice input[type="radio"],
table.choice input[type="checkbox"]{
	height: 13px;
}
.radio dd {
	width: 100px;
	vertical-align: middle;
	margin-left: 0;
	padding-left: 0;

}
dd.checkbox {
	padding-top: 10px;
}
table.choice label.block-1,
table.choice label.block-2 {
    display: inline-block;
    padding: 1px 6px;
    border-radius: 3px;
}
table.choice label.block-1.active {
    color: #fff;
    background-color: #007bf9;
}
table.choice label.block-2.active {
    color: #fff;
    background-color: #009600;
}

dl.wahl {
    margin: 20px 0 0;
}
dl.wahl dt {
    width: 70px;
    margin: 0;
    padding: 0;
}
dl.wahl dd {
    width: 100px;
    margin: 0;
    padding: 0;
}
/***** Anmeldung - End *****/

/***** Referenzschulen *****/
div.content.referenzschulen table {
	margin: 0 0 32px 0;
}
div.content.referenzschulen table tr:nth-child(1) {
	background-color: #f3f3f3;
}
div.content.referenzschulen table tr:hover {
	background-color: #f3f3f3;
}
div.content.referenzschulen table tr.header:hover {
	background-color: transparent;
}
div.content.referenzschulen table th {
	padding: 4px;
	text-align: left;
	font-weight: 700;
}
div.content.referenzschulen table tr td {
	padding: 4px;
}
div.content.referenzschulen table tr td:nth-child(1) {
	width: 20px;
}
div.content.referenzschulen table tr td:nth-child(2) {
	width: 420px;
}
div.content.referenzschulen table tr td:nth-child(3) {
	width: 490px;
}

/***** Rückblick - Start *****/
div.gallery {
	margin: 0 0 32px;
}
div.gallery img {
	margin: 24px;
	padding: 16px;
	border: 2px solid #cfcfcf;
}
div.gallery div.foto {
	float: left;
}
div.gallery div.foto a {
	display: block;
}
div.gallery div.foto a.download {
	margin: -24px 24px 24px;
	font-size: 12px;
}
div.gallery div.foto a.download:hover {
	text-decoration: underline;
}

div.videos {
	margin: 0 -30px 32px 0;
}
div.video {
	float: left;
	margin: 0 32px 32px 0;
}
div.video video {
	display: block;
	width: 460px;
}
div.video a.download {
	clear: right;
	float: right;
	display: inline-block;
	margin: 8px 0;
	font-size: 12px;
}
div.video p {
	display: inline-block;
	margin: 8px 0;
}

.info-begleitung {
	display: none;
	width: 620px;
	min-width: 620px;
	margin: 10px -10px 20px;
	padding: 10px;
	border: 1px solid #1E579A;
	border-radius: 5px;
	background-color: #D0E2F6;
}
a.pdf {
	display: block;
	margin: 0 0 8px;
	padding: 0 0 0 26px;
	line-height: 32px;
	background: url(../images/pdficon_small.png) no-repeat left center;
}
dt {
	float: none;
	clear: none;
	width: 30%;
	min-width: 30%;
	display: inline-block;
	height: auto;
}
dd {
	float: none;
	clear: none;
	width: 60%;
	min-width: 60%;
	height: auto;
	display: inline-block;
}
.fullwidth {
	width: 100%;
}
span.hide-begleitperson {
	display: block;
	position: relative;
	display: none;
}

.row {
	display: flex;
	width: 100%;
	padding: 0;
	margin: 0;
}
.col-8 {
	display: flex;
	width: calc(100%/12*8);
	padding: 0;
	margin: 0;
}
.col-6 {
	display: flex;
	width: calc(100%/12*6);
	padding: 0;
	margin: 0;
}
.col-2 {
	display: flex;
	padding: 0;
	margin: 0;
	width: calc(100%/12*2);
}
.mt-2 { margin-top: .64rem; }
.mt-5 { margin-top: 1.6rem; }

.forum {
	display: block;
}
span.info {
	padding-left: 17px;
	font-size: 0.9rem;
	color: #999;
}
label.forum-label {
	font-size: .8rem;
	margin: 12px 0 0 5px;
}
label.forum-label+.disabled {
	color: #999;
}
div.error-new {
	margin: -10px -10px 30px 0px;
	padding: 10px;
	border: 1px solid #960000;
	border-radius: 5px;
	background-color: #eacccc;
}

dl.daten dt {
	width: 160px;
	float: left;
}
dl.daten dd {
	width: 720px;
	float: left;
	
}


/***** Rückblick - End *****/

/***** Content - End **********************************************************/


/***** Footer - Start *********************************************************/
footer {
	padding: 0 20px;
	color: #fff;
	font-size: 13px;
	background-color: #1e579a;
	border-top: 1px solid #ededed;
}
footer p {
	margin: 0;
	line-height: 48px;
}

/***** Footer - End ***********************************************************/

