/**
meel.fun styling based on mail.de template
main blue:  #3799c7   |    55, 153, 199
light blue: #77bfdd   |   119, 191, 211
main text:  #2f2f2f
bold text:  #848484
background: #d6d9d9
 */

@-ms-viewport     { width: device-width; }
@-o-viewport      { width: device-width; }
@viewport         { width: device-width; }

* {
    box-sizing: border-box;
}
body {
    /* CSS variables */
    --main--blue--light: #27a2f8;
    --main--blue--light--second: #0096ff;
    --main--blue--dark: #002752;
    --main--blue--dark--second: #1d2755;
    --bg--grey--light: #f6f7f8;

    padding: 0;
    margin: 0;
    background-image: linear-gradient(to bottom, var(--main--blue--light--second), var(--main--blue--light));
    background-size: cover;
    background-attachment: fixed;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    font-size: 15px;
    color: #fff;
    font-synthesis: none !important;
}

html,
body,
.site-wrapper,
.site-wrapper-inner {
    min-height: 100%;
}
h2 {
    font-size: 40px;
}
h3 {
    font-size: 35px;
}
h4 {
    font-size: 25px;
}
h3, h4 {
    margin: 10px 0;
}

.logo-text {
    font-size: 32px;
    font-weight: bold;
    color: var(--main--blue--dark);
    margin: 9px 0 6px;
}

input[type=radio] {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 1px solid #fff;
    background-color: var(--main--blue--dark--second);
}
input[type=radio]:checked::before {
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #fff;
    display: inline-block;
    margin: 3px;
}
input[type=checkbox] {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 1px solid #fff;
    background-color: var(--main--blue--dark--second);
    margin: 0 5px 0 0;
    vertical-align: middle;
}
input[type=checkbox]:checked {
    background-color: var(--main--blue--light);
    border-color: transparent;
}
input[type=checkbox]:checked::before {
    content: '✓';
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.inner {
    margin: auto;
    max-width: 800px;
}

#ecmaWarning {
    text-align: center;
    margin: 15% 0;
    font-weight: bolder;
}
#ecmaWarning .alert {
    font-size: large;
}

.masthead {
    width: 100%;
    background: #fff;
    padding: 0 15px;
}
.masthead nav,
.masthead-nav > li {
    display: inline-block;
}
.masthead nav {
    margin: 5px 0;
    float: right;
}
.masthead-nav > li {
    padding: 5px;
}
.masthead-nav > li a {
    font-size: 20px;
    text-decoration: none;
}
.masthead-nav > li.active a,
.masthead-nav > li:hover a {
    transform: scale(1.2);
    display: inline-block;
}

.cover-heading {
    position: relative;
    margin: 40px 5px 30px;
    width: auto;
    font-size: 120%;
    text-align: center;
}

#product_name {
    margin-top: 10px;
}
#product_name * {
    vertical-align: middle;
}
#product_name .icon {
    font-size: 50px;
    margin-right: 15px;
}
#product_name span {
    font-size: 35px;
}

.mastform {
    position: relative;
    background: var(--main--blue--dark);
    padding: 10px;
    width: auto;
}
.mastform form[name=signup] {
    padding-top: 20px;
}
.mastform h4 {
    margin-bottom: 20px;
}
.mastform ol {
    color: var(--main--blue--light);
    margin: 8px -20px;
}
.form-group {
    margin-bottom: 12px;
    position: relative;
}
.form-group > * {
    width: 100%;
}
.form-group label {
    color: #fff;
    font-size: 18px;
    margin-bottom: 5px;
}

.bsi-placeholder {
    text-align: center;
    padding: 15px;
    background: rgba(255,255,255,0.1);
    border-radius: 6px;
    font-size: 24px;
}

.mastfoot {
    background: var(--main--blue--dark--second);
    color: #ffffff;
    overflow: hidden;
}
.mastfoot a {
    color: var(--main--blue--light);
    text-decoration: none;
}
.mastfoot a:hover {
    text-decoration: underline;
}
.mastfoot .inner {
    padding: 0 25px;
    display: flex;
    gap: 5px;
}
.mastfoot .footcol {
    margin: 15px 0;
    flex: 1 1 auto;
}
.mastfoot .footcol h5 {
    margin-bottom: 15px;
    font-weight: bold;
    font-size: 16px;
}
.mastfoot .footcol .security-icon,
.mastfoot .footcol .privacy-icon {
    font-size: 40px;
    display: block;
    margin: 10px 0;
}
.mastfoot .footcol .infotxt {
    font-size: 11px;
    display: block;
    margin: 5px 0;
}
.mastfoot .footcol hr {
    color: #fff;
    margin: 5px 0;
}
.mastfoot .footcol ul {
    font-size: 12px;
    line-height: 1.4;
    padding-left: 0;
    list-style-type: none;
}
.mastfoot p {
    margin-top: 8px;
    font-size: 12px;
}

hr {
    color: var(--main--blue--light);
    margin: 20px 0;
}
.terms a,
label.check a {
    color: var(--main--blue--light);
}
a {
    font-weight: normal;
    color: #fff;
    text-decoration: underline;
}

#signup_product {
    margin: 0 auto;
}
#signup_product_choice div {
    display: inline-block;
    position: relative;
    left: -4px;
}
#signup_product_choice label {
    display: inline-block;
    width: 100%;
    left: 10px;
    top: 6px;
    margin: 12px 5px;
    cursor: pointer;
    font-size: 35px;
}
#signup_product_choice label * {
    vertical-align: middle;
}
#signup_product_choice label sup {
    vertical-align: super;
    font-size: 75%;
}
#signup_product_choice label .icon {
    font-size: 50px;
    margin: 0 10px;
}

#signup_credentials,
#signup_credentials_pass {
    position: relative;
    padding-right: 10px;
}

.form-control:not(input[type=radio]) {
    border: none;
    border-radius: 3px;
    background-color: #fff;
    padding: 5px 65px 5px 12px;
    height: 35px;
    margin-top: 5px;
    font-size: 14px;
}
.form-control:focus {
    box-shadow: none;
    outline: 2px solid var(--main--blue--light);
}

label.control-label {
    display: block;
    font-size: 110%;
    margin-bottom: 10px;
}

#signup_phone_phonenumber {
    padding-left: 85px;
}
#areaCode {
    font-size: 14px;
    height: 35px;
    border-right: 1px solid var(--main--blue--dark);
    padding: 10px;
    position: absolute;
    bottom: 0;
    color: #555;
    width: max-content;
}

.btn {
    font-size: 18px;
    padding: 15px 30px;
    background-color: var(--main--blue--light);
    color: #ffffff;
    border: none;
    border-radius: 6px;
    cursor: pointer;
}
.btn-verify {
    font-size: 16px;
    width: 100%;
    margin: 5px 0;
    padding: 15px 20px;
}
.btn:not(:disabled):hover {
    background-color: var(--main--blue--light--second);
}
.btn:disabled {
    cursor: default;
    opacity: 0.75;
}

#phoneValidationError {
    margin: 0 8px;
    color: #bb6633;
    font-weight: bold;
}

.alert {
    padding: 15px 20px;
    font-size: 13px;
    border-radius: 6px;
    color: var(--main--blue--dark);
    background-color: #fefefe;
    margin-bottom: 10px;
}
.alert-info {
    background-color: #c5f5fd;
    color: #005362;
}
.alert-warning {
    background-color: #fff2c8;
    color: #6b4c00;
}
.alert-danger {
    background-color: #ffd5da;
    color: #901025;
}

#availabilityState {
    font-size: 13px;
    border-radius: 6px;
    background-color: transparent;
    margin: 27px 0 27px 0;
    padding: 10px 20px;
    height: 36px;
}
#availabilityState.available {
    background-color: #d1e7dd;
    color: #0f5132;
}
#availabilityState.invalid,
#availabilityState.unavailable {
    background-color: #f8d7da;
    color: #842029;
}

#pwhelp {
    margin-top: 38px;
}
#phonehelp {
    margin-top: 26px;
}

#mainForm {
    position: relative;
}

#ajaxErrors {
    width: 93%;
    left: 3.5%;
}
#ajaxErrors .alert.alert-danger {
    position: fixed;
    top: 10px;
    z-index: 10000;
    background-color: #f8d7da;
    color: #842029;
}

#check {
    position: absolute;
    font-size: 28px;
    width: 35px;
    height: 35px;
    right: 10px;
    top: 27px;
    z-index: 10;
}
#check.available::before {
    content: "✔";
    color: green;
}
#check.unavailable::before {
    content: "✘";
    color: red;
}

#pwpie {
    position: absolute;
    height: 25px;
    width: 25px;
    border-radius: 50%;
    right: 45px;
    top: 32px;
    font-weight: bold;
    color: #ffffff;
    line-height: 25px;
    text-align: center;
}
#pwpie.bad,
#pwpie.short {
    background-image:
            linear-gradient(90deg, var(--main--blue--light) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0)),
            linear-gradient(126deg, #d03c41 50%, var(--main--blue--light) 50%, var(--main--blue--light));
}
#pwpie.weak {
    background-image:
            linear-gradient(90deg, var(--main--blue--light) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0)),
            linear-gradient(198deg, #bb6633 50%, var(--main--blue--light) 50%, var(--main--blue--light));
}
#pwpie.fair {
    background-image:
            linear-gradient(-36deg, #718d49 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0)),
            linear-gradient(270deg, #718d49 50%, var(--main--blue--light) 50%, var(--main--blue--light));
}
#pwpie.strong {
    background-image:
            linear-gradient(72deg, #77bb33 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0)),
            linear-gradient(270deg, #77bb33 50%, var(--main--blue--light) 50%, var(--main--blue--light));
}

#pwfit {
    position: absolute;
    width: 35px;
    height: 35px;
    right: 40px;
    top: 101px;
    z-index: 10;
    font-size: 28px;
}
#pwfit.okay::before {
    content: "✔";
    color: green;
}
#pwfit.fail::before {
    content: "✘";
    color: red;
}

.pwdToggle {
    position: absolute;
    right: 8px;
    top: 36px;
    width: 20px;
    height: 17px;
    cursor: pointer;
    font-size: 20px;
}

#callNotice {
    font-weight: bold;
    color: #ee953f;
    margin: 8px 0 4px 0;
}
#callNumber {
    color: #3799c7;
}
#retryValidationText {
    position: relative;
    top: -10px;
    left: 4px;
}
.ringing {
    position: relative;
    top: 0;
    animation-name: phoneRing;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    margin-right: 8px;
    float: left;
}
@keyframes phoneRing {
    0% {left:  0;}
    5% {left:  3px;}
    10% {left: 0;}
    15% {left: 3px;}
    20% {left: 0;}
    25% {left: 3px;}
    100% {left: 0;}
}

.contractSummary {
    position: relative;
}
.contractSummary .summaryInfo {
    display: inline-block;
    color: #494949;
    margin: 2px;
    width: 99%;
}
.contractSummary .totalCost {
    border-top: 2px dotted #898989;
    margin-bottom: 0;
    padding-top: 2px;
}
.contractSummary .summaryInfo.deco {
    color: var(--main--blue--dark);
    font-weight: bolder;
    font-size: 110%;
}
#signup_alert .summaryInfo.deco {
    font-size: 130%;
    height: 25px;
}
#PriceFreeMailZero .summaryInfo.deco {
    margin-top: -1px;
    margin-bottom: 5px;
}
.contractSummary .summaryInfo.detail {
    margin-bottom: 8px;
}
.contractSummary .vat {
    font-size: 7pt;
    margin: 0 2px;
}
.contractSummary .pricing {
    float: right;
    text-align: right;
    margin-right: 8px;
}

.terms {
    display: inline-block;
    font-size: 13px;
    margin-bottom: 10px;
}

#submissionArea {
    text-align: center;
    margin: 30px 0 15px;
    position: relative;
}
#submissionMask {
    position: absolute;
    width: calc(100% - 60px);
    height: 51px;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    z-index: 100;
    border-radius: 6px;
    color: #fff;
    line-height: 51px;
    font-weight: bold;
}
#submissionMask::after {
    content: 'Wird verarbeitet...';
}
#gotMail {
    text-align: center;
    margin: 12px 0;
}

label.check {
    font-size: 13px;
    line-height: 1.5;
}

@media (min-width: 640px) {
    html,
    body,
    .site-wrapper {
        height: 100%;
    }
    .logo-text {
        font-size: 45px;
    }

    .inner {
        margin-left: 10px;
        margin-right: 10px;
    }

    .mastform {
        border-radius: 6px;
        padding: 15px 30px;
    }
    .group-xs {
        max-width: 25%;
    }
    .group-s {
        max-width: 34%;
    }
    .group-sm {
        max-width: 42%;
    }
    .group-m {
        max-width: 50%;
    }
    .row {
        display: flex;
        gap: 25px;
    }
    .row > div {
        flex: 1 1 auto;
        width: 100%;
    }
    .bsiCol .bsi-placeholder {
        float: right;
        margin-left: 10px;
        margin-top: 0;
    }
    .terms {
        margin-bottom: 0;
        max-width: 325px;
    }
}

@media (min-width: 815px) {
    .inner {
        margin: auto;
    }
}
