@import url('https://fonts.googleapis.com/css?family=Material+Icons|Iceberg|Maven+Pro:400,500,700,900');

/* General */

html { -webkit-font-smoothing: antialiased; }
body { font-family: 'Maven Pro', sans-serif; font-size: 16px; /*background-color: #89cac8;*/ }

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 { font-family: 'Maven Pro', sans-serif; font-weight: 900; color: #89cac8; }
h2, .h2 { font-size: 30px; }
h3, .h3 { font-size: 20px; }

h2.lg, .h2.lg, h3.lg, .h3.lg { font-size: 46px; margin-bottom: 20px; }

p, ul, ol { color: #333; font-weight: 400; line-height: 1.5; } /*color was: #454d4a*/

a { cursor: pointer; color: #ec008d; }
a:hover, a:active, a:focus { text-decoration: underline; color: #ec008d; }

ul.horizontal-list { margin: 0; padding: 0; list-style-type: none; }
ul.horizontal-list li { display: inline-block; }
ul.horizontal-list li a { display: block; }

ul.vert-list { margin-top: 10px; padding: 0; list-style-type: none; }
ul.vert-list > li { position: relative; margin-bottom: 8px; padding-left: 16px; font-weight: 500; }
ul.vert-list > li::before { position: absolute; left: 0; top: 8px; display: inline-block; width: 10px; height: 10px; border-radius: 2px; background-color: #ec008d; content: ''; }

i.material-icons { vertical-align: middle; }

img { max-width: 100%; height: auto; }

hr { border-top: 1px solid #89cac8; }

img { max-width: 100%; height: auto; }

.h-with-link a { color: #89cac8; }
.h-with-link a:hover, .h-with-link a:active, .h-with-link a:focus { color: #89cac8; text-decoration: none; }

.page-loading { display: none; }

.wrapper { position: relative; padding-top: 170px; overflow-x: hidden; background-color: #fff; }
.wrapper.wrapper-home { padding-top: 72px; }

.embed-container { position: relative; padding-bottom: 56.25%; height: 0; margin-top: 10px; overflow: hidden; max-width: 100%; -webkit-box-shadow: 0px 2px 12px 0px rgba(0,0,0,0.75); -moz-box-shadow: 0px 2px 12px 0px rgba(0,0,0,0.75); box-shadow: 0px 2px 12px 0px rgba(0,0,0,0.75); }
.embed-container iframe, .embed-container object, .embed-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.flex-wrap { display: flex; align-items: stretch; flex-wrap: wrap; justify-content: space-between; margin-left: -15px; margin-right: -15px; }
.flex-wrap.flex-center { justify-content: center; }
.flex-wrap.flex-left { justify-content: left; }
.flex-item-1-1 { flex-basis: 100%; margin-left: 15px; margin-right: 15px; }
.flex-item-1-2 { flex-basis: calc(50% - 30px); margin-left: 15px; margin-right: 15px; }
.flex-item-1-3 { flex-basis: calc(33.33% - 30px); margin-left: 15px; margin-right: 15px; }
.flex-item-1-4 { flex-basis: calc(25% - 30px); margin-left: 15px; margin-right: 15px; }
.flex-item-padded { padding-left: 10%; padding-right: 10%; }

/* Global styles */

#navbar { position: fixed; top: 0; width: 100%; z-index: 19; }
#navbar #navbar-top { height: 72px; background-color: #89cac8; border-bottom: 1px solid #fff; }
#navbar #navbar-top #navbar-top-inner { position: relative; padding-left: 150px; }
#navbar #navbar-top #navbar-top-inner #navbar-logo { position: absolute; top: 0; left: 0; display: block; width: 140px; height: auto; }
#navbar #navbar-top #navbar-top-inner #navbar-logo img { max-width: 100%; height: auto; }

#navbar #navbar-top #navbar-top-inner ul#main-nav li a { padding: 24px 15px; font-size: 14px; font-weight: 700; text-transform: uppercase; color: #fff; }
#navbar #navbar-top #navbar-top-inner ul#main-nav li a:hover, #navbar ul#main-nav li a:active, #navbar ul#main-nav li a:focus { text-decoration: none; opacity: 0.75; }
#navbar #navbar-top #navbar-top-inner ul#main-nav li { position: relative; }
#navbar #navbar-top #navbar-top-inner ul#main-nav li::before { content: ''; position: absolute; top: 0; left: 50%; width: 1px; height: 20px; background-color: #fff;  transform-style: preserve-3d; -webkit-transform-style: preserve-3d; }

#navbar #navbar-top #navbar-top-inner ul#main-nav-social li a { padding: 20px 10px; }
#navbar #navbar-top #navbar-top-inner ul#main-nav-social li a img { width: 16px; height: 16px; }
#navbar #navbar-top #navbar-top-inner ul#main-nav-social li::after { content: ''; position: absolute; top: 0; right: 40px; width: 1px; height: 44px; background-color: #fff; }
#navbar #navbar-top #navbar-top-inner ul#main-nav-social li:last-child::after { display: none; }
#navbar #navbar-top #navbar-top-inner ul#main-nav-social li a:hover, #navbar #navbar-top #navbar-top-inner ul#main-nav-social li a:focus, #navbar #navbar-top #navbar-top-inner ul#main-nav-social li a:active { opacity: 0.75; }

#navbar #navbar-breadcrumb { height: 48px; background-color: #00A12F; color: #fff; font-size: 14px; font-weight: 500; }
#navbar #navbar-breadcrumb #navbar-breadcrumb-inner { padding: 12px 0 0 160px; }
#navbar #navbar-breadcrumb #navbar-breadcrumb-inner a { color: #fff; }

#mobile-menu { background-color: #00A12F; }
#mobile-menu a { color: #fff; font-size: 14px; font-weight: 700; text-transform: uppercase; }
.mm-vertical .mm-panel { padding-top: 6px; }
.mm-menu .mm-listview > li:after { border: 0px none; }

#home-postcode-check .form-control, #postcode-check .form-control { height: 42px; border: 0px none; }

.btn { padding: 10px 12px 10px 12px; font-size: 16px; font-weight: 700; }
.btn-block { display: block; }
.btn.btn-primary { border: 0px none !important; background-color: #ec008d; }
.btn.btn-primary:hover, .btn.btn-primary:active, .btn.btn-primary:focus { background-color: #a0248f; }
.btn.btn-default { border: 1px solid #89cac8; color: #89cac8; background-color: #fff; font-size: 16px; }
.btn.btn-default:hover, .btn.btn-default:active, .btn.btn-default:focus { background-color: #89cac8; color: #fff !important; }
.btn.btn-link { border: 0px none !important; color: #ec008d; background-color: transparent; font-size: 16px; font-weight: 500; }
.btn.btn-link:hover, .btn.btn-link:active, .btn.btn-link:focus { background-color: transparent !important; color: #ec008d; text-decoration: underline; }

body.admin-bar .modal-dialog { margin-top: 40px; }
.modal-content { box-shadow: none; border: 0px none; }
.modal-footer { padding: 0 40px 40px 40px; border-top: 0px none; text-align: left; }
.modal-footer .btn { font-size: 16px; }
.modal-body { position: relative; padding: 40px; }
.modal-body h2 { margin-top: 0; }
.modal-body .bootbox-close-button { position: absolute; top: 0; right: -10px; padding: 0; width: 30px; height: 30px; margin-top: 0; text-align: center; font-family: arial; font-weight: normal; line-height: 0; color: #fff; background-color: #4fb9c4; opacity: 1; border-radius: 50%; border: 1px solid #fff; }
.modal-body .form-control { background-color: #eff0f0; box-shadow: inset 0 1px 1px rgba(0,0,0,0); -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,0); border-width: 0; }
.alert-form .modal-body { padding: 20px 40px 40px 40px; }

section.section-padding { padding-top: 30px; padding-bottom: 30px; }
section:last-of-type.section-padding { padding-bottom: 60px; }

.poly-bg { padding-top: 80px !important; padding-bottom: 80px !important; margin-top: 30px; margin-bottom: 30px; background-position: center center; background-size: cover; background-repeat: no-repeat; background-image: url('../img/poly-bg.jpg'); }

footer { padding-top: 40px; padding-bottom: 40px; background-color: #89cac8; color: #fff; }
footer ul.horizontal-list { float: right; }
footer ul.horizontal-list li::before { content: ''; display: inline-block; width: 2px; height: 11px; margin: 0 15px; background-color: #fff; }
footer ul.horizontal-list li:first-child::before { width: 0; height: 0; margin: 0; }
footer ul.horizontal-list li a { display: inline-block; color: #fff; font-weight: 500; }

.pagination { padding-bottom: 50px; }
.pagination .screen-reader-text { display: none; }
.pagination .page-numbers { display: inline-block; min-width: 30px; height: 30px; margin: 0 4px; padding: 2px 4px; text-align: center; border-radius: 3px; background-color: #fff; border: 1px solid #89cac8; color: #89cac8; font-weight: 500; }
.pagination .page-numbers.current { background-color: #89cac8; color: #fff; }
.pagination .page-numbers:hover, .pagination .page-numbers:focus, .pagination .page-numbers:active { background-color: #cee5d4; text-decoration: none; }
.pagination .page-numbers.dots { background-color: transparent; border: 0px none; }

#postcode-check { position: fixed; z-index: 99; right: -630px; top: 50%; transform: translateY(-50%); width: 630px; height: auto; min-height: 200px; padding: 30px; background-color: #eff0f0; border: 1px solid #e6007e; border-right: 0px none; -webkit-transition: all 1s ease; -moz-transition: all 1s ease; -o-transition: all 1s ease; -ms-transition: all 1s ease; transition: all 1s ease; }
.mm-opened #postcode-check { display: none; }
#postcode-check.open { right: 0; }
#postcode-check h2 { margin-top: 0; }
#postcode-check .form-inline { margin-top: 30px; }
#postcode-check .form-control { width: 90px; }
#postcode-check .form-control#address_zipcode { width: 160px; }
#postcode-check #postcode-check-btn { display: block; position: absolute; top: 77px; left: -122px; height: 42px; text-align: center; width: 200px; padding: 10px 8px; -webkit-transform: rotate(-90deg); transform: rotate(-90deg); transform-style: preserve-3d; border: 1px solid #ec008d; border-radius: 3px 3px 0 0; background-color: #ec008d; color: #fff; font-weight: 700; }
#postcode-check #postcode-check-btn:hover { text-decoration: none; background-color: #a0248f; }

/* Home */

#home-header { position: relative; height: 520px; }
#home-header #home-header-inner { position: absolute; bottom: 40px; width: 100%; padding-bottom: 30px; padding-top: 20px; background-color: rgba(0,0,0,0.4); }
#home-header #home-header-inner h1 { font-size: 58px; font-weight: 900; }
#home-header #home-header-inner h1 span { display: block; font-size: 54px; font-weight: 700; }

#home-postcode-check { position: relative; z-index: 9; padding: 30px; margin-bottom: 20px; border: 1px solid #fff; border-radius: 3px; background-color: #89cac8; }
#home-postcode-check .form-group { float: left; width: 35%; margin-bottom: 20px; padding-right: 15px; }
#home-postcode-check .form-group:first-of-type { width: 100%; padding-right: 0; }
#home-postcode-check .form-group:last-of-type { width: 30%; padding-right: 0; }
#home-postcode-check .form-group .form-control { display: block; width: 100%; }
#home-postcode-check .btn { clear: both; padding: 11px 12px 11px 12px; font-size: 14px; }

#map-section { position: relative; padding-top: 100px; }
#map-section #map, #map-section #map-custom-802, .multiple-map { width: calc(100% - 20px); height: 400px; }
#map-section #map-overlay { position: absolute; min-height: 100px; top: 18px; left: -5px; right: 15px; padding: 12px 20px; border: 2px solid #89cac8; border-radius: 6px; background-color: #89cac8; }
#map-section #map-overlay:before {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0; content: ''; border-radius: 6px;
    background: rgba(0,0,0,0.6);
    background: -moz-linear-gradient(top, rgba(0,0,0,0.6) 15%, rgba(0,0,0,0.6) 16%, rgba(0,0,0,0.39) 31%, rgba(0,0,0,0.1) 51%, rgba(0,0,0,0.1) 83%, rgba(0,0,0,0.48) 93%, rgba(0,0,0,0.6) 96%, rgba(0,0,0,0.6) 100%);
    background: -webkit-gradient(left top, left bottom, color-stop(15%, rgba(0,0,0,0.6)), color-stop(16%, rgba(0,0,0,0.6)), color-stop(31%, rgba(0,0,0,0.39)), color-stop(51%, rgba(0,0,0,0.1)), color-stop(83%, rgba(0,0,0,0.1)), color-stop(93%, rgba(0,0,0,0.48)), color-stop(96%, rgba(0,0,0,0.6)), color-stop(100%, rgba(0,0,0,0.6)));
    background: -webkit-linear-gradient(top, rgba(0,0,0,0.6) 15%, rgba(0,0,0,0.6) 16%, rgba(0,0,0,0.39) 31%, rgba(0,0,0,0.1) 51%, rgba(0,0,0,0.1) 83%, rgba(0,0,0,0.48) 93%, rgba(0,0,0,0.6) 96%, rgba(0,0,0,0.6) 100%);
    background: -o-linear-gradient(top, rgba(0,0,0,0.6) 15%, rgba(0,0,0,0.6) 16%, rgba(0,0,0,0.39) 31%, rgba(0,0,0,0.1) 51%, rgba(0,0,0,0.1) 83%, rgba(0,0,0,0.48) 93%, rgba(0,0,0,0.6) 96%, rgba(0,0,0,0.6) 100%);
    background: -ms-linear-gradient(top, rgba(0,0,0,0.6) 15%, rgba(0,0,0,0.6) 16%, rgba(0,0,0,0.39) 31%, rgba(0,0,0,0.1) 51%, rgba(0,0,0,0.1) 83%, rgba(0,0,0,0.48) 93%, rgba(0,0,0,0.6) 96%, rgba(0,0,0,0.6) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0.6) 15%, rgba(0,0,0,0.6) 16%, rgba(0,0,0,0.39) 31%, rgba(0,0,0,0.1) 51%, rgba(0,0,0,0.1) 83%, rgba(0,0,0,0.48) 93%, rgba(0,0,0,0.6) 96%, rgba(0,0,0,0.6) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#000000', GradientType=0 );
}
#map-section #map-overlay .content-top { position: relative; padding-left: 90px; padding-right: 100px; color: #fff; line-height: 1.3; font-weight: 500; font-size: 15px; }
#map-section #map-overlay span.percentage { display: block; position: absolute; left: 0; top: 0; font-size: 52px; font-family: 'Iceberg', cursive; text-shadow: 2px 2px 0px rgba(0, 0, 0, 0.3); }
#map-section #map-overlay span.percentage span.perc-sign { font-size: 30px; }
#map-section #map-overlay #details { position: absolute; right: -15px; top: -15px; width: 120px; padding: 14px 2px; border: 2px solid #fff; border-radius: 12px; background-color: #ec008d; -webkit-box-shadow: 0px 3px 7px 0px rgba(0,0,0,0.6); -moz-box-shadow: 0px 3px 7px 0px rgba(0,0,0,0.6); box-shadow: 0px 3px 7px 0px rgba(0,0,0,0.6); }
#map-section #map-overlay #details:before {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0; content: ''; border-radius: 12px;
    background: rgba(0,0,0,0);
    background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 15%, rgba(0,0,0,0.3) 90%, rgba(0,0,0,0.3) 100%);
    background: -webkit-gradient(left top, left bottom, color-stop(0%, rgba(0,0,0,0)), color-stop(15%, rgba(0,0,0,0)), color-stop(90%, rgba(0,0,0,0.3)), color-stop(100%, rgba(0,0,0,0.3)));
    background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 15%, rgba(0,0,0,0.3) 90%, rgba(0,0,0,0.3) 100%);
    background: -o-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 15%, rgba(0,0,0,0.3) 90%, rgba(0,0,0,0.3) 100%);
    background: -ms-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 15%, rgba(0,0,0,0.3) 90%, rgba(0,0,0,0.3) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 15%, rgba(0,0,0,0.3) 90%, rgba(0,0,0,0.3) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#000000', GradientType=0 );
}
#map-section #map-overlay #details #details-inner { position: relative; width: 100%; text-align: center; color: #fff; font-weight: 500; font-size: 15px; line-height: 1.2; }
#map-section #map-overlay .progress { position: relative; width: calc(100% - 110px); height: 8px; border: 1px solid #fff; margin-bottom: 0; margin-top: 8px; background-color: #fff; box-shadow: none; -webkit-box-shadow: none; }
#map-section #map-overlay .progress .progress-bar { background-color: #ec008d; }

.bottom-maps #map-section {
    padding-top: 0;
    padding-bottom: 118px;
}

.map-overlay-bottom{

    bottom: 18px;
    top: inherit !important;

}

.bottom-maps{

    margin-top: 50px;

}

.news-post p { margin-bottom: 0; }
.news-thumb { display: block; }
.news-thumb, .news-img { position: relative; height: 150px; margin-bottom: 10px; border-radius: 3px; }
.news-img { height: 240px; }
.news-thumb .date-label, .news-img .date-label { position: absolute; top: -1px; left: 20px; display: inline-block; min-width: 50px; padding: 4px 8px 24px 8px; text-align: center; background-color: #fff; font-size: 20px; font-weight: 500; color: #89cac8; line-height: 1; -webkit-clip-path: polygon(0 0, 100% 0, 100% 75%, 0% 100%); clip-path: polygon(0 0, 100% 0, 100% 75%, 0% 100%); }
.news-thumb .date-label span, .news-img .date-label span { display: block; }
.news-thumb .date-label span.lg, .news-img .date-label span.lg { font-size: 24px; font-weight: 900; }

.isp { display: block; }
.isp img { max-width: 100%; height: auto; }

.block-pros, .block-faq, .block-poll, .block-signup-check { padding: 30px; border: 2px solid #89cac8; border-radius: 3px; background-color: #fff; }
.block-faq ul.vert-list > li > a { color: #454d4a; }
.block-poll .radio { margin-bottom: 14px; }
.block-poll .radio label { font-weight: 500; color: #454d4a }
.block-signup-check { position: relative; margin-top: 30px; }
.block-signup-check:last-of-type { margin-bottom: 30px; }
.block-signup-check h2 { margin-top: 0; }
.block-signup-check h3 { margin-top: 0; padding-right: 70px; font-size: 16px; }
.block-signup-check ul { margin-bottom: 0; padding: 0; list-style-type: none; }
.block-signup-check .sign-up-check-edit { display: block; position: absolute; right: 30px; top: 30px; }
.block-signup-check #fiberglassconnection_postcodechecker_description p:last-of-type { margin-bottom: 0; }

/* Archive blog */

#archive-blog .news-post { margin-bottom: 40px; }

/* Single blog, Page, 404 */

.content h1 { font-size: 30px; margin-top: 30px; margin-bottom: 20px; }
.content h2 { font-size: 18px; margin-bottom: 6px; }
.content h3, .content h4, .content h5 { font-size: 16px; margin-bottom: 4px;  }
.content h5 { color: #454d4a; font-weight: 500; }
.content img { margin: 15px 0; }

#single-blog, #page, #faq, #form-wrapper, #form-check-wrapper, #four-oh-four { padding-bottom: 50px; }

#four-oh-four .content a { display: inline-block; margin: 5px 0; color: #454d4a; }
#four-oh-four .content b { color: #4fb9c4; }
#four-oh-four .content a i { margin-right: 8px; color: #4fb9c4; }

/* FAQ */

.faq-block { margin-top: 30px; border: 1px solid #89cac8; border-radius: 3px; }
.faq-block .faq-block-header { padding: 12px 20px; background-color: #e0eaec; }
.faq-block .faq-block-header h2 { margin: 0; }
.faq-block > ul.vert-list { margin: 0; }
.faq-block > ul.vert-list > li { margin-bottom: 0; padding: 12px 24px; border-top: 1px solid #89cac8; }
.faq-block > ul.vert-list > li:first-child { border-top: 0px none; }
.faq-block > ul.vert-list > li a.grey { display: block; padding-left: 20px; text-decoration: none; }
.faq-block > ul.vert-list > li::before { top: 20px; left: 20px; }
.faq-block > ul.vert-list > li .btn { display: inline-block; margin-top: 20px; margin-bottom: 20px; }
.faq-block > ul.vert-list > li ul, .faq-block > ul.vert-list > li ol { margin-bottom: 10px; }
.faq-block > ul.vert-list ul { list-style-type: disc; }
.faq-block > ul.vert-list ul ul, .faq-block > ul.vert-list ol ul { list-style-type: circle; margin-bottom: 0; }
.faq-block p.no-questions { padding: 12px 24px; margin: 0; font-style: italic; }

/* Planning */

#planning { display: flex; align-items: stretch; flex-wrap: wrap; justify-content: center; margin: 30px -15px 0 -15px; padding: 0 60px; }
#planning .planning-part { display: flex; z-index: 2; flex-basis: calc(18% - 30px); align-items: center; margin: 0 15px; position: relative; padding: 10px 10px 10px 24px; border: 2px solid #89cac8; border-radius: 3px; background-color: #fff; color: #89cac8; font-weight: 700; }
#planning .planning-part span { display: block; font-weight: 400; font-size: 14px; }
#planning .planning-part .planning-part-number { position: absolute; top: 50%; transform: translateY(-50%); left: -15px; width: 30px; height: 30px; padding-top: 1px; border-radius: 50%; border: 2px solid #fff; background-color: #89cac8; color: #fff; font-weight: 900; text-align: center; }
#planning .planning-part.active { border-color: #ec008d; }
#planning .planning-part.active .planning-part-number { background-color: #ec008d; }
#planning .planning-line { align-self: center; position: absolute; z-index: 1; height: 2px; width: 1140px; background-color: #ec008d; }

/* Forms */

form hr { margin-top: 10px; margin-bottom: 20px; }

.form-group { margin-bottom: 20px; }
.form-control { height: 42px; border-color: #89cac8; }

.form-label { display: block; font-weight: 700; color: #89cac8; }
label.checkbox-label { font-weight: 400; }

.pc-check { margin-top: 20px; margin-bottom: 50px; padding: 20px 30px; border: 2px solid #89cac8; border-radius: 3px; }
.pc-check h2 { margin-top: 0; font-weight: 700; }

textarea[name='comments'], textarea[name='message'], textarea[name='object_description'], textarea[name='object_extra_text'], textarea[name='additional_info'] { min-height: 140px; }

/* ISP's */

.isp-card { padding: 20px; margin: 30px 0 0 0; text-align: center; border: 2px solid #89cac8; border-radius: 3px; background-color: #fff; }
.isp-card img { max-width: 100%; }
.isp-card ul { text-align: left; }
.isp-card ul li { margin-bottom: 10px; }
.isp-card .tel, .isp-card .callback { color: #89cac8; }
.isp-card .tel { display: block; font-weight: 700; font-size: 18px; vertical-align: middle; }
.isp-card .tel i { margin-right: 4px; font-size: 22px; }
.isp-card .callback { font-weight: 500; }

/* Helper Classes */

.gutter-8.row { margin-right: -4px; margin-left: -4px; }
.gutter-8 > [class^="col-"], .gutter-8 > [class^=" col-"] { padding-right: 4px; padding-left: 4px; }

.gutter-10.row { margin-right: -5px; margin-left: -5px; }
.gutter-10 > [class^="col-"], .gutter-10 > [class^=" col-"] { padding-right: 5px; padding-left: 5px; }

.bg-cover { background-position: center center; background-repeat: no-repeat; background-size: cover; }
.bg-contain{ background-position: center center; background-repeat: no-repeat; background-size: contain; }

.margin-top-0 { margin-top: 0; }
.margin-top-10 { margin-top: 10px; }
.margin-top-20 { margin-top: 20px; }
.margin-top-30 { margin-top: 30px; }

.margin-bottom-0 { margin-bottom: 0; }
.margin-bottom-10 { margin-bottom: 10px; }
.margin-bottom-20 { margin-bottom: 20px; }
.margin-bottom-30 { margin-bottom: 30px; }

.padding-top-0 { padding-top: 0 !important; }

.padding-bottom-0 { padding-bottom: 0 !important; }

.white { color: #fff; }
.grey { color: #454d4a; }
.text-500 { font-weight: 500; }

.form_error { margin-bottom: 20px; color: #a94442; }
.invalid, .form-control.invalid { background-color: #ffe6e6; border-color: #a94442 !important; -webkit-box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); -moz-box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); }
.invalid.focus, .form-control.invalid.focus { background-color: #fff3f3; }
.checkbox.invalid-checkbox-radio, .radio.invalid-checkbox-radio { padding: 10px 15px; background-color: #ffe6e6; border: 1px solid #a94442 !important; border-radius: 2px; -webkit-box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); -moz-box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); }
.checkbox-inline.invalid-checkbox-radio, .radio-inline.invalid-checkbox-radio { background-color: #ffe6e6; border: 1px solid #a94442 !important; border-radius: 2px; -webkit-box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); -moz-box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); box-shadow: 0px 0px 10px 0px rgba(169,68,66,1); }
.checkbox, .radio { -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }

/* spinner */
.spinner { margin: 0 auto; width: 70px; height: 22px; text-align: center; }
.spinner > div { width: 14px; height: 14px; margin: 4px 2px; background-color: #fff; border-radius: 100%; display: inline-block; -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both; animation: sk-bouncedelay 1.4s infinite ease-in-out both; }
.btn-default .spinner > div { background-color: #333; }
.spinner .bounce1 { -webkit-animation-delay: -0.32s; animation-delay: -0.32s; }
.spinner .bounce2 { -webkit-animation-delay: -0.16s; animation-delay: -0.16s; }
@-webkit-keyframes sk-bouncedelay {
    0%, 80%, 100% { -webkit-transform: scale(0) }
    40% { -webkit-transform: scale(1.0) }
}
@keyframes sk-bouncedelay {
    0%, 80%, 100% {
        -webkit-transform: scale(0);
        transform: scale(0);
    } 40% {
        -webkit-transform: scale(1.0);
        transform: scale(1.0);
    }
}

/* Media Queries */

@media (max-width:1199px) {

    #navbar #navbar-top #navbar-top-inner ul#main-nav li a { padding: 25px 12px; font-size: 13px; }

    #home-postcode-check { padding: 20px; }
    #home-postcode-check .form-inline { margin-top: 15px; }

    #planning { padding: 0 30px; }

}

@media (max-width:991px) {

    h2.lg, h3.lg { font-size: 42px; margin-bottom: 15px; }

    .wrapper { padding-top: 130px; }
    .wrapper.wrapper-home { padding-top: 56px; }

    .flex-item-padded { padding-left: 0; padding-right: 0; }

    #navbar #navbar-top { height: 56px; }
    #navbar #navbar-top #navbar-top-inner { padding-left: 116px; }
    #navbar #navbar-top #navbar-top-inner #navbar-logo { width: 106px; }

    #navbar #navbar-top #navbar-top-inner ul#main-nav-social li a { padding: 15px 8px; }

    #navbar #navbar-top #navbar-top-inner #mobile-menu-btn { display: block; padding: 15px 5px 15px 25px; text-align: center; color: #fff; }

    #navbar #navbar-breadcrumb { height: 38px; }
    #navbar #navbar-breadcrumb #navbar-breadcrumb-inner { padding: 6px 0 0 120px; }
    #navbar #navbar-breadcrumb #navbar-breadcrumb-inner .material-icons { font-size: 20px; }

    #navbar #navbar-top #navbar-top-inner ul#main-nav-social { position: absolute; right: 60px; }
    #navbar #navbar-top #navbar-top-inner ul#main-nav-social li a { padding: 14px 10px; }
    #navbar #navbar-top #navbar-top-inner ul#main-nav-social li:first-child::after { height: 38px; }

    #home-header { height: 400px; }
    #home-header #home-header-inner h1 { font-size: 64px; font-weight: 900; }
    #home-header #home-header-inner h1 span { display: block; font-size: 36px; font-weight: 700; }

    #home-postcode-check { margin-bottom: 15px; padding: 20px;  }
    #home-postcode-check h2 { margin-bottom: 20px; }

    #planning { padding: 0; }
    #planning .planning-part { display: flex; z-index: 2; flex-basis: calc(50% - 30px); margin-bottom: 30px; }
    #planning .planning-line { display: none; }

    #map-section #map { width: 100%; }
    #map-section #map-overlay { right: 35px; }
    #map-section #map-overlay .content-top { padding-left: 70px; padding-right: 70px; }
    #map-section #map-overlay span.percentage { left: 0; top: 0; font-size: 34px; }
    #map-section #map-overlay #details { right: -30px; width: 120px; padding: 14px 8px; font-size: 12px;  }

    .faq-block { margin-top: 20px; }
    .faq-block .faq-block-header { padding: 12px 15px; }
    .faq-block .faq-block-header h2 { font-size: 18px; }
    .faq-block ul.vert-list li { padding: 8px 15px; }
    .faq-block ul.vert-list li a.grey { padding-left: 20px; font-size: 14px; }
    .faq-block ul.vert-list li::before { top: 15px; left: 15px; }

    footer ul.horizontal-list { clear: both; float: left; margin-top: 15px; }

    .block-pros ul li, .block-faq ul li, .block-poll label { font-size: 14px; }

    section.section-padding { padding-top: 15px; padding-bottom: 15px; }

    .flex-sm-1-1 { flex-basis: calc(100% - 30px); margin-bottom: 20px; }
    .flex-sm-1-2 { flex-basis: calc(50% - 30px); margin-bottom: 20px; }

    .spacer-xs-sm { clear: both; margin-top: 30px; width: 100%; }

}

@media (max-width:767px) {

    h1, h2, h3 { font-size: 24px; }
    h1.lg, h2.lg, h3.lg { font-size: 24px; margin-bottom: 10px; }

    .wrapper { padding-top: 100px; }
    .wrapper.wrapper-home { padding-top: 42px; }

    .flex-item-1-2, .flex-item-1-3, .flex-item-1-4 { flex-basis: calc(100% - 30px); margin-bottom: 20px; }
    .flex-xs-1-1 { flex-basis: calc(100% - 30px); margin-bottom: 20px; }

    section.section-padding { padding-top: 15px; padding-bottom: 15px; }

    #navbar #navbar-top { height: 42px; }
    #navbar #navbar-top #navbar-top-inner { padding-left: 88px; }
    #navbar #navbar-top #navbar-top-inner #navbar-logo {  width: 86px; }

    #navbar #navbar-top #navbar-top-inner #mobile-menu-btn { display: block; padding: 8px 5px 8px 25px; text-align: center; color: #fff; }

    #navbar #navbar-top #navbar-top-inner ul#main-nav-social { right: 40px; }
    #navbar #navbar-top #navbar-top-inner ul#main-nav-social li a { padding: 7px 8px; }
    #navbar #navbar-top #navbar-top-inner ul#main-nav-social li:first-child::after { right: 36px; height: 30px; }

    #navbar #navbar-breadcrumb { height: 34px; }
    #navbar #navbar-breadcrumb #navbar-breadcrumb-inner { padding: 5px 0 0 96px; }

    #home-postcode-check h2 { font-size: 24px; }
    #home-postcode-check .btn { display: block; width: 100%; }

    #home-header { height: 320px; }
    #home-header #home-header-inner h1 { font-size: 36px; font-weight: 900; }
    #home-header #home-header-inner h1 span { display: block; font-size: 18px; font-weight: 700; }

    .block-pros, .block-faq, .block-poll, .block-signup-check { padding: 20px; }
    .block-signup-check { position: relative; margin-top: 20px; }
    .block-signup-check:last-of-type { margin-bottom: 20px; }
    .block-signup-check .sign-up-check-edit { display: block; position: absolute; right: 20px; top: 15px; }

    #planning { position: relative; padding: 20px 0; }
    #planning .planning-part { display: flex; z-index: 2; flex-basis: calc(100% - 30px); margin-bottom: 30px; }
    #planning .planning-line { display: block; width: 2px; height: 100%; }

    #postcode-check { width: 300px; padding: 20px; border-radius: 0 0 0 4px; right: -300px; }
    #postcode-check h2 { font-size: 22px; }
    #postcode-check .form-inline { margin-top: 20px; }
    #postcode-check .form-control#address_zipcode { width: 255px; }
    #postcode-check .form-control#address_street_nr, #postcode-check .form-control#address_street_nr_addition, #postcode-check .form-control#address_room { float: left; width: 78px; margin-right: 10px; }
    #postcode-check .form-control#address_room { margin-right: 0; }
    #postcode-check .btn { width: 100%; margin-top: 15px; }

    #map-section { padding-right: 10px; }
    #map-section #map, #map-section #map-custom-802, .multiple-map { width: auto; }
    #map-section #map-overlay { left: -5px; top: 10px; right: 5px; }
    #map-section #map-overlay .content-top { padding-left: 55px; padding-right: 100px; font-size: 12px; }
    #map-section #map-overlay span.percentage { font-size: 26px; }
    #map-section #map-overlay span.percentage span.perc-sign { font-size: 22px; }
    #map-section #map-overlay #details { right: -10px; }
    #map-section #map-overlay #details #details-inner { font-size: 12px; }

    .poly-bg { padding-top: 30px !important; padding-bottom: 30px !important; margin-top: 15px; margin-bottom: 30px; }

    .isp { text-align: center; }
    .isp img { max-width: 220px; height: auto; }

    .isp-card { padding: 20px; margin: 0; }

    .faq-block { margin-top: 0; }

    .pc-check { margin-bottom: 30px; padding: 20px 20px 15px 20px; }

    #single-blog, #page, #faq, #form-wrapper, #form-check-wrapper { padding-bottom: 30px; }

    .pagination { width: 100%; }
    .pagination .page-numbers { display: none; }
    .pagination .page-numbers.current, .pagination .page-numbers.prev, .pagination .page-numbers.next { display: inline-block; }
    .pagination .page-numbers.prev { float: left; }
    .pagination .page-numbers.next { float: right; }


    footer ul.horizontal-list li { display: block; margin-top: 8px; }
    footer ul.horizontal-list li::before { width: 0; height: 0; margin: 0; }

}



body.admin-bar #navbar { top: 32px; }
body.admin-bar .modal-dialog { margin-top: 60px; }
@media (max-width: 782px) {
    #wpadminbar { position: fixed; }
    body.admin-bar #navbar { top: 46px; }
}
