/*

	Haupt-CSS-Datei

	Autor:				Marco Philipeit - http://marcophilipeit.de
	Start:				01.10.11
	Letzte Aenderung:	25.11.11

*/

/*
 * HTML5 Boilerplate
 *
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */


/* =============================================================================
   HTML5 element display
   ========================================================================== */

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { display: block; }
audio[controls], canvas, video { display: inline-block; *display: inline; *zoom: 1; }

/* =============================================================================
   Base
   ========================================================================== */

/*
 * 1. Correct text resizing oddly in IE6/7 when body font-size is set using em units
 *    http://clagnut.com/blog/348/#c790
 * 2. Force vertical scrollbar in non-IE
 * 3. Remove Android and iOS tap highlight color to prevent entire container being highlighted
 *    www.yuiblog.com/blog/2010/10/01/quick-tip-customizing-the-mobile-safari-tap-highlight-color/
 * 4. Prevent iOS text size adjust on device orientation change, without disabling user zoom
 *    www.456bereastreet.com/archive/201012/controlling_text_size_in_safari_for_ios_without_disabling_user_zoom/
 */

html { font-size: 100%; overflow-y: scroll; -webkit-overflow-scrolling: touch; -webkit-tap-highlight-color: rgba(0,0,0,0); -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

body { margin: 0; font-size: 13px; line-height: 1.231; }

body, button, input, select, textarea { font-family: sans-serif; color: #222; }

/* 
 * These selection declarations have to be separate
 * No text-shadow: twitter.com/miketaylr/status/12228805301
 * Also: hot pink!
 */

::-moz-selection { background: #0c6282; color: #fff; text-shadow: none; }
::selection { background: #0c6282; color: #fff; text-shadow: none; }


/* =============================================================================
   Links
   ========================================================================== */

a,
a:link,
a:visited {
	color: #0c6282;
	border: 0;
	text-decoration: underline;
}

a:focus,
a:hover {
	color: #6fb22c;
}


/* =============================================================================
   Typography
   ========================================================================== */

/*abbr[title] { border-bottom: 1px dotted; }*/
abbr[title] { border: 0; }

b, strong { font-weight: bold; }

blockquote { margin: 1em 40px; }

dfn { font-style: italic; }

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

ins { background: #ff9; color: #000; text-decoration: none; }

mark { background: #ff0; color: #000; font-style: italic; font-weight: bold; }

/* Redeclare monospace font family: en.wikipedia.org/wiki/User:Davidgothberg/Test59 */
pre, code, kbd, samp { font-family: monospace, monospace; _font-family: 'courier new', monospace; font-size: 1em; }

/* Improve readability of pre-formatted text in all browsers */
pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; }

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

small { font-size: 85%; }

/* Position subscript and superscript content without affecting line-height: gist.github.com/413930 */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }


/* =============================================================================
   Lists
   ========================================================================== */

ul, ol { margin: 1em 0; padding: 0 0 0 40px; }
dd { margin: 0 0 0 40px; }
nav ul, nav ol { list-style: none; margin: 0; padding: 0; }


/* =============================================================================
   Embedded content
   ========================================================================== */

/*
 * Improve image quality when scaled in IE7
 * code.flickr.com/blog/2008/11/12/on-ui-quality-the-little-things-client-side-image-resizing/
 */

img { border: 0; -ms-interpolation-mode: bicubic; }

/*
 * Correct overflow displayed oddly in IE9 
 */

svg:not(:root) {
    overflow: hidden;
}


/* =============================================================================
   Figures
   ========================================================================== */

figure { margin: 0; }


/* =============================================================================
   Forms
   ========================================================================== */

form { margin: 0; }
fieldset { border: 0; margin: 0; padding: 0; }

/* 
 * 1. Correct color not inheriting in IE6/7/8/9 
 * 2. Correct alignment displayed oddly in IE6/7 
 */

legend { border: 0; *margin-left: -7px; padding: 0; }

/* Indicate that 'label' will shift focus to the associated form element */
label { cursor: pointer; }

/*
 * 1. Correct font-size not inheriting in all browsers
 * 2. Remove margins in FF3/4 S5 Chrome
 * 3. Define consistent vertical alignment display in all browsers
 */

button, input, select, textarea { font-size: 100%; margin: 0; vertical-align: baseline; *vertical-align: middle; }

/*
 * 1. Define line-height as normal to match FF3/4 (set using !important in the UA stylesheet)
 * 2. Correct inner spacing displayed oddly in IE6/7
 */

button, input { line-height: normal; *overflow: visible; }

/*
 * 1. Display hand cursor for clickable form elements
 * 2. Allow styling of clickable form elements in iOS
 */

button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; -webkit-appearance: button; }

/*
 * Consistent box sizing and appearance
 */

input[type="checkbox"], input[type="radio"] { box-sizing: border-box; }
input[type="search"] { -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; }

/* 
 * Remove inner padding and border in FF3/4
 * www.sitepen.com/blog/2008/05/14/the-devils-in-the-details-fixing-dojos-toolbar-buttons/ 
 */

button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

/* Remove default vertical scrollbar in IE6/7/8/9 */
textarea { overflow: auto; vertical-align: top; }

/* Colors for form validity */
input:valid, textarea:valid {  }
input:invalid, textarea:invalid { background-color: #f0dddd; }


/* =============================================================================
   Tables
   ========================================================================== */

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


/* =============================================================================
   Primary styles
   Author: Marco Philipeit
   ========================================================================== */

	/*  Allgemein
	---------------------------------- */

	html, body {
		background-color: fff;
		color: #161616;
		font-family: 'Open Sans', Arial, Verdana, Helvetica, "Trebuchet MS", sans-serif;
		text-align: left;
	}

	input, textarea, select {
		font-family: 'Open Sans', Arial, Verdana, Helvetica, "Trebuchet MS", sans-serif;
		font-size: 1em;
	}

	#begrenzung,
	#kopfteil,
	#hauptteil,
	#fussteil {
		width: 100%;
		margin: 0;	
		float: none;
	}
	
	#kopfteil {
		background: #0c6082 url("../lib.grafiken/hintergrund.mobile.png") bottom right repeat-x;
		padding-bottom: 105px;	
		text-align: center;
		position: relative;
		z-index: 0;
	}
	
	#hauptteil {
		margin-top: -40px;
		position: relative;
		z-index: 2;
	}
	
	#fussteil {
		background: url("../lib.grafiken/hintergrund.fussteil.jpg") top center repeat-x;
		height: 46px;
		padding-top: 90px;
		margin-top: -60px;
		position: relative;
		z-index: 1;
	}
	
	#fussteil p {
		margin-right: 10px;
		margin-left: 10px;	
	}
	
	#hauptnavigation a {
		text-align: center;
		color: #fff;
		padding: 10px 5px;
		text-decoration: none;
	}
	
	#hauptbuehne {
		background: url("../lib.grafiken/transparenz-blau-15.png");
		padding: 5%;	
	}
	
	#hauptbuehne h1 {
		color: #0c6282;
		font-weight: normal;
		font-size: 20px;
		line-height: 30px;
		margin-top: 0px;
	}
	
	#hauptbuehne h1 em {
		font-weight: bold;
		font-style: normal;	
	}
	
	#hauptbuehne p {
		margin-top: 24px;
		line-height: 24px;
	}
	
	#inhalt,
	#seitenleiste {
		margin: 5%;
	}
	
	#inhalt h2,
	#seitenleiste h2 {
		margin-top: 0;	
		color: #0c6282;
		font-weight: normal;
		padding-top: 15px;
	}
		
	#inhalt h3,
	#seitenleiste h3 {
		font-size: 13px;	
	}
	
	#inhalt em {
		font-weight: bold;
		font-style: normal;	
	}
	
	#inhalt .abstandObenMittel { padding-top: 15px; }
	
	#inhalt,
	#seitenleiste {
		line-height: 24px;	
	}
	
	#inhalt p,
	#seitenleiste p {
		margin-bottom: 24px;	
	}
	
	#inhalt .fehler {
		padding-left: 50px;
		background: url("../lib.grafiken/icon.fehler.png") top left no-repeat;	
	}
	
	#inhalt .erfolg {
		padding-left: 50px;
		background: url("../lib.grafiken/icon.erfolg.png") top left no-repeat;	
	}
	
	#inhalt .unterschrift {
		margin-top: -40px;	
	}
	
	#inhalt .inhaltstabelle {
		width: 100%;	
	}
	
	#inhalt .inhaltstabelle th {
		width: 33%;
		font-weight: normal;
		text-align: left;
	}
	
	#inhalt .inhaltstabelle td,
	#inhalt .inhaltstabelle th {
		vertical-align: top;
		padding-top: 10px;		
	}
	
	#inhalt ul,
	#inhalt ul li {
		margin: 0;	
		padding: 0;
		list-style: none;
	}
	
	#inhalt ul li {
		background: url("../lib.grafiken/listpunkt.png") 4px 10px no-repeat;
		padding-left: 15px;
	}
	
	#inhalt .projektUeberlagerung {
		width: 422px;
		height: 250px;
		overflow: hidden;
		position: relative;
		z-index: 1;
	}
	
	#inhalt .projektUeberlagerung img {
		width: 422px;
		height: 250px;
		overflow: hidden;
		position: relative;
		z-index: 2;
	}
	
	#inhalt .projektUeberlagerung .ueberlagerung {
		background: url("../lib.grafiken/projekte-ueberlagerung.png") top left no-repeat;
		width: 422px;
		height: 250px;
		overflow: hidden;
		position: absolute;
		top: 0;
		left: 0;
		z-index: 3;
	}
	
	.formular {
		width: 90%;
		padding: 5%;
		background: url("../lib.grafiken/transparenz-blau-15.png");	
	}
	
	.formular ol,
	.formular ol li {
		margin: 0;
		padding: 0;
		list-style: none;	
	}
	
	.formular ol li {
		margin-bottom: 10px;	
	}
	
	.formular ol li.leerfeldfehler {
		color: #cc0000;	
	}
	
	.kleiner {
		line-height: 1.5;
	}
	
	.formular legend {
		font-weight: bold;
		margin-bottom: 24px;	
	}
	
	.formular label {
		display: block;	
	}
	
	.formular input,
	.formular textarea {
		width: 100%;	
	}
	
	.formular .width-auto {
		width: auto;	
	}
	
	#fussteil,
	#fussteil a {
		color: #fff;	
	}
	
	#fussteil a:hover,
	#fussteil a:focus {
		color: #6fb22c;
	}
	
	#fussteil #rechtliches {
		text-align: left;
		color: #fff;
		padding: 
	}
	
	#fussteil #social-media {
		display: none;	
	}

/* =============================================================================
   Non-semantic helper classes
   Please define your styles before this section.
   ========================================================================== */

/* For image replacement */
.ir { display: block; text-indent: -999em; overflow: hidden; background-repeat: no-repeat; text-align: left; direction: ltr; }
.ir br { display: none; }

/* Hide for both screenreaders and browsers:
   css-discuss.incutio.com/wiki/Screenreader_Visibility */
.hidden { display: none; visibility: hidden; }

/* Hide only visually, but have it available for screenreaders: by Jon Neal.
  www.webaim.org/techniques/css/invisiblecontent/  &  j.mp/visuallyhidden */
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }

/* Extends the .visuallyhidden class to allow the element to be focusable when navigated to via the keyboard: drupal.org/node/897638 */
.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }

/* Hide visually and from screenreaders, but maintain layout */
.invisible { visibility: hidden; }

/* Contain floats: nicolasgallagher.com/micro-clearfix-hack/ */ 
.clearfix:before, .clearfix:after { content: ""; display: table; }
.clearfix:after { clear: both; }
.clearfix { zoom: 1; }


/* =============================================================================
   PLACEHOLDER Media Queries for Responsive Design.
   These override the primary ('mobile first') styles
   Modify as content requires.
   ========================================================================== */


@media only screen and (min-width: 480px) {
  /* Style adjustments for viewports 480px and over go here */
		
	#hauptbuehne {
		width: 90%;
		height: 176px;
	}
	
	#hauptbuehne .text {
		width: 413px;
	}
	
	#anschrift {
		float: left;
		width: 50%;	
	}
	
	#optionen {
		float: right;
		width: 50%;
		text-align: center;
		line-height: 14px;
		margin-top: -24px;
	}
	
	#optionen p {
		margin: 0;	
	}
	
	#optionen #optionen-xing {
		margin-top: 29px;	
		margin-bottom: 5px;	
	}
	
}

@media only screen and (min-width: 768px) {
  /* Style adjustments for viewports 768px and over go here */
  	
	#begrenzung {
		overflow: hidden;	
	}
	
	#kopfteil {
		background: url("../lib.grafiken/hintergrund.kopfteil.jpg") top center repeat-x;
		height: 198px;
		padding: 0;
		position: relative;
		z-index: 0;
	}
	
	#hauptbuehne {
		width: 90%;
		padding: 61px 5% 31px 5%;
		height: 176px;
		background: url("../lib.grafiken/hintergrund.hauptbuehne.klein.png") bottom right;
	}
	
	#hauptbuehne .text {
		width: 413px;
	}
	
	#hauptteil {
		margin-top: -96px;	
	}
	
	#fussteil {
		background: url("../lib.grafiken/hintergrund.fussteil.jpg") top center repeat-x;
		height: 46px;
		padding-top: 90px;
		margin-top: -80px;
	}
	
	#kopfteil,
	#hauptteil,
	#fussteil {
		width: 100%;	
	}
	
	.begrenzung {
		width: 94%;
		padding: 0px 3%;
		margin: 0 auto;	
	}
	
	#inhalt {
		float: left;
		width: 45%;
		margin: 0;
		padding-right: 5%;
		border-right: 1px solid #cee0e7;
		margin-top: 24px;
		min-height: 530px;
		padding-bottom: 24px;
	}
	
	#seitenleiste {
		float: right;
		margin: 0;
		width: 45%;
		margin: 0;
		margin-top: 24px;
		padding-left: 4%;
		height: 475px;
		background: url("../lib.grafiken/visitenkarte.jpg") bottom center no-repeat;
	}
	
	#logo {
		float: left;
		width: 336px;	
	}
	
	#hauptnavigation {
		float: right;
		width: 50%;
		text-align: right;
		padding-top: 42px;
		height: 23px;
		margin-right: -12px;
	}
	
	#hauptnavigation a {
		color: #fff;
		text-decoration: none;
		padding: 2px 12px;
	}
	
	#hauptnavigation a.aktiv {
		font-weight: bold;
		background: url("../lib.grafiken/transparenz-weiss-10.png");
		-moz-border-radius: 12px;
		border-radius: 12px;
	}
	
	#hauptnavigation a.aktiv:hover,
	#hauptnavigation a.aktiv:focus {
		color: #fff;
	}
	
	#hauptnavigation a:hover,
	#hauptnavigation a:focus {
		color: #80cf32;
	}
	
	#anschrift {
		width: 57%;	
	}
	
	#optionen {
		width: 43%;
	}
	
	#anschrift .abstand {
		margin: 24px 0;	
	}
	
	#inhalt .projektUeberlagerung {
		width: 320px;	
	}
	
	#fussteil #rechtliches {
		float: left;
		width: 50%;	
	}
	
	#fussteil #social-media {
		display: block;
		float: right;
		text-align: right;
		width: 19%;
		margin-top: 12px;
		padding-left: 31%;
	}
	
	#fussteil #social-media-facebook,
	#fussteil #social-media-twitter,
	#fussteil #social-media-googleplusone {
		float: left;
		height: 22px;	
	}
	
	#fussteil #social-media-facebook {
		width: 80px;
		overflow: hidden;
	}
	
	#fussteil #social-media-googleplusone {
		margin-left: 4px;
	}


}



@media only screen and (min-width: 1000px) {
  /* Style adjustments for viewports 1070px and over go here */
  
  	#hauptbuehne {
		background: url("../lib.grafiken/hintergrund.hauptbuehne.png") bottom left;
		padding: 61px 556px 31px 31px;
		margin-left: -31px;
		width: 413px;
		height: 176px;
	}
	
	#hauptnavigation {
		width: 602px;	
	}
	
	.begrenzung {
		width: 938px; /* 1000px - 31px x 2 */
		padding: 0px 31px;
		margin: 0 auto;	
	}
	
	#anschrift {
		width: 50%;	
	}
	
	#optionen {
		width: 50%;
	}
	
	#inhalt .projektUeberlagerung {
		width: 422px;	
	}
  
}


/* =============================================================================
   Print styles.
   Inlined to avoid required HTTP connection: www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */
 
@media print {
  * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } /* Black prints faster: sanbeiji.com/archives/953 */
  body, html { background-color: fff !important; color: #161616 !important; font-size: 14px !important; font-family: Arial, Verdana, Helvetica, "Trebuchet MS", sans-serif !important; text-align: left !important; }
  a, a:visited { color: #0c6282 !important; text-decoration: underline; }
  /*a[href]:after { content: " (" attr(href) ")"; }
  abbr[title]:after { content: " (" attr(title) ")"; }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }  /* Don't show links for images, or javascript/internal links */
  pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
  thead { display: table-header-group; } /* css-discuss.incutio.com/wiki/Printing_Tables */
  tr, img { page-break-inside: avoid; }
  img { max-width: 100% !important; }
  @page { margin: 0.5cm; }
  p, h2, h3 { orphans: 3; widows: 3; }
  h2, h3{ page-break-after: avoid; }
  
  	/*  Layout
	---------------------------------- */
	
	#hauptnavigation,
	#optionen,
	#rechtliches,
	#social-media {
		display: none;	
	}
	
	#kopfteil,
	#hauptteil,
	#fussteil {
		margin: 0;
		padding: 0;
	}
}

