/* reset */
html, body, button, div, span, object, iframe, h1, h2, h3, h4, h5, h6, hr, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, input, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, textarea, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
}
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary {
    display: block;
}
audio, canvas, video {
    display: inline-block;
}
input[type="text"], input[type="password"], input[type="email"], input[type="tel"], input[type="url"], input[type="submit"], textarea {
    -webkit-appearance: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
body {
    font-size: 62.5%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
}

/* typography */
body, button, input, select, textarea {
    font-family: arial, helvetica, sans-serif;
    color: #000;
}
a {
    color: #000;
    text-decoration: underline;
}
h1, h2, h3, h4, h5, h6 {
    font-weight: normal;
    line-height: 1.2em;
    word-wrap: break-word;
}
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
    text-decoration: none;
}
h1, .h1 {
    font-size: 2.4em;
    margin: 0 0 .2em 0;
}
h2, .h2 {
    font-size: 2em;
    margin: 0 0 .2em 0;
}
h3, .h3 {
    font-size: 1.6em;
    margin: 0 0 .2em 0;
}
p, ul, ol, pre, input, textarea, select {
    font-size: 1.3em;
    line-height: 1.5em;
    margin: 0 0 .7692307692em 0;
}
p {
    word-wrap: break-word;
}
ul, ol {
    margin: 0 0 .7692307692em 2em;
    word-wrap: break-word;
}
dl {
    font-size: 1.3em;
    line-height: 1.5em;
    word-wrap: break-word;
}
dd {
    margin: 0 0 .7692307692em 0;
}
small {
    font-size: 1.1em;
    line-height: 1.5em;
    word-wrap: break-word;
}
p small {
    font-size: .8461538462em;
}
hr {
    display: block;
    position: relative;
    margin: -7px;
    margin: 0 0 14px 0 !important;
    height: 1px;
    color: #000;
    background: #000;
}

/* forms */
label {
    font-size: 1.3em;
    line-height: 1.5em;
    margin: 0 0 .3em 0;
}
.text-container label,
.textarea-container label,
.selectbox-container label {
    display: block;
}
.checkbox-container label,
.radio-container label {
    padding: 0 0 0 .5em;
    cursor: pointer;
}
.checkbox-container input,
.radio-container input {
    cursor: pointer;
}
.checkbox-container p,
.radio-container p {
    margin: 0 0 .3em 0;
}
.text-container input,
.textarea-container textarea {
    width: 100%;
    padding: 4px 7px;
    border: 1px solid #000;
    margin: 0 0 1em 0;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
    border-radius: 0;
}
.selectbox-container select {
    width: 100%;
}
.error {
    color: #f00;
}
label .error {
    font-size: 1em;
}

/* buttons */
button {
    display: block;
    font-size: 1em;
    margin: 0 0 1em 0;
    padding: 0 40px;
    height: 35px;
    line-height: 35px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
}
input[type="submit"] {
    display: block;
    float: right;
    padding: 0 40px;
    height: 35px;
    line-height: 35px;
    text-align: center;
    cursor: pointer;
}

/* layout */
#wrapper {
    margin: 0 4.375%; /* 14/320*100% */
    width: 91.25%;
}
header {
    position: relative;
    width: 109.5890410958%;
    margin: 0 -4.7945205479%; /* subtract from wrapper margin 14/(320-14-14)*100% */
}
#identityWrapper {
    overflow: hidden;
    padding: 0 4.375%;
}
#identityContainer {
    position: relative;
}
#identityContainer.hasButtonmenu {
    min-height: 39px;
}
#logo {
    display: block;
    margin: 5px 0;
}
#identity {
    margin: 10px 0;
    min-height: 1.2em;
    line-height: 1.2em;
    font-size: 1.4em;
}
#identity.hasLogo {
    position: absolute;
    top: 50%; /* vertical center */
    margin: -.6em 4.375% 0 4.375%; /* if a logo is uploaded add extra margin - margin-top is half the height */
}
#menubutton {
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    margin: -14px 0 0 0;
    padding: 0 17px;
    height: 29px;
    line-height: 29px;
    font-size: 1.3em;
    text-decoration: none;
    -webkit-tap-highlight-color: rgba(0,0,0,0); /* hide border from android browsers when tapped */
}
.module {
    position: relative;
    margin: 0 0 14px 0;
    zoom: 1;
}
.module:after {
    display: block;
    content: '';
    clear: both;
    visibility: hidden;
    height: 0;
}
.clear:after {
    display: block;
    content: '';
    clear: both;
}
footer {
    margin: 0 0 14px 0;
    width: 100%;
}
footer ul {
    margin: 0;
    list-style: none;
}

/* main nav */
nav#main {
    position: relative;
    overflow: hidden;
    padding: 0 4.375%;
    margin: 0;
}
nav#main ul {
    margin: 0;
    list-style: none;
    width: 9999px;
}
nav#main li {
    float: left;
}
nav#main a {
    display: block;
    margin: 0 7px 0 -7px;
    padding: 0 7px;
    height: 35px;
    line-height: 35px;
}

/* hide main nav or main nav children from the backend */
nav.hidden, nav#main ul ul {
    display: none;
}

/* button nav level 1 */
nav#buttonmenu {
    display: none; /* tapping the menu button changes the buttonmenu to display block */
    position: absolute;
    top: 0; /* top will be set to the same height as #identityWrapper by js */
    left: 0;
    z-index: 100;
    width: 100%;
    margin: 0;
    padding: 14px 0 13px 0;
}
nav#buttonmenu ul {
    margin: 0 4.375%; /* 14/320*100% */
    list-style: none;
}
nav#buttonmenu a {
    float: left;
    display: block;
    margin: 0 0 1px 0;
    width: 100%;
    height: 39px;
    line-height: 39px;
    text-decoration: none;
}
nav#buttonmenu span.arrow {
    float: left;
    display: block;
    padding: 0;
    width: 13.356164384%; /* 39/292*100% */
    height: 39px;
    font-size: .7692307692em;
    text-align: center;
}

/* button nav level 2 */
nav#buttonmenu li ul {
    margin: 0;
}
nav#buttonmenu li ul a {
    width: 100;
    font-size: .7692307692em;
}
nav#buttonmenu li ul .arrow {
    padding: 0 0 0 8%;
}

/* button nav level 3 */
nav#buttonmenu li li ul a {
    font-size: .5917159763em;
}
nav#buttonmenu li li ul .arrow {
    padding: 0 0 0 16%;
}

/* top info bar */
.infobar-wrapper {
    padding: 14px 4.375% 4px 4.375%; /* 14/320*100% */
    width: 91.25%;
    background: #fff;
    -webkit-box-shadow: inset 0 -4px 4px -4px rgba(0,0,0,.5);
    -moz-box-shadow: inset 0 -4px 4px -4px rgba(0,0,0,.5);
    box-shadow: inset 0 -4px 4px -4px rgba(0,0,0,.5);
}
.infobar-wrapper p,
.infobar-wrapper a {
    color: #333;
    opacity: 1;
    filter: none;
}

/* module: vertical navigation */
nav.verticalnav {
    margin: 0 0 11px 0;
}
nav.verticalnav ul {
    list-style: none;
    margin: 0;
}
nav.verticalnav li {
    margin: 0 0 3px 0;
}
nav.verticalnav a {
    display: block;
    text-decoration: none;
    text-align: center;
    height: 35px;
    line-height: 35px;
}

/* module: headline */
.h1 {
    margin: 0 0 .3em 0;
}
.h1:empty {
    display: none;
}

/* module: sub headline */
.h2 {
    margin: 0 0 .3em 0;
}
.h2:empty {
    display: none;
}

/* module: bar */
.bar {
    overflow: hidden;
}
.bar .h2 {
    margin: 14px 0 13px 0;
    min-height: 17px;
}

/* module: preamble */
.preamble {
    margin: 0;
}
.preamble p {
    font-size: 1.5em;
    margin: 0 0 .6666666667em 0;
}
.preamble + .text,
.preamble + .preamble,
.preamble + .columns p:first-child {
    margin-top: -2px; /* if the module is followed my a text module remove the 3px extra margin in order to give us the wanted space of 14px */
}

/* module: text */
.text {
    margin: 0 0 2px 0; /* the 2px bottom margin is in addition to the paragraph bottom margin */
}
.text + .text,
.text + .preamble,
.text + .columns p:first-child {
    margin-top: -2px;
}

/* module: two columns */
.columns {
    margin: 0 0 2px 0;
}
.columns div {
    float: left;
    width: 47.602739726%; /* 139/(320-14-14)*100% */
}
.columns div.last {
    margin: 0 0 0 4.7945205479%; /* 14/(320-14-14)*100% */
}
.columns + .text,
.columns + .preamble,
.columns + .columns p:first-child {
    margin-top: -2px;
}

/* module: box */
.box {
    padding: 14px 14px 2px 14px;
}
.box .h2 {
    margin: 0 0 .2em 0;
}

/* module: image */
.image {
    display: block;
    width: 100%;
    height: auto;
}

/* module: wide image */
.imagewide {
    display: block;
    margin: 0 -4.7945205479% 0 -4.7945205479%;
    width: 109.5890410958%;
    height: auto;
}

/* module: image with text */
.imagetext img {
    float: left;
    margin: 0 4.7945205479% .3em 0; /* 139/(320-14-14)*100% */
    width: 47.602739726%; /* 139/(320-14-14)*100% */
    height: auto;
}
.imagetext .h2 {
    margin: 0 .2em;
}
.imagetext .readmore {
    margin: -.6em 0 0 0;
}

/* module: formbuilder
   module: contact form */
.formbuilder .h2 {
    margin: 0 0 .2em 0;
}
.spam-protection input {
    width: auto;
}
.captcha-image {
    display: block;
    margin: 0 0 14px 0;
}

/* module: call */
.call a {
    display: block;
    font-size: 1.3em;
    height: 31px;
    line-height: 31px;
    text-decoration: none;
    text-align: center;
}

/* module: divider */
.divider-full {
    margin: 0 -4.7945205479% 14px -4.7945205479% !important; /* subtract from wrapper margin 14/(320-14-14)*100% */
}
.divider-center, .divider-blank {
    width: 100%;
}
.divider-blank,
.divider-variable {
    margin: 0; /* make it transparent in IE6 and IE7 */
}
.divider-blank {
    height: 14px;
}

/* module: link list
   module: download list */
.linklist ul {
    list-style: none;
    margin: 0;
    border-top: 1px solid #000;
}
.linklist li {
    height: 35px;
    line-height: 35px;
    border-bottom: 1px solid #000;
    overflow: hidden;
}
.linklist a {
    display: block;
    text-decoration: none;
}
.linklist .formbuilder {
    position: absolute;
    width: 100%;
}

/* module: opening hours */
.hours .content {
    padding: 14px 14px 1px 14px;
}
.hours table {
    font-size: 1.3em;
    line-height: 1.5em;
    margin: 0 0 .7692307692em 0;
}
.hours td {
    padding-left: 2em;
}
.hours td:first-child {
    padding-left: 0;
}
.hours small {
    display: block;
    padding: .3545454545em 14px;
}

/* module: contact */
.contact dl {
    padding: 14px 14px 1px 14px;
}

/* module: google maps */
.map .h2 {
    margin: 0 0 .2em 0;
}
.map small {
    display: block;
    padding: .3545454545em 0;
}
.map iframe {
    overflow: hidden;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100% !important;
    height: 100% !important;
}
.map .content {
    position: relative;
    height: 0;
    padding: 0 0 56.25% 0;
}
.map .content > div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.map .content .gmnoprint {
    width: auto !important;
}
.map .content img {
    max-width: auto;
}

/* module: notify */
.notify .h2 {
    margin: 0 0 .2em 0;
}

/* module: comments */
.comments .h2 {
    margin: 0 0 .2em 0;
}
.comments ol {
    margin: 0;
    list-style: none;
    font-size: 1em;
}
.comments p.author {
    margin: 0;
}
.comments .spam-protection input{
    width: 100%;
}

/* module: rss feed */
.feeds img {
    max-width: 100%;
    height: auto;
}

/* module: image two column */
.imagetwocolumn {
    margin: 0 0 14px 0;
    overflow: hidden;
}
.imagetwocolumn img {
    float: left;
    margin: 0 4.7945205479% 0 0; /* 139/(320-14-14)*100% */
    width: 47.602739726%; /* 139/(320-14-14)*100% */
    height: auto;
}
.imagetwocolumn img.last {
    margin: 0;
}

/* module: image three column */
.imagethreecolumn {
    margin: 0 0 14px 0;
    overflow: hidden;
}
.imagethreecolumn img {
    float: left;
    margin: 0 4.7945205479% 0 0; /* 139/(320-14-14)*100% */
    width: 30.136986301%; /* 88/(320-14-14-14-14)*100% */
    height: auto;
}
.imagethreecolumn img.last {
    margin: 0;
}

/* module: gallery 1 */
.gallery ul {
    list-style: none;
    margin: 0;
    width: 100%;
}
.gallery li {
    float: left;
    width: 23.97260274%;
    margin: 0 1.3698630137% 1.3698630137% 0;
}
.gallery li:nth-child(4n) {
    margin: 0 0 1.3698630137% 0;
}
.gallery a {
    display: block;
    text-decoration: none;
}
.gallery .thumb {
    position: relative;
    height: 0;
    padding: 0 0 100% 0; /* padding-bottom is set to 100% to create perfectly fluid squares */
}
.gallery .img {
    position: absolute; /* absolutely positioning all corners stretches the element to the parent element - including the padding! */
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
}
.gallery img {
    width: 100%;
    height: 100%;
}
.mmgallery-overlay {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    z-index: 1000;
    left: 0;
    margin: 0;
    background: #000;
    -webkit-transition: visibility 0s linear 0.4s, opacity 0.4s linear; /* when we use visibily and opacity in conjunction we can get some sweet transitions */
    -moz-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    -o-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    -ms-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    transition: visibility 0s linear 0.4s, opacity 0.4s linear;
}
.mmgallery-overlay-active {
    visibility: visible;
    opacity: 1;
    -webkit-transition-delay: 0s;
    -moz-transition-delay: 0s;
    -o-transition-delay: 0s;
    -ms-transition-delay: 0s;
    transition-delay: 0s;
}
.mmgallery-overlay .table {
    display: table;
    text-align: center;
}
.mmgallery-overlay .cell {
    display: table-cell;
    vertical-align: middle;
}
.mmgallery-navigation ul {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 44px;
    background: #242424;
    background: linear-gradient(rgba(0,0,0,.6),rgba(40,40,40,.6));
    background: -o-linear-gradient(rgba(0,0,0,.6),rgba(40,40,40,.6));
    background: -moz-linear-gradient(rgba(0,0,0,.6),rgba(40,40,40,.6));
    background: -webkit-linear-gradient(rgba(0,0,0,.6),rgba(40,40,40,.6));
    background: -ms-linear-gradient(rgba(0,0,0,.6),rgba(40,40,40,.6));
    background: -webkit-gradient(
        linear,
        left bottom,
        left top,
        color-stop(0, rgba(0,0,0,.7)),
        color-stop(1, rgba(60,60,60,.7))
    );
    margin: 0;
    list-style: none;
    font-size: 2em;
    -webkit-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    -moz-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    -o-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    -ms-transition: visibility 0s linear 0.4s, opacity 0.4s linear;
    transition: visibility 0s linear 0.4s, opacity 0.4s linear;
}
.mmgallery-navigation ul.active {
    visibility: visible;
    opacity: 1;
    -webkit-transition-delay: 0s;
    -moz-transition-delay: 0s;
    -o-transition-delay: 0s;
    -ms-transition-delay: 0s;
    transition-delay: 0s;
}
.mmgallery-navigation li {
    float: left;
    width: 33.333333333%;
    height: 44px;
    text-align: center;
    line-height: 44px;
}
.mmgallery-navigation a {
    display: block;
    text-decoration: none;
    color: #fff;
}
.mmgallery-navigation a:active {
    /* display iOS-like highlight on tap */
    text-shadow: 0 0 20px rgba(255,255,255,1),
                 0 0 21px rgba(255,255,255,1),
                 0 0 22px rgba(255,255,255,1),
                 0 0 23px rgba(255,255,255,1),
                 0 0 24px rgba(255,255,255,1),
                 0 0 25px rgba(255,255,255,1),
                 0 0 27px rgba(255,255,255,1),
                 0 0 29px rgba(255,255,255,1),
                 0 0 32px rgba(255,255,255,1),
                 0 0 35px rgba(255,255,255,1),
                 0 0 40px rgba(255,255,255,1),
                 0 0 44px rgba(255,255,255,1),
                 0 0 45px rgba(255,255,255,1),
                 0 0 50px rgba(255,255,255,1);
}

/* module: gallery 3 */
.imageslider img {
    width: 100%;
    height: auto;
    margin: 0 0 7px 0; /* set margin on img instead of module div so there will be a margin between images on devices without JavaScript or touch support */
}
.imageslider .mmslider img {
    margin: 0;
}
#bodyEmu .imageslider img { /* hide from backend */
    display: none;
}
#bodyEmu .imageslider img:first-child {
    display: block;
}

/* module: product catalogue */
.product-catalog ul {
    font-size: 1em;
    display: table;
    list-style: none;
    margin: 0;
    width: 100%;
}
.product-catalog li {
    display: inline-block;
    _float: left;
    _display: block;
    vertical-align: top;
    width: 47.602739726%; /* 139/(320-14-14)*100% */
    margin: 0 0 1em 0;
}
.product-catalog li:nth-child(2n) {
    margin-left: 4.7945205479%; /* 14/(320-14-14)*100% */
}
.product-catalog a {
    display: block;
    text-decoration: none;
}
.product-catalog .thumb {
    position: relative;
    height: 0;
    padding: 0 0 100% 0; /* padding-bottom is set to 100% to create perfectly fluid squares */
}
.product-catalog .img {
    position: absolute; /* absolutely positioning all corners stretches the element to the parent elemet - including the padding! */
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    border: 1px solid #000;
}
.product-catalog .imgcontainer {
    display: table;
    width: 100%;
    height: 100%;
    text-align: center;
}
.product-catalog .imgcell {
    display: table-cell;
    vertical-align: middle;
}
.product-catalog img {
    max-width: 100%;
    max-height: 69%; /* the maximum height of the image */
}
.product-catalog .stamp {
    display: block;
    position: absolute;
    padding: .5em 0;
    width: 100%;
    left: 0;
    bottom: 0;
    font-size: 1.3em;
    text-align: center;
    opacity: .8;
    filter: alpha(opacity=80);
}
.product-catalog span {
    display: block;
}
.product-catalog span,
.product-catalog strong {
    font-size: 1.3em;
    line-height: 1.5em;
}

/* module: product catalogue with buy button */
.product-catalog button {
    padding: 0;
    margin: .3em 0 0 0;
    width: 100%;
}

/* module: single product */
.product .images {
    overflow: hidden;
    margin: 0 0 1.3em 0;
}
.product .thumb {
    position: relative;
    height: 0;
    padding: 0 0 100% 0; /* padding-bottom is set to 100% to create perfectly fluid squares */
    margin: 0 0 7px 0;
}
.product .img {
    position: absolute; /* absolutely positioning all corners stretches the element to the parent elemet - including the padding! */
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    border: 1px solid #000;
}
.product .imgcontainer {
    display: table;
    width: 100%;
    height: 100%;
    text-align: center;
}
.product .imgcell {
    display: table-cell;
    vertical-align: middle;
}
.product img {
    max-width: 100%;
    max-height: 69%; /* the maximum height of the image */
}
.product .stamp {
    display: block;
    position: absolute;
    padding: .5em 0;
    width: 100%;
    left: 0;
    bottom: 0;
    font-size: 1.6em;
    text-align: center;
    opacity: .8;
    filter: alpha(opacity=80);
}
.product .price {
    font-size: 1.8em;
    text-align: right;
}
.product .price strike {
    margin-right: .5em;
}
.product .variants {
    text-align: left;
}
.product select {
    width: 100%;
}
.product p:last-child {
    margin-bottom: 0;
}

/* module: add-to-cart button */
.product-button input[type="submit"] {
    margin-bottom: 0;
}

/* slider styles */
.page-indication {
    float: right; /* float: right; and left: -50%; on the container and left: 50%; on the inner element centers the element even if no width is set */
    position: relative;
    top: 0;
    left: -50%;
}
.page-indication ul {
    position: relative;
    top: 0;
    left: 50%;
    margin: 0;
    list-style: none;
}
.page-indication li {
    float: left;
    background: #999;
    padding: 0;
    margin: 7px 5px 0 5px !important;
    width: 6px;
    height: 6px;
    text-indent: -9999px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}
.page-indication li.active {
    background: #d0d0d0;
}

/* backend width calculator */
#bodyEmu .imageColumnWidth,
#bodyEmu .imageColumnWidthFull {
    display: block;
    position: absolute;
    top: -9999px;
    left: -9999px;
    height: 1px;
}
#bodyEmu .imageColumnWidth {
    width: 292px;
}
#bodyEmu .imageColumnWidthFull {
    width: 320px;
}

/* backend accordion - this class is added when the Show expanded option is checked */
#bodyEmu .accordion .panel {
    display: none;
}

/* helpers */
.alignleft {
    text-align: left;
}
.aligncenter {
    text-align: center;
}
.alignright {
    text-align: right;
}

/* mono branding top */
.mono-branding-top {
    overflow: hidden;
    position: fixed;
    z-index: 1;
    top: 100px;
    right: 0;
    width: 45px;
    max-height: 45px;
    background: #000;
    background: rgba(0,0,0,.7);
    -webkit-border-radius: 5px 0 0 5px;
    -moz-border-radius: 5px 0 0 5px;
    border-radius: 5px 0 0 5px;
    -webkit-transition: all .2s ease-out;
    -moz-transition: all .2s ease-out;
    -o-transition: all .2s ease-out;
    -ms-transition: all .2s ease-out;
    transition: all .2s ease-out;
}
.mono-branding-top-active {
    width: 180px;
    max-height: 100%;
}
.mono-branding-top .mono-branding-logo {
    display: block;
    width: 180px;
    height: 45px;
    background: url(img/mono-branding.png) no-repeat 13px 11px;
    text-indent: -9999px;
}
.mono-branding-top .mono-branding-expand {
    width: 133px;
    padding: 10px 0 26px 47px;
}
.mono-branding-top p {
    font-family: arial, helvetica, sans-serif;
    margin: 0;
    padding: 0 13px 20px 0;
    color: #fff;
    opacity: 1;
    filter: none;
    background: transparent;
    font-size: 15px;
    line-height: 1.6;
    text-align: left;
    -webkit-font-smoothing: antialiased;
}
.mono-branding-top .mono-branding-button {
    font-family: arial, helvetica, sans-serif;
    display: block;
    padding: 0 75px 0 0;
    height: 29px;
    line-height: 29px;
    background: #fff url(img/mono-branding.png) no-repeat 65px -42px;
    font-size: 15px;
    text-align: right;
    color: #000;
    -webkit-border-radius: 5px 0 0 5px;
    -moz-border-radius: 5px 0 0 5px;
    border-radius: 5px 0 0 5px;
    -webkit-font-smoothing: antialiased;
}
.mono-branding-top a {
    text-decoration: none;
    border: 0;
}

/* mono branding footer */
.mono-branding-footer {
    padding: 0 4.375%; /* 14/320*100% */
    background: #000;
    background: rgba(0,0,0,.7);
}
.mono-branding-footer .mono-branding-logo {
    display: block;
    width: 100%;
    height: 48px;
    background: url(img/mono-branding.png) no-repeat 0 12px;
    text-indent: -9999px;
}

.mono-branding-footer p,
.mono-branding-footer .mono-branding-button {
    font-family: arial, helvetica, sans-serif;
    height: 48px;
    line-height: 48px;
    margin: 0;
    color: #fff;
    opacity: 1;
    filter: none;
    background: transparent;
}

@media screen and (orientation: landscape) {

    /* layout */
    .infobar-wrapper {
        padding: 14px 2.9166666667% 4px 2.9166666667%; /* 14/480*100% */
        width: 94.1666666666%;
    }
    #wrapper {
        margin: 0 2.9166666667%; /* 14/480*100% */
        width: 94.1666666666%;
    }
    header {
        width: 106.1946902654%;
        margin: 0 -3.0973451327%; /* subtract from wrapper margin 14/(480-14-14)*100% */
    }
    #identityWrapper {
        padding: 0 2.9166666667%; /* 14/480*100% */
    }
    #identity.hasLogo {
        margin: -.6em 2.9166666667% 0 2.9166666667%;
    }

    /* main nav */
    nav#main {
        padding: 0 2.9166666667%;
    }

    /* button nav level 1 */
    nav#buttonmenu ul {
        margin: 0 2.9166666667%; /* 14/480*100% */
    }

    /* module: two columns */
    .columns div {
        width: 48.451327434%;
    }
    .columns div.last {
        margin: 0 0 0 3.0973451327%; /* 14/(480-14-14)*100% */
    }

    /* module: wide image */
    .imagewide {
        margin: 0 -3.0973451327% 0 -3.0973451327%;
        width: 106.1946902654%;
    }

    /* module: image with text */
    .imagetext img {
        margin: 0 3.0973451327% .3em 0;
        width: 48.451327434%;
    }

    /* module: divider */
    .divider-full {
        margin: 0 -3.0973451327% 14px -3.0973451327%; /* subtract from wrapper margin 14/(480-14-14)*100% */
        width: 106.1946902654%;
    }

    /* module: image two column */
    .imagetwocolumn img {
        margin: 0 3.0973451327% 0 0;
        width: 48.451327434%;
    }
    .imagetwocolumn img.last {
        margin: 0;
    }

    /* module: image three column */
    .imagethreecolumn img {
        margin: 0 3.0973451327% 0 0;
        width: 31.268436578%;
    }
    .imagethreecolumn img.last {
        margin: 0;
    }

    /* module: gallery */
    .gallery li {
        width: 15.92920354%;
        margin: 0 .8849557522% .8849557522% 0;
    }
    .gallery li:nth-child(4n) {
        margin: 0 .8849557522% .8849557522% 0;
    }
    .gallery li:nth-child(6n) {
        margin: 0 0 .8849557522% 0;
    }

    .mono-branding-footer {
        padding: 0 2.9166666667%;
    }

}


/* Replace D4 modules with placeholders */
.contact-combined,
.testimonial,
.headerLP,
.spotcall,
.external-product,
.external-product-list,
.usp,
.display,
.text-threecolumns,
.text-fourcolumns,
.carousel,
.gallery-4,
.external,
.jumbotron,
.full-width-container {
    position: relative;
    overflow: hidden;
    height: 0;
    padding-bottom: 41.84100418%; /* Ratio 2.39:1 */
    z-index: 1;
}
.contact-combined:before,
.testimonial:before,
.headerLP:before,
.spotcall:before,
.external-product:before,
.external-product-list:before,
.usp:before,
.display:before,
.text-threecolumns:before,
.text-fourcolumns:before,
.carousel:before,
.gallery-4,
.external:before,
.jumbotron:before,
.full-width-container:before {
    display: block;
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: '';
    border: 1px solid #dadada;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
    background: #e6e6e6 url(img/placeholder.png) no-repeat center center;
    -webkit-background-size: auto 50%;
    -moz-background-size: auto 50%;
    background-size: auto 50%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.formbuilder button {
    display: none;
}
