/* -- GENERAL -- */
h4, h5, h6 { margin-top: 1em; }
h2 { font-size: 1.2em; line-height: 1em }
h3 { font-size: 1.1em; }
h4 { font-size: 1.0em; }
h5 { font-size: 0.9em; }
h6 { font-size: 0.9em; }
p { padding: 0.5em 0; }
ul, ol { padding-bottom: 0.5em; }
hr { clear: both; margin: 0; padding: 0; }

body {
    background: #CFDAE0 url(../images/background.png) repeat-x top left;
    color: #333;
    font-family: 'Trebuchet MS', Arial, Verdana, Geneva, sans-serif;
    font-size: 0.75em;
    line-height: 1.2em;
}
#container {
    margin: 10px auto;
    position: relative;
    width: 990px;
}
header form, nav li, footer li { display: inline-block; }
hr { border-color: #333; }
.accessibility {
    left: -10000px;
    position: absolute;
}

.box {
    background-color: #FFF;
    display: block;
    margin-top: 15px;
    position: relative;
}
.box h3 {
    border-bottom: #becdd6 1px solid;
    box-shadow: #becdd6 0px 2px 5px;
    -webkit-box-shadow: #becdd6 0px 2px 5px;
    -moz-box-shadow: #becdd6 0px 2px 5px;
    color: #F30;
    font-size: 1.2em;
    line-height: 2.5em;
    margin-bottom: 1em;
    text-align: center;
}
.box>p, .box>div, .box>section, .box>article, .box>ul, .box>ol, .box>hr, .box>form, .box>h4 { padding: 0 15px 15px 15px; }
.box>ul>li, .box>ol>li {
    margin-left: 20px;
}
ul ul, ul ol, ol ul { margin-left: 20px; }
.box>hr {
    border-color: #F30;
    margin: 15px 15px 0 15px;
}
aside .box>hr { clear: none; }

form .formerror {
    background-color: #FFFFB7;
    border: #F00 1px solid;
}
form .errorlist {
    color: #F00;
    font-weight: bold;
    list-style-type: none;
    padding: 1em 0 0;
}

/* -- call to action buttons -- */
.button {
    background: url(../images/button_left.png) no-repeat top left;
    display: inline-block;
    height: 28px;
}
.button a, .button a:hover { 
    background: url(../images/button_right.png) no-repeat top right;
    color: #A73C00;
    display: inline-block;
    font-size: 1em;
    height: 28px;
    line-height: 20px;
    margin-left: 11px;
    padding-right: 10px;
    text-decoration: none;
    text-shadow: #FFF 1px 1px 1px;
}
.bigbutton {
    background: url(../images/button_big_left.png) no-repeat top left;
    display: inline-block;
    height: 34px;
}
.bigbutton a, .bigbutton a:hover { 
    background: url(../images/button_big_right.png) no-repeat top right;
    color: #A73C00;
    display: inline-block;
    font-size: 1.2em;
    font-weight: bold;
    height: 34px;
    line-height: 30px;
    margin-left: 12px;
    padding-right: 10px;
    text-decoration: none;
    text-shadow: #FFF 1px 1px 1px;
}
.button a:hover, .bigbutton a:hover { text-decoration: underline; }
.button img, .bigbutton img { vertical-align: middle; }

/* -- HEADER -- */
header #account h2, #ksp h2, nav h2 { display: none; }
header #ksp h2.active {
    display: inline-block;
    font-size: 1.6em;
    padding-top: 10px;
    text-shadow: #000 0 0 3px;
    width: 500px;
}
header {
    background: #CFDAE0 url(../images/header_background.png) repeat-x top left;
    height: 110px;
    position: relative;
    text-align: center;
}
header, header a {
    color: #FFF;
    text-decoration: none;
}
header li.active a, header a:hover {
    text-decoration: underline;
}
header h1 {
    left: 0;
    padding: 10px;
    position: absolute;
    top: 6px;
} 
header #lang {
    padding: 2px 10px;
    position: absolute;
    right: 0px;
    top: 0;
}
header #lang h2 {
    display: inline;
    font-size: 90%;
    font-weight: normal;
}
header #lang form { opacity: 0.7; }
header #lang form.active, header #lang form:hover { opacity: 1; }
header #account {
    padding: 10px;
    position: absolute;
    right: 0;
    top: 15px;
}
header #account p { padding: 0; }
header #account img { vertical-align: middle; }
header nav {
    position: absolute;
    top: 78px;
}
header nav li {
    background: url(../images/menu_separator.png) no-repeat top right;
    height: 32px;
}
header nav li a {
    line-height: 35px;
    padding: 0 10px 0 5px;
}
header nav .dropdown a {
    background: url(../images/down_icon.png) no-repeat center left;
    padding-left: 15px;
}
header nav .dropdown div { display: none; }
header nav .dropdown:hover div {
    background: url(../images/partnersmenu_top.png) no-repeat top left;
    display: block;
    position: absolute;
    top: 25px;
    width: 250px;
    z-index: 10000;
}
header nav .dropdown:hover div ul {
    background-color: #FFF;
    background-color: rgba(255, 255, 255, 0.9);
    box-shadow: #CCC 0px 3px 5px;
    -webkit-box-shadow: #CCC 0px 3px 5px;
    -moz-box-shadow: #CCC 0px 3px 5px;
    margin-left: 0;
    margin-top: 5px;
}
header nav .dropdown:hover div ul li {
    display: block;
    background: none;
    height: auto;
    padding: 0 5px;
}
header nav .dropdown:hover div ul a {
    background-repeat: none;
    background-position: 5px center;
    border-bottom: 1px dotted;
    color: #333;
    display: block;
    line-height: 1;
    padding: 0 0 0.5em 60px;
    text-align: left;
}
header nav .dropdown:hover div ul a:hover {
    text-decoration: none;
}
header nav .dropdown:hover div ul a strong {
    display: block;
    line-height: 2em;
    text-decoration: underline;
}
header nav .dropdown:hover div ul a#partner-reseller { background-image: url(../images/partner_reseller.png); }
header nav .dropdown:hover div ul a#partner-operator { background-image: url(../images/partner_operator.png); }
header nav .dropdown:hover div ul a#partner-hotel { background-image: url(../images/partner_hotel.png); }
header nav .dropdown:hover div ul a#partner-campsite { background-image: url(../images/partner_campsite.png); }
header nav .dropdown:hover div ul a#partner-portal { background-image: url(../images/partner_portal.png); }
header nav .dropdown:hover div ul a#coverage-zone-a { background-image: url(../images/icon_3g_a.png); }
header nav .dropdown:hover div ul a#coverage-zone-b { background-image: url(../images/icon_3g_b.png); }
header nav .dropdown:hover div ul a#coverage-wifi { background-image: url(../images/icon_wifi_access_small.png); }
header nav .dropdown:hover div ul a#wifi-service { background-image: url(../images/icon_service_description_wifi.png); }
header nav .dropdown:hover div ul a#wifi-new-customer { background-image: url(../images/icon_new_customer_wifi.png); }
header nav .dropdown:hover div ul a#wifi-sign-up { background-image: url(../images/icon_sign_up_wifi.png); }
header nav .dropdown:hover div ul a#wifi-download { background-image: url(../images/icon_download_wifi.png); }
header nav .dropdown:hover div ul a#wifi-support { background-image: url(../images/icon_support_wifi.png); }
header nav .dropdown:hover div ul a#mobile-service { background-image: url(../images/icon_service_description_3g.png); }
header nav .dropdown:hover div ul a#mobile-new-customer { background-image: url(../images/icon_new_customer_3g.png); }
header nav .dropdown:hover div ul a#mobile-sign-up { background-image: url(../images/icon_sign_up_3g.png); }
header nav .dropdown:hover div ul a#mobile-download { background-image: url(../images/icon_download_3g.png); }
header nav .dropdown:hover div ul a#mobile-support { background-image: url(../images/icon_support_3g.png); }
header nav .dropdown:hover div ul li:last-child a { border-bottom: none; }
header form#findform {
    bottom: 2px;
    position: absolute;
    right: 10px;
}
header form#findform input[type=text] {
    background-color: #ffffb5;
    border: #e55d07 1px solid;
    font-size: 90%;
    padding-left: 5px;
    width: 200px;
}

/* -- CONTENT -- */
#content h2 { display: none; }
#content {
    float: left;
    position: relative;
    width: 745px;
}

/* -- SIDE -- */
.liveagent {
    cursor: pointer;
    display: block;
    padding: 15px;
    text-align: center;
}
.liveagent img { vertical-align: middle; }
aside h2 { display: none; }
aside {
    color: #777;
    margin-left: 760px;
}
#supportbutton {
    background: url(../images/support.png) no-repeat top center;
    text-align: center;
}
#supportbutton a { text-decoration: none; }
#supportbutton #clickhere, #supportbutton #clickhere strong { display: block; }
#supportbutton #clickhere strong {
    font-size: 1.3em;
    padding-bottom: 5px;
}
#supportbutton #clickhere {
    color: #3B6490;
    font-size: 1.1em;
    padding: 5px 20px 10px 70px;
    text-transform: uppercase;
}
#supportbutton #helpline h4 {
    font-size: 120%;
    font-weight: bold;
    margin-top: 0;
}
#supportbutton #helpline em {
    color: #F30;
    font-style: normal;
}
#supportbutton #helpline {
    font-size: 80%;
}
#sonja { float: left; width: 100%; }
#sonja .tiportrick ul {margin-left: 15px; }
#sonja .tiportrick hr {
    border-color: #ccc;
    border-style: dotted;
    clear: both;
    margin-top: 15px;
}
#sonja .tiportrick img {
    float: left;
    padding: 0 5px 5px 15px;
}

/* -- FOOTER -- */
footer {
    clear: both;
    padding-top: 15px;
}
footer p {
    background: #CFDAE0 url(../images/footer_background.png) repeat-x top left;
    color: #FFF;
    font-size: 90%;
    line-height: 20px;
    text-align: center;
}
footer p, footer p a { color: #FFF; }
footer ul, footer ul a {
    color: #777;
}
footer ul { padding-top: 5px; }
footer li {
    border-bottom: 1px dotted;
    display: block;
    font-size: 90%;
    font-weight: bold;
    line-height: 1.8em;
}
footer li ul { display: inline; margin-left: 0; }
footer li ul li {
    border-bottom: none;
    border-right: 1px dotted;
    display: inline;
    font-weight: normal;
    padding: 0 5px;
}
