/********************************************************************************
 * Reset
 ********************************************************************************/
div.clear {
    clear: both;
}

/********************************************************************************
 * Page layout
 ********************************************************************************/
body{
    font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Lucida, Arial, Helvetica, Sans-Serif;
    font-size: 15px;
    background-image: url('../skin/main.background.jpg');
    background-repeat: repeat-x;
    background-position: center top;
}
@media (min-width: 758px) {
    body{
        background-image: none;
    }
}
@media (min-width: 992px) {
    body{
        background-image: url('../skin/main.background.jpg');
    }
}
.container.pageWrapper {
    max-width: 970px;
    overflow: hidden;
    background-position: center;
}
.container-fluid.page {
    background-image: url('../skin/main.page.noframe.trans.png');
    background-repeat: no-repeat;
    background-size: 100% auto;
}
@media (min-width: 758px) {
    .container-fluid.page {
        background: url('../skin/main.flow.png'), url('../skin/main.page.jpg');
        background-repeat: repeat-y, no-repeat;
        background-size: cover, cover;
        background-size: 100% auto, 100% auto;
        background-position: 0 100px center, top center;
    }
}
@media (min-width: 992px) {
    .container-fluid.page {
        min-height: 940px;
        background: url('../skin/main.page.jpg'), url('../skin/main.flow.png');
        background-repeat: no-repeat, repeat-y;
        background-size: 100% auto, 100% auto;
    }
}
.container.content {
    width: 100%;
    padding: 20px 0px;
}
@media (min-width: 480px) {
   .container.content {
       width: 80%;
       padding: 20px 20px;
    }
}
@media (min-width: 576px) {
    .container.content {
        max-width: 700px;
        padding: 20px 50px;
    }
}
.banner {
    padding: 20px;
}
.mainlogo {
    max-width: 80%;
}

/********************************************************************************
 * Menu
 ********************************************************************************/

.container.menumobile{
    width: calc(80% + 32px);
}
@media (max-width: 480px){
    .container.menumobile{
        width: calc(100% + 60px);
        padding:0;
        margin:0 -30px;
    }
}
@media (min-width: 576px) {
    .container.menumobile{
        margin:0 auto 2rem auto;
        max-width: 750px;
    }
}
.nav-tabs{
    border:0;
    margin-left: 0;
}
.menumobile a.nav-link{
    color: #FFF !important;
    text-decoration: none;
    border: 0;
}
.menumobile a.nav-link:hover{
    text-shadow: 0 0 4px rgba(255,255,255,.4);
}
.nav-tabs .nav-item {
    margin: 0 0 0 7.5px;
}
@media (min-width: 480px){
    .nav-tabs .nav-item {
        margin: 0 0 0 15px;
    }
}
@media (min-width: 576px) {
    .nav-tabs .nav-item{
        margin: 0 0 0 30px;
    } 
   .nav-tabs .nav-item:first-child {
        margin: 0 0 0 45px;
    }
	.items .nav-link:first-child {
        margin-left: 35px;
    }
}
.nav-tabs .nav-link{
    border-top-left-radius: .3rem;
    border-top-right-radius: .3rem;
}
.nav-tabs .nav-link.type_flwb{
    background: rgb(211,50,16);
}
.nav-tabs .nav-link.type_flwb.active{
    background: linear-gradient(180deg, rgba(142,30,7,1) 0%, rgba(211,50,16,1) 80%);
}
.nav-tabs .nav-link.type_2ph{
    background: rgb(14,48,134);
}
.nav-tabs .nav-link.type_2ph.active{
    background: linear-gradient(180deg, rgba(8,32,96,1) 0%, rgba(14,48,134,1) 80%);
}
.items .nav{
    border:none;
    box-shadow: 0 0 5px 1px rgba(0,0,0,.5);
    border-radius: none;
}
@media (min-width: 480px) {
    .items .nav{
        border-radius: .3rem;
    }   
}
.items .nav.type_flwb{
    background: rgb(211,50,16);
    background: linear-gradient(180deg, rgba(211,50,16,1) 40%, rgba(142,30,7,1) 100%);
}
.items .nav.type_2ph{
    background: rgb(14,48,134);
    background: linear-gradient(180deg, rgba(14,48,134,1) 40%, rgba(8,32,96,1) 100%);
}

/********************************************************************************
 * General
 ********************************************************************************/
a:link, a:visited, a:hover {
    font-weight: bold;
    text-decoration: underline;
}
.type_2ph a:link, .type_2ph a:visited {
    color: #0030ad;
}
.type_2ph a:hover {
    color: #2080ff;
}
.type_flwb a:link, .type_flwb a:visited {
    /* color: #ac1800; */
}
.type_flwb a:hover {
    color: #ff3d0d;
}
a.nolink {
    text-decoration: none;
    color: #FFF !important;
    font-weight: normal;
}
/* -- submenu -- */
nav.subnav .nav-link.active{
  text-decoration: none;
   color: #000;
}
nav.subnav .nav-link{
    padding-left: 0rem;
    padding-right: 1.2rem;
}
nav.subnav .nav-link:last-child {
    padding-right: 0;
}

/* -- unsortet lists -- */
ul.listboxen li:hover i.fas.fa-fw{
    color: rgba(0,0,0,.9);
}
ul.listboxen li{
    transform: all .3s;
}
ul.listboxen li:hover{
    background-color: rgba(0,0,0,.1);
    transform: all .3s;
}
ul.listboxen li i.fas.fa-fw{
    margin-right: 1.25rem;
    color:rgb(14,48,134);
}
ul.listboxen li p{
    margin-bottom:0;
}
/*------*/

div.clear {
    clear: both;
}

h1, h2, h3, h4{
    margin-bottom: 8px;
}
h1{
    font: 26px Georgia, Times New Roman, Serif;
}
h1.site_title{
    font-size: 20px;
}
h2{
    font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Lucida, Arial, Helvetica, Sans-Serif;
    font-size: 22px;
}
h2.page_utitle{
    font-size: 29px;
}
h3{
    font-size: 18px;
    margin-top: 2.5rem;
}
h4{
    font-size: 16px;
    font-style: italic;
    margin-top: 1.25rem;
}

small {
    font-size: 80%;
}
/**
* Moderatoren
*/

.card-title {
    font-size: 18px;
    margin-bottom: 0;
}
.card-text {
    font-size: 13px;
    margin-bottom: 5px;
}
.card-body {
    padding: 1rem;
}
/**
* Partner
*/
.tablelinks {
    font-weight: normal !important;
    font-size: .75rem;
}
/**
* Home
*/
#homebgimg {
    margin-left: -2.4rem;
    margin-right: -2.4rem;
    background-size: 100% auto;
    background-size: cover;
    -webkit-background-size: cover;
    background-attachment: fixed;
    background-image: url('../images/home/WABKurs.jpeg');
    background-position: center;
    height: 66vh;
}
@media only screen and (max-device-width: 1112px) { /*Tablets and Mobilephones*/
    #homebgimg {
        background-attachment: scroll;
    }
}
@media (min-width: 954px) {
    #homebgimg {
        margin-left: -3rem;
        margin-right: -3rem;
    }
}

/********************************************************************************
 * Footer
 ********************************************************************************/
p.login {
    text-align: center;
    margin: 50px 0 -30px;
    padding: 5px;
}

p.footer {
    text-align: center;
    margin-top: 30px;
    padding: 5px;
}

/********************************************************************************
 * Icon links
 ********************************************************************************/
a.icon {
    padding-left: 20px;
    background: no-repeat 0 3px;
}

a.icon.pdf {
    background-image: url('../skin/icons/pdf.png');
}

a.icon.email {
    background: url('../skin/icons/email.png') no-repeat 0 2px;
    font-weight: normal;
    font-size: 80%;
}

a.icon.delete {
    background: url('../skin/delete.png') no-repeat 0 2px;
    font-weight: normal;
    font-size: 80%;
}

a.icon.email:link, a.icon.email:visited, a.icon.email:hover {
    color: #000;
    text-decoration: none;
}

/********************************************************************************
 * Partner list
 ********************************************************************************/
div.partnerlist div.logo {
    float: left;
    margin: 0 20px 30px 30px;
}

div.partnerlist div.logo img {
    border: 1px solid #C0C0C0;
    padding: 4px;
    width: 160px;
}

div.partnerlist div.text {
    float: left;
    margin-bottom: 30px;
}

/********************************************************************************
 * Courses table
 ********************************************************************************/
table {
    margin-bottom: 8px;
}

table.courses {
    width: 100%;
    border-collapse: separate;
}

table.courses td {
    padding: 4px 0;
    font-size: 14px;
    border-top: 1px solid #FFF;
    border-bottom: 1px solid #BBB;
}

table.courses td.first {
    padding-left: 15px;
}

table.courses td.last {
    padding-right: 15px;
    width:120px;
}
ul.course-reg-steps, div.course-reg-next {
    border-top: 1px solid #BBB;
    border-bottom: 1px solid #BBB;
    background: url('../skin/links-background.png');
}

ul.course-reg-steps {
    margin: 10px 0;
    padding: 10px 30px;
    color: #444;
}

ul.course-reg-steps li {
    list-style: none;
    display: inline;
    margin: 0 25px 0 0;
    color: #666;
}
ul.course-reg-steps li:first-child{
   margin-left: -20px;
}
ul.course-reg-steps li span {
    font-family: Helvetica, Arial, Sans-Serif;
    font-size: 18px;
    line-height: 30px;
    padding: 0 9px;
    display:inline-block;
    height: 30px;
    width: 30px;
    margin-right: 5px;
    border: 1px solid #888;
    border-radius: 50%;
    background: #EEE;
}

ul.course-reg-steps li.selected {
    font-weight: bold;
    color: #000;
}

ul.course-reg-steps li.selected span {
    background: #FFF;
}

div.course-reg-next {
    margin: 20px 0 10px 0;
    padding: 8px 30px;
}

div.course-reg-next .next {
    float: right;
}

div.course-reg-next .previous {
    float: left;
}

table.courses a.icon {
    font-weight: normal;
    font-size: 80%;
    padding-top: 2px;
    padding-bottom: 2px;
    margin-right: 10px;
}

table.courses a.icon:link, table.courses a.icon:visited {
    text-decoration: none;
}

table.courses a.icon:hover {
    text-decoration: underline;
}

/********************************************************************************
 * Registration data table
 ********************************************************************************/
table.regdata {
    margin: 20px 0;
    width: 100%;
    border-collapse: collapse;
}

table.regdata td {
    border-bottom: 1px solid #bbb;
    padding: 5px 0 5px 30px;
}

table.regdata td.label {
    font-weight: bold;
    font-size: 80%;
    width: 100px;
    vertical-align: top;
}

table.regdata tr.first td {
    border-top: 1px solid #bbb;
}

/********************************************************************************
 * Loading indicator
 ********************************************************************************/
span.indicator {
    background: url('../skin/indicator.gif') no-repeat;
    padding-left: 20px;
    font: 14px "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Lucida, Arial, Helvetica, Sans-Serif;
    color: #888;
}
/********************************************************************************
 * Mobility package box
 ********************************************************************************/
div#mobility-box {
    margin: 0 30px 10px;
    padding: 8px;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
}
