
/* ======================================
  1. Kalibrierung und Restauration
  ====================================== */
/* Reset - alle Abstände auf NULL */
*  { padding: 0; margin: 0; }
/* optional: erzwingt Scrollbar im Firefox */
html { height: 95%; margin-bottom: 1px; }
h2, p, ul, ol { margin-bottom: 1em; }
ul ul { margin-bottom: 0; }
li { margin-left: 1em ; }
/* hier ggfs. Abstände für weitere Elemente restaurieren */

/* ======================================
  2. Allgemeine Styles
  ====================================== */
body {
  background-color: #8c8c8c;
  color: white;
  font-family: Verdana, Arial, Helvetica, sans-serif; 
  font-size: small;
  height: 100%; 
  }
h1 { font-size: 150%; }
h2 { font-size: 130%; } 
address {
  text-align: center;
  font-size: 80%;
  font-style: normal;
  letter-spacing: 2px;
  line-height: 1.5;
}
a { 
  color: black;
  text-decoration: none; 
  /* outline: none; */ /* nur wenn es Sie wirklich stört */
} 
a:link {
  color: black;
  } 
a:visited {
  color: black;
  } 
a:hover,
a:focus { 
  color: blue;
}
a:active { 
  
}

hr {
  color: #5F8EDC;
}

.error {
    color: red;
}

/* Formularelemente */

.input_before {
    text-align: left;
    vertical-align: middle;
    padding-right: 5px;
    cursor: pointer;
}

.input_button {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    padding: 4px 12px;
    margin-top: 0;
    margin-bottom: 0;
    font-size: 13px;
    line-height: 14px;
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
    color: #333;
    text-shadow: 0 1px 1px rgba(255,255,255,0.75);
    background-color: #f5f5f5;
    background-image: -moz-linear-gradient(top,#fff,#e6e6e6);
    background-image: -webkit-gradient(linear,0 0,0 100%,from(#fff),to(#e6e6e6));
    background-image: -webkit-linear-gradient(top,#fff,#e6e6e6);
    background-image: -o-linear-gradient(top,#fff,#e6e6e6);
    background-image: linear-gradient(to bottom,#fff,#e6e6e6);
    background-repeat: repeat-x;
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#ffe5e5e5', GradientType=0);
    border-color: #e6e6e6 #e6e6e6 #bfbfbf;
    *background-color: #e6e6e6;
    filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);
    border: 1px solid #bbb;
    *border: 0;
    border-bottom-color: #a2a2a2;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    *margin-left: .3em;
    -webkit-box-shadow: inset 0 1px 0 rgba(255,255,255,.2), 0 1px 2px rgba(0,0,0,.05);
    -moz-box-shadow: inset 0 1px 0 rgba(255,255,255,.2), 0 1px 2px rgba(0,0,0,.05);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.2), 0 1px 2px rgba(0,0,0,.05);
}
.input_button:hover,
.input_button:focus,
.input_button:active,
.input_button.active,
.input_button.disabled,
.input_button[disabled] {
    color: #333;
    background-color: #e6e6e6;
    *background-color: #d9d9d9;
}
.input_button:active,
.input_button.active {
    background-color: #cccccc \9;
}
.input_button:first-child {
    *margin-left: 0;
}
.input_button:hover,
.input_button:focus {
    color: #333;
    text-decoration: none;
    background-position: 0 -15px;
    -webkit-transition: background-position .1s linear;
    -moz-transition: background-position .1s linear;
    -o-transition: background-position .1s linear;
    transition: background-position .1s linear;
}
.input_button:focus {
    outline: thin dotted #333;
    outline: 5px auto -webkit-focus-ring-color;
    outline-offset: -2px;
}
.input_button.active,
.input_button:active {
    background-image: none;
    outline: 0;
    -webkit-box-shadow: inset 0 2px 4px rgba(0,0,0,.15), 0 1px 2px rgba(0,0,0,.05);
    -moz-box-shadow: inset 0 2px 4px rgba(0,0,0,.15), 0 1px 2px rgba(0,0,0,.05);
    box-shadow: inset 0 2px 4px rgba(0,0,0,.15), 0 1px 2px rgba(0,0,0,.05);
}
.input_button.disabled,
.input_button[disabled] {
    cursor: default;
    background-image: none;
    opacity: 0.65;
    filter: alpha(opacity=65);
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}

.input_text {
    margin: 0;
    font-size: 100%;
    border-radius: 3px;
    border: 0;
    display: inline-block;
    height: 16px;
    padding: 4px 6px;
    margin-bottom: 6px;
    font-size: 13px;
    line-height: 16px;
    color: #555;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    background-color: #fff;
    border: 1px solid #ccc;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    -moz-box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    -webkit-transition: border linear .2s, box-shadow linear .2s;
    -moz-transition: border linear .2s, box-shadow linear .2s;
    -o-transition: border linear .2s, box-shadow linear .2s;
    transition: border linear .2s, box-shadow linear .2s;
}

::-webkit-input-placeholder { color: #CECECE; }

:-moz-placeholder { /* Firefox 18- */ color: #CECECE; }

::-moz-placeholder {  /* Firefox 19+ */ color: #CECECE; }

:-ms-input-placeholder {  color: #CECECE; }

.input_select {
    margin: 0;
    font-size: 100%;
    border-radius: 3px;
    border: 0;
    display: inline-block;
    height: 26px;
    padding: 4px 6px;
    margin-bottom: 6px;
    font-size: 13px;
    line-height: 16px;
    color: #555;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    background-color: #fff;
    border: 1px solid #ccc;
    -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    -moz-box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    -webkit-transition: border linear .2s, box-shadow linear .2s;
    -moz-transition: border linear .2s, box-shadow linear .2s;
    -o-transition: border linear .2s, box-shadow linear .2s;
    transition: border linear .2s, box-shadow linear .2s;
    vertical-align: middle;
    font-weight: normal;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.input_select2 {
    margin: 0;
    font-size: 100%;
    border-radius: 8px;
    border: 0;
    display: inline-block;
    height: 22px;
    padding: 1px 1px;
    margin-bottom: 6px;
    font-size: 14px;
    line-height: 14px;
    color: #555;
    border: 1px solid #ccc;
    box-shadow: inset 0 1px 1px rgba(0,0,0,0.075);
    transition: border linear .2s, box-shadow linear .2s;
    vertical-align: middle;
    font-weight: normal;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.input_option {
    color: #555;
    margin: 0;
    font-size: 100%;
    border: 0;
    font-size: 13px;
    font-weight: normal;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    background-color: #fff;
    padding-left: 4px;
    padding-right: 4px;
}

.input_info {
  padding: 5px;
  font-size: 80%;
  color: #666666;
}

/* Allgemeine Klassen und IDs */ 
img#logo { 
  
}

/* Tabellenüberschrift */
.tab_head {
  color: black;
  font-weight: bold;
  background-color: #E8E6E6;
  padding-left: 4px;
  padding-top: 4px;
  padding-bottom: 4px;
}

/* Spaltenüberschrift Sortier-Spalte*/
.tab_col_sort {
  text-align: left;
  color: black;
  font-weight: normal;
  background-color: #DCECFC;
  border-right: 1px solid #FFFFFF;
  border-bottom: 2px solid #203a73;
  padding-top: 2px;
  padding-bottom: 2px;
  padding-left: 5px;
}

/* Spaltenüberschrift */
.tab_col {
  text-align: left;
  color: black;
  font-weight: normal;
  background-color: transparent;
  border-bottom: 2px solid #203a73;
  padding: 2px;
}

/* Spaltenüberschrift */
.tab_col2 {
  text-align: left;
  color: black;
  font-weight: normal;
  //background-color: transparent;
  background-color: #FEE3C8; //#FEDFC0;
  border-bottom: 2px solid #203a73;
  padding: 2px;
}

/* Spaltenüberschrift */
.tab_col_center {
  text-align: center;
  color: black;
  font-weight: normal;
  background-color: transparent;
  border-bottom: 2px solid #203a73;
  padding: 2px;
}

/* Spaltenüberschrift */
.tab_col_right {
  text-align: right;
  color: black;
  font-weight: normal;
  background-color: transparent;
  border-bottom: 2px solid #203a73;
  padding: 2px;
}

/* Tabellenspalen */
.tab_row {
  color: #666666;
  font-weight: normal;
  background-color: transparent;
  padding: 2px;
  padding-right: 5px;
}
.tab_row2 {
  color: #666666;
  font-weight: normal;
  background-color: #F0F0FC;
  padding: 2px;
  padding-right: 5px;
}

/* Tabellenspalen */
.tab_row_center {
  text-align: center;
  color: #666666;
  font-weight: normal;
  background-color: transparent;
  padding: 2px;
  padding-right: 5px;
}
.tab_row2_center {
  text-align: center;
  color: #666666;
  font-weight: normal;
  background-color: #F0F0FC;
  padding: 2px;
  padding-right: 5px;
}

/* Tabellenspalen */
.tab_row_right {
  text-align: right;
  color: #666666;
  font-weight: normal;
  background-color: transparent;
  padding: 2px;
  padding-right: 5px;
}
.tab_row2_right {
  text-align: right;
  color: #666666;
  font-weight: normal;
  background-color: #F0F0FC;
  padding: 2px;
  padding-right: 5px;
}

/* Spaltensummen */
.tab_sum {
  text-align: left;
  color: black;
  font-weight: normal;
  background-color: transparent;
  border-top: 2px solid #203a73;
  padding: 2px;
}

/* Spaltensummen */
.tab_sum_center {
  text-align: center;
  color: black;
  font-weight: normal;
  background-color: transparent;
  border-top: 2px solid #203a73;
  padding: 2px;
}

/* Spaltensummen */
.tab_sum_right {
  text-align: right;
  color: black;
  font-weight: normal;
  background-color: transparent;
  border-top: 2px solid #203a73;
  padding: 2px;
  padding-right: 5px;
}

.tab_hover:hover  td{
  font-weight: normal;
  background-color: #FAFAEB;
  cursor: pointer;
}

.tab_cal:hover {
  font-weight: normal;
  background-color: #F0F0FC;
  cursor: pointer;
}

.tab_mon {
  font-weight: normal;
  border-left: 1px solid #E4E3E3;
  border-top: 1px solid #E4E3E3;
  padding-left: 5px;
  padding-top: 5px;
  padding-right: 2px;
  padding-bottom: 2px;
  font-size: 85%;
}

.tab_mini {
  font-weight: normal;
  color: #666666;
  font-size: 90%;
}

/* ======================================
  Untermenü
  ====================================== */

.tab_menu01{
  font-size: 95%;
  color: red;
  padding: 5px;
  background-color: #FFFFFF;
  margin-right: 2px;
  border-top: 1px solid #203a73;
  border-left: 1px solid #203a73;
  border-right: 1px solid #203a73;
  text-align: center;
} 

.tab_menu01 a:link  {
  color: #666666;
  text-decoration: none;
} 

.tab_menu01 a:hover {
  color: black;
  text-decoration: none;
} 

.tab_menu01 a:active {
  text-decoration: none;
} 

.tab_menu01 a:visited {
  text-decoration: none;
} 

.tab_menu01:hover  {
  background-color: #CCCCCC;
  cursor: pointer;
} 

.tab_menu02{
  font-size: 95%;
  color: #666666;
  padding: 5px;
  background-color: #EDF2FF;
  margin-right: 2px;
  border-top: 1px solid #203a73;
  border-left: 1px solid #203a73;
  border-right: 1px solid #203a73;
  text-align: center;
} 

.tab_menu02 a:link  {
  color: #666666;
  text-decoration: none;
} 

.tab_menu02 a:hover {
  color: black;
  text-decoration: none;
} 

.tab_menu02 a:active {
  text-decoration: none;
} 

.tab_menu02 a:visited {
  text-decoration: none;
} 

.tab_menu02:hover  {
  background-color: #CCCCCC;
  cursor: pointer;
} 

.form_login {
  background-color: #eee;
  width: 370px;
  padding: 20px;
  border: 1px solid #203a73;
}

  
/* ======================================
  3.  Styles für die Layoutbereiche
  ====================================== */
#wrapper { 
  background-color: white; 
  color: black; 
  min-width: 1150px;
  width: 90%;
  margin: 10px auto;
}
#kopfbereich {
  text-align: right;
  background-color: #203a73;
  color: white;
  padding: 10px 20px 0 20px;
}
  #kopfbereich p {
    padding: 5px 0 5px 0; 
    margin-bottom: 0;
  }
  div#kopfbereich p span {
     
  }
#navibereich { 
  text-align: left; 
  color: black;
  font-size: 11px;
  background-color: #203a73;
  padding: 5px 5px 4px 5px; 
  /* alt: padding: 5px 10px 4px 10px; */
  border-bottom: 1px solid #8c8c8c;
} 
  #navibereich ul { margin-bottom: 0; } 
  #navibereich li {
    display: inline; 
    list-style-type: none; 
    margin: 0;
  }
  #navibereich a ,
  #navibereich strong { 
    color: black;
    background-color: #D4E1F7; 
    padding: 4px 5px 4px 5px; 
	/* alt: padding: 4px 8px 4px 8px; */
    border: 1px solid #8c8c8c;
  } 
  #startseite #navi01 a,
  #kontaktseite #navi02 a { 
    color: black; 
    background-color: white; 
    border-bottom-color: white; 
  } 
  
  #navibereich #navi03 a {
    color: white;
    background-color: transparent; 
    border: 0px;
  }  
  #navibereich #navi03 a:hover, a:focus {
    color: #6699FF; /*black;*/
  }  

  #navibereich a:hover,
  #navibereich a:focus { 
    color: black; 
    background-color: white; 
    border-bottom-color: white;      
  } 
  #navibereich a:active {
    color: black; 
    background-color: white; 
    border-bottom-color: white;  
  } 
  
#textbereich { 
  padding: 20px 20px 20px 20px;
  overflow: auto;
  min-height: 65vH;
}
  #textbereich a { 
   
}
  #textbereich a:hover,
  #textbereich a:focus { 
}

#fussbereich {
  color: black; 
  margin: 10px auto;
  border-top: 1px solid #8c8c8c; 
}

#divWarten {
  width: 80%;
  top: 250px;
  display: none;
  position: absolute;
  z-index: 2;
  align:center;
  vertical-align:middle;
}

/* ======================================
  4. Sonstige Styles
  ====================================== */
/* Das Kontaktformular */
form {
  width: 370px;
  padding: 10px;
}

label {
  display: block;
  cursor: pointer;
}

/*input#absender,
textarea {
  width: 300px;
  border: 1px solid #8c8c8c;
  margin-bottom: 1em;
}*/

textarea {
  height: 7em;
}

input:focus,
textarea:focus {
  background-color: #F0F0FC;
  
  border-color: rgba(82,168,236,0.8);
  outline: 0;
  outline: thin dotted \9;
  -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(82,168,236,.6);
  -moz-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(82,168,236,.6);
  box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(82,168,236,.6); 
}

input:disabled {
    background: #F7F6F6;
} 


table.sortable tbody tr:nth-child(2n) td {
  color: #666666;
  background: #F0F0FC;
  padding: 2px;
  padding-right: 5px;
}
table.sortable tbody tr:nth-child(2n+1) td {
  color: #666666;
  background: transparent;
  padding: 2px;
  padding-right: 5px;
}

.csbutton_green {
  background-color: #4CAF50; /* Green */
  border: none;
  border-radius: 8px;
  color: white;
  padding: 4px 10px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}

.csbutton_gray {
  background-color: #e7e7e7; /* Gray  */
  border: none;
  border-radius: 8px;
  color: black;
  padding: 4px 10px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}

.csbutton_red {
  background-color: #f44336; /* Red */
  border: none;
  border-radius: 8px;
  color: white;
  padding: 4px 10px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}

.csbutton_blue {
  background-color: #000080; /* Blue (Navy) */
  border: none;
  border-radius: 8px;
  color: white;
  padding: 4px 10px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}

.csbutton_yellow {
  background-color: #E2B007; /* Yellow (Goldgelb) */
  border: none;
  border-radius: 8px;
  color: white;
  padding: 4px 10px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}

.csbutton_mini_yellow {
  background-color: #E2B007; /* Yellow (Goldgelb) */
  border: none;
  border-radius: 3px;
  color: white;
  padding: 2px 6px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}

.csbutton_mini_green {
  background-color: #4CAF50; /* Green */
  border: none;
  border-radius: 3px;
  color: white;
  padding: 2px 6px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 14px;
}


/* =======================================
   E N D E   D E S   S T Y L E S H E E T S
   ======================================= */
