/* custom css */

.nicescroll-rails {
    z-index: 100 !important;
}
@-webkit-keyframes scrollformore {
    0% { background-position: 0 0; }
    100% { background-position: -680px 0; }
}

@-moz-keyframes scrollformore {
    0% { background-position: 0 0; }
    100% { background-position: -680px 0; }
}

@-ms-keyframes scrollformore {
    0% { background-position: 0 0; }
    100% { background-position: -680px 0; }
}

@-o-keyframes scrollformore {
    0% { background-position: 0 0; }
    100% { background-position: -680px 0; }
}

@keyframes scrollformore {
    0% { background-position: 0 0; }
    100% { background-position: -680px 0; }
}

@-webkit-keyframes send {
    0% { background-position: 0 0; }
    100% { background-position: -208px 0; }
}


@-moz-keyframes send {
    0% { background-position: 0 0; }
    100% { background-position: -208px 0; }
}


@-ms-keyframes send {
    0% { background-position: 0 0; }
    100% { background-position: -208px 0; }
}


@-o-keyframes send {
    0% { background-position: 0 0; }
    100% { background-position: -208px 0; }
}

@keyframes send {
    0% { background-position: 0 0; }
    100% { background-position: -208px 0; }
}

@-webkit-keyframes play {
    0% { background-position: 0 0; }
    100% { background-position: -1820px 0; }
}

@-moz-keyframes play {
    0% { background-position: 0 0; }
    100% { background-position: -1820px 0; }
}

@-ms-keyframes play {
    0% { background-position: 0 0; }
    100% { background-position: -1820px 0; }
}

@-o-keyframes play {
    0% { background-position: 0 0; }
    100% { background-position: -1820px 0; }
}

@keyframes play {
    0% { background-position: 0 0; }
    100% { background-position: -1820px 0; }
}

@-webkit-keyframes farmers {
    0% { background-position: 0 0; }
    100% { background-position: -1360px 0; }
}

@-moz-keyframes farmers {
    0% { background-position: 0 0; }
    100% { background-position: -1360px 0; }
}

@-ms-keyframes farmers {
    0% { background-position: 0 0; }
    100% { background-position: -1360px 0; }
}

@-o-keyframes farmers {
    0% { background-position: 0 0; }
    100% { background-position: -1360px 0; }
}

@keyframes farmers {
    0% { background-position: 0 0; }
    100% { background-position: -1360px 0; }
}

@-webkit-keyframes readmore {
    0% { background-position: 0 0; }
    100% { background-position: 0 -220px; }
}

@-moz-keyframes readmore {
    0% { background-position: 0 0; }
    100% { background-position: 0 -220px; }
}

@-ms-keyframes readmore {
    0% { background-position: 0 0; }
    100% { background-position: 0 -220px; }
}

@-o-keyframes readmore {
    0% { background-position: 0 0; }
    100% { background-position: 0 -220px; }
}

@keyframes readmore {
    0% { background-position: 0 0; }
    100% { background-position: 0 -220px; }
}

@-webkit-keyframes picker {
    0% { background-position: 0 0; }
    100% { background-position: -664px 0; }
}

@-moz-keyframes picker {
    0% { background-position: 0 0; }
    100% { background-position: -664px 0; }
}

@-ms-keyframes picker {
    0% { background-position: 0 0; }
    100% { background-position: -664px 0; }
}

@-o-keyframes picker {
    0% { background-position: 0 0; }
    100% { background-position: -664px 0; }
}

@keyframes picker {
    0% { background-position: 0 0; }
    100% { background-position: -664px 0; }
}
.bg-orange {
    background: #dc9c51; 
}
.bg-orange a {
    color: rgba(255, 255, 255, 0.8); 
}
.bg-orange p, 
.bg-orange a:hover {
    color: #FFF; 
}
.bg-blue {
    background: #74b9da; 
}
.bg-blue a {
    color: rgba(255, 255, 255, 0.8); 
}
.bg-blue p, 
.bg-blue a:hover {
    color: #FFF; 
}
.bg-beige {
    background: #c1ae92; 
}
.bg-beige a {
    color: #dc9c51; 
}
.bg-beige p, 
.bg-beige a:hover {
    color: #2c2c2b; 
}
.bg-lightbeige {
    background: #ddcbb5; 
}
.bg-lightbeige a {
    color: #dc9c51; 
}
.bg-lightbeige p, 
.bg-lightbeige a:hover {
    color: #2c2c2b; 
}
.bg-darkbeige {
    background: #ae9c8b; 
}
.bg-darkbeige a {
    color: rgba(255, 255, 255, 0.8); 
}
.bg-darkbeige p, 
.bg-darkbeige a:hover {
    color: #FFF; 
}
.bg-teal {
    background: #788890; 
}
.bg-teal a {
    color: rgba(255, 255, 255, 0.8); 
}
.bg-teal p, 
.bg-teal a:hover {
    color: #FFF; 
}
.bg-green {
    background: #669345; 
}
.bg-green a {
    color: rgba(255, 255, 255, 0.8); 
}
.bg-green p, 
.bg-green a:hover {
    color: #FFF; 
}
.bg-lightgrey {
    background: #c5c6c6; 
}
.bg-lightgrey a {
    color: #575656; 
}
.bg-lightgrey p, 
.bg-lightgrey a:hover {
    color: #2c2c2b; 
}

.bg-mediumgrey {
    background: #9c9d9d; 
}
.bg-mediumgrey a {
    color: #c5c6c6; 
}
.bg-mediumgrey p, 
.bg-mediumgrey a:hover {
    color: #FFF; 
}

.bg-darkgrey {
    background: #575656; 
}
.bg-darkgrey a {
    color: #c5c6c6; 
}
.bg-darkgrey p, 
.bg-darkgrey a:hover {
    color: #FFF; 
}
.bg-browngrey {
    background: #504840; 
}
.bg-browngrey a {
    color: #c5c6c6; 
}
.bg-browngrey p, 
.bg-browngrey a:hover {
    color: #FFF; 
}

.bg-logoblack {
  background: #2c2c2b; 
}
  .bg-logoblack a {
    color: #c5c6c6; 
}
  .bg-logoblack p, 
  .bg-logoblack a:hover {
    color: #FFF; 
}
.bg-lightwarmgrey {
  background: #87807f; 
}
  .bg-lightwarmgrey a {
    color: #c5c6c6; 
}
  .bg-lightwarmgrey p, 
  .bg-lightwarmgrey a:hover {
    color: #FFF; 
}
.bg-darkwarmgrey {
    background: #424441; 
}
.bg-darkwarmgrey a {
    color: #c5c6c6; 
}
.bg-darkwarmgrey p, 
.bg-darkwarmgrey a:hover {
    color: #FFF; 
}
.bg-body {
    background: #3c3c3e; 
}
.bg-body a {
    color: #FFF; 
}
.bg-body a:hover {
    color: rgba(255, 255, 255, 0.8); 
}
.bg-black {
    background: #000; 
}
.bg-white {
    background: #FFF; 
}
.orange {
    color: #dc9c51; 
}
.blue {
  color: #74b9da; 
}
.beige {
  color: #c1ae92; 
}
.lightbeige {
  color: #ddcbb5; 
}
.darkbeige {
  color: #ae9c8b; 
}
.teal {
  color: #788890; 
}
.green {
  color: #669345; 
}
.lightgrey {
  color: #c5c6c6; 
}
.mediumgrey {
  color: #9c9d9d; 
}
.darkgrey {
  color: #575656; 
}
.browngrey {
  color: #504840; 
}
.logoblack {
  color: #2c2c2b; 
}
.lightwarmgrey {
  color: #87807f; 
}
.darkwarmgrey {
  color: #424441; 
}
.white {
  color: #FFF !important; 
}
.black {
  color: #000 !important; 
}
.search-box input[type=text], 
input[type=email], 
input[type=password], 
input[type=search], 
input[type=text], 
select, 
textarea {
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
    border: 0;
    color: #9c9d9d;
    display: inline-block;
    font-size: 1.8em;
    height: auto;
    max-width: 70%;
    padding: 5px 20px;
}
input[type=email]:active, 
input[type=email]:focus, 
input[type=password]:active, 
input[type=password]:focus, 
input[type=search]:active, 
input[type=search]:focus, 
input[type=text]:active, 
input[type=text]:focus, 
select:active, 
select:focus, 
textarea:active, 
textarea:focus {
    box-shadow: none;
}
.formset .fieldset:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}
body {
    -webkit-tap-highlight-color: transparent;
}
::selection {
    background: #74b9da;
    color: #FFF;
}
::-moz-selection {
    background: #74b9da;
    color: #FFF;
}
img::selection {
    background: 0 0;
}
img::-moz-selection {
    background: 0 0;
}
* {
    vertical-align: top;
}
html {
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    overflow-y: scroll;
}
.leaflet-popup-content, body {
    font-family: 'Aller Typo W01 Regular', Arial, Helvetica, sans-serif;
    font-style: normal;
    font-weight: 400;
}
.leaflet-control-attribution {
    display: none;
}
h1, h2, h3, h4, h5, h6 {
    font-family: 'Aller Typo W01 Bold', Arial, Helvetica, sans-serif;
    font-style: normal;
    font-weight: 400;
}
.formset .fieldset label, 
.mobile-menu nav ul, 
.scribble, 
.search-box input[type=text], 
input[type=email], 
input[type=password], 
input[type=search], 
input[type=text], 
nav.main, 
select, 
textarea {
    font-family: 'Amatic SC', cursive;
    font-weight: 700;
}
footer a.back-to-top, 
nav.secondary {
    font-family: ucu_charles_scriptregular;
    font-style: normal;
    font-weight: 400;
}
nav.secondary ul.countries li:first-child {
    border-top: 1px dashed #666;
    margin-top: 10px;
    padding-top: 10px;
}
.formset .fieldset .submit, 
.shout, 
.team h2, 
.team h3 {
    font-family: onedirectionmedium;
    font-style: normal;
    font-weight: 400;
}
h1, h2, h3, h4, h5, h6 {
    color: #504840;
    line-height: 1;
}
h1, h2.h1 {
    font-size: 1.5em;
}
h1.shout, h2.h1.shout {
    font-size: 2em;
}
h2 {
    font-size: 1.8em;
}
h2 span {
    vertical-align: middle;
}
p {
    margin-bottom: 1em;
}
ol.nostyle, 
ul.nostyle {
    list-style: none;
    margin-left: 0;
}
.inline-block {
    display: inline-block;
}
.small {
    font-size: .9em;
}
.tiny {
    font-size: .8em;
}
button, 
button:active, 
button:focus, 
button:hover {
    border: 0!important;
    box-shadow: none!important;
    transition: none;
}
[class*=" icon-"]:after, 
[class*=" icon-"]:before, 
[class^=icon-]:after, 
[class^=icon-]:before {
    font-family: fontello;
    font-style: normal;
    font-weight: 400;
    speak: none;
    display: inline-block;
    text-decoration: inherit;
    width: 1em;
    margin-right: .2em;
    text-align: center;
    font-variant: normal;
    text-transform: none;
    line-height: 1em;
    margin-left: .2em;
}
.icon-menu:before {
    content: '\e800';
}
body {
    background: #3c3c3e;
    color: #FFF;
}
.nobr {
    white-space: nowrap;
}
.message-bar h2 {
    margin: 0;
    padding: 20px 0;
    text-align: center;
}
@media only screen and (min-width:768px) {
    .row {
        max-width: 768px;
    }
}
@media only screen and (min-width:992px) {
    .row {
        max-width: 960px;
    }
}
@media only screen and (min-width:1224px) {
    .row {
        max-width: 1196px;
    }
}
.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}
.align-left {
    text-align: left;
}
.align-right {
    text-align: right;
}
.align-center {
    text-align: center;
}
@media only screen and (max-width:767px) {
    .m-reset.left, .m-reset.right {
        float: none!important;
    }
    .m-reset.align-center, .m-reset.align-right {
        text-align: left;
    }
}
.content {
    font-size: 1.1em;
    height: 100%;
    padding: 20px;
}
.content div {
    display: inline-block;
    vertical-align: middle;
}
.content div.divhelper {
    height: 100%;
}
section.main-section {
    background: #c5c6c6 url(../images/paper.jpg);
    color: #504840;
    overflow: hidden;
    position: relative;
    z-index: 3;
}
.screen-reader-text {
    left: -9000px;
    position: absolute;
}
a {
    color: red;
    text-decoration: none;
}
a:active, a:focus, a:hover {
    color: #000;
    outline: 0;
}
.button {
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    -ms-border-radius: 30px;
    -o-border-radius: 30px;
    border-radius: 30px;
    background: #333;
    border: 0;
    box-shadow: none;
    color: #FFF;
    padding: 15px 65px;
}
.button:active, 
.button:focus, 
.button:hover {
    background: #666;
    box-shadow: none;
}
img {
    max-width: 100%;
}
img.full {
    height: auto!important;
    width: 100%;
}
.relative {
    position: relative;
}
.pbs {
    padding-bottom: 20px;
}
.pbl {
    padding-bottom: 40px;
}
.pts {
    padding-top: 20px;
}
.ptl {
    padding-top: 40px;
}
.pls {
    padding-left: 20px;
}
.pll {
    padding-left: 40px;
}
.prs {
    padding-right: 20px;
}
.prl {
    padding-right: 40px;
}
.mbs {
    margin-bottom: 20px;
}
.mbl {
    margin-bottom: 40px;
}
.mts {
    margin-top: 20px;
}
.mtl {
    margin-top: 40px;
}
.mls {
    margin-left: 20px;
}
.mll {
    margin-left: 40px;
}
.mrs {
    margin-right: 20px;
}
.mrl {
    margin-right: 40px;
}
nav ol, nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.desktop {
    display: none;
}
header {
    min-height: 107px;
}
@media only screen and (min-width:480px) {
    header {
        min-height: 115px;
    }
}
header li.find {
    background: #74b9da;
}
header li.beverages {
    background: #c1ae92;
}
header li.fairtrade {
    background: #788890;
}
header li.fairshare {
    background: #669345;
}
header li.about {
    background: #575656;
}
header li.contact {
    background: #74b9da;
}
header li.franchises {
    background: #2c2c2b;
}
header h1 {
    background: url(../images/mobile-logo.svg) no-repeat 0 0;
    background-size: 100% auto;
    display: inline-block;
    height: 89px;
    margin: 0;
    overflow: hidden;
    position: absolute;
    right: 15px;
    top: 15px;
    text-indent: -9999em;
    width: 240px;
}
header h1 a {
    display: block;
    height: 89px;
    width: 230px;
}
@media only screen and (min-width:480px) {
    header h1, header h1 a {
        width: 278px;
    }
}
header h2 {
    margin: 0;
    overflow: hidden;
    text-indent: -9999em;
}
.mobile-menu {
    position: relative;
}
.mobile-menu a.icon-menu {
    color: #c5c6c6;
    font-size: 40px;
    left: 20px;
    position: absolute;
    top: 15px;
}
.mobile-menu a.icon-menu span {
    display: block;
    font-size: 13px;
}
.mobile-menu a.icon-menu:hover {
    color: #FFF;
}
.mobile-menu a.icon-menu:after, .mobile-menu a.icon-menu:before {
    margin: 0;
    width: auto;
}
@media only screen and (min-width:480px) {
    #map {
        height: 400px;
    }
    .mobile-menu a.icon-menu {
        font-size: 60px;
        top: 10px;
    }
    .mobile-menu a.icon-menu span {
        font-size: 20px;
    }
    .mobile-menu nav {
        top: 115px;
    }
}
.mobile-menu nav {
    display: none;
    left: 0;
    position: absolute;
    top: 107px;
    width: 100%;
    z-index: 4;
}
.mobile-menu nav ul li {
    background: #2c2c2b;
    border-top: 1px solid rgba(255, 255, 255, .3);
    border-bottom: 1px solid #000;
}
.mobile-menu nav ul li:hover {
    background: #333;
}
.mobile-menu nav ul li a {
    color: #FFF;
    display: block;
    font-size: 2em;
    padding: 10px 20px;
    text-align: center;
}
nav.main {
    display: none;
}
nav.main li a i {
    background: url(../images/nav-swish.svg) no-repeat 0 0;
    background-size: 100% auto;
    display: none;
    height: 10px;
    margin: -10px auto 0;
    max-width: 95px;
    width: 80%;
}
nav.main li a:hover i {
    display: block;
}
nav.main li.home a:hover i {
    display: none;
}
.about-page nav.main li.about a i, 
.contact-page nav.main li.contact a i, 
.fairshare-page nav.main li.fairshare a i, 
.fairtrade-page nav.main li.fairtrade a i, 
.find-page nav.main li.find a i, 
.franchises-page nav.main li.franchises a i, 
.our-beverages-page nav.main li.beverages a i {
    display: block;
}
nav.secondary {
    display: none;
}
.feature-banner {
    padding: 20px 0;
}
.feature-banner h2 {
    font-size: 1.5em;
    margin: 5px 0;
    text-align: center;
}
.feature-banner h2 a {
    color: #FFF;
}
.feature-banner h2 a:hover {
    color: rgba(255, 255, 255, .7);
}
.feature-banner.billboard h2 {
    font-size: 2.5em;
}
.feature-banner.billboard .shout {
    padding-top: 10px;
}
.feature-banner.house-blends h2 {
    background: url(../images/house-blends-swish.png) no-repeat bottom center;
    color: #ae9c8b;
    display: inline-block;
    font-size: 3em;
    margin: 0 30px;
    padding: 0 60px 10px;
    position: relative;
}
.feature-banner.house-blends h2:after {
    background: url(../images/arrow-down-right.svg) no-repeat 0 0;
    background-size: 100% auto;
    content: ".";
    display: block;
    height: 123px;
    overflow: hidden;
    position: absolute;
    right: 0;
    text-indent: -9999em;
    top: 50%;
    width: 60px;
    z-index: 3;
}
.feature-banner.alternative-blends {
    position: relative;
}
.feature-banner.alternative-blends h2 {
    color: #9c9d9d;
    display: inline-block;
    font-size: 3em;
    margin: 0;
    padding: 0 60px;
    position: relative;
}
.feature-banner.alternative-blends h2:before {
    background: url(../images/arrow-down-left.svg) no-repeat 0 0;
    background-size: 100% auto;
    content: ".";
    display: block;
    height: 123px;
    overflow: hidden;
    position: absolute;
    left: 0;
    z-index: 3;
    text-indent: -9999em;
    top: 50%;
    width: 60px;
}
@media only screen and (max-width:992px) {
    .feature-banner.alternative-blends h2: before {
        margin-left: 20px;
    }
}
.feature-banner.food-menu {
    position: relative;
}
.feature-banner.food-menu h2 {
    font-size: 3em;
    margin: 0;
}
.content-layer {
    color: #FFF;
    height: 100%;
    padding: 40px;
    position: absolute;
    text-align: center;
    top: 0;
    vertical-align: middle;
    z-index: 2;
    width: 100%;
}
.content-layer div.content-info {
    display: inline-block;
    position: relative;
    vertical-align: middle;
    width: 100%;
}
.content-layer div.content-info img {
    margin-bottom: 10px;
    max-width: 500px;
}
.content-layer div.content-info p {
    font-size: .9em;
    line-height: 1.1;
}
.content-layer .divhelper {
    display: inline-block;
    height: 100%;
    vertical-align: middle;
}
.hero {
    height: 100%;
    position: relative;
}
.hero .content-layer {
    padding: 0;
}
.hero .content-layer div.content-info img {
    margin-bottom: 0;
    max-width: 70%;
}
.hero .feature-banner {
    position: relative;
    z-index: 2;
}
a.next {
    position: relative;
}
a.next:after {
    background: url(../images/arrow-right.svg) no-repeat 0 0;
    background-size: 100% auto;
    content: ".";
    display: inline-block;
    height: 30px;
    margin-left: 10px;
    overflow: hidden;
    text-indent: -999em;
    vertical-align: middle;
    width: 30px;
    z-index: 3;
}
a.next:hover:after {
    opacity: .7;
}
a.prev {
    position: relative;
}
a.prev:before {
    background: url(../images/arrow-right.svg) no-repeat 0 0;
    background-size: 100% auto;
    content: ".";
    display: inline-block;
    height: 30px;
    margin-right: 10px;
    overflow: hidden;
    text-indent: 999em;
    vertical-align: middle;
    width: 30px;
    z-index: 3;
}
a.prev:hover:before {
    opacity: .7;
}
.bg-darkwarmgrey a.prev:before {
    background: url(../images/arrow-right-beige.svg) no-repeat 0 0;
    background-size: 100% auto;
}
.bg-darkwarmgrey a.prev:hover:before {
    background: url(../images/arrow-right.svg) no-repeat 0 0;
    background-size: 100% auto;
    opacity: 1;
}
.photo-cover {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    height: 100%;
    width: 100%;
}
footer {
    color: #9c9d9d;
    padding: 60px 0 20px;
    text-align: center;
}
footer a {
    color: #9c9d9d;
}
footer a:active, 
footer a:focus, 
footer a:hover {
    color: #FFF;
}
footer a.back-to-top {
    display: inline-block;
    font-size: 35px;
    padding: 0 60px 60px;
    position: relative;
}
footer a.back-to-top:after {
    background: url(../images/arrow-up-right.svg) no-repeat 0 0;
    background-size: 100% auto;
    content: ".";
    display: block;
    height: 50px;
    overflow: hidden;
    position: absolute;
    right: 0;
    text-indent: -9999em;
    top: -25px;
    width: 45px;
}
footer a.back-to-top:hover:after {
    background: url(../images/arrow-up-right-over.svg) no-repeat 0 0;
    background-size: 100% auto;
}
footer nav {
    padding-bottom: 20px;
}
footer nav li {
    display: inline-block;
}
footer nav li a {
    display: block;
    padding: 5px 10px;
    text-transform: lowercase;
}
.team {
    color: #FFF;
}
.team .half .half {
    float: left;
    width: 50%;
}
.team h2, .team h3 {
    color: #FFF;
}
.team h2 {
    font-size: 3em;
}
.team h3 {
    font-size: 2em;
}
.team h3, .team p.small {
    color: #FFF;
}
.search-box input[type=text] {
    margin: 20px;
    width: 250px;
}
.search-box input[type=submit] {
    background: url(../images/submit.svg) no-repeat;
    background-size: 100% auto;
    border: 0;
    cursor: pointer;
    display: inline-block;
    font-size: 0;
    height: 72px;
    line-height: 0;
    margin: 10px 0 0;
    overflow: hidden;
    text-indent: -9999em;
    top: 0;
    width: 72px;
}
.icon-location:before {
    background: url(../images/location-icon.svg) no-repeat;
    background-size: 100% auto;
    content: ".";
    display: inline-block;
    height: 61px;
    margin: 14px 20px 0 0;
    overflow: hidden;
    text-indent: -9999em;
    width: 44px;
}
.icon-arrow-after:after {
    background: url(../images/submit-inverse.svg) no-repeat;
    background-size: 100% auto;
    content: ".";
    display: inline-block;
    height: 72px;
    margin: 0 0 0 20px;
    overflow: hidden;
    text-indent: -9999em;
    vertical-align: middle;
    width: 72px;
}
.icon-arrow-send {
    line-height: 52px;
    vertical-align: middle;
}
.icon-arrow-send:after {
    background: url(../images/send.svg) no-repeat;
    content: ".";
    display: inline-block;
    height: 52px;
    margin: 0 0 0 20px;
    overflow: hidden;
    text-indent: -9999em;
    vertical-align: middle;
    width: 52px;
}
.icon-arrow-before:before {
    background: url(../images/submit.svg) no-repeat;
    background-size: 100% auto;
    content: ".";
    display: inline-block;
    height: 72px;
    margin: 0 20px 0 0;
    overflow: hidden;
    text-indent: -9999em;
    vertical-align: middle;
    width: 72px;
}
.country-list {
    margin: 0;
    padding: 0;
}
.country-list li {
    display: inline-block;
    font-size: 1.5em;
    padding: 5px 10px;
}
.country-list li a:hover {
    color: rgba(255, 255, 255, .8);
}
.formset {
    padding-top: 20px;
    width: 100%;
}
.formset .fieldset {
    display: block;
}
.formset .fieldset label {
    display: block;
    font-size: 1.5em;
    vertical-align: middle;
}
.formset .fieldset input, 
.formset .fieldset textarea {
    margin: 20px 0;
    max-width: none;
}
.formset .fieldset textarea {
    min-height: 250px;
}
.formset .fieldset .submit {
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
    background: #74b9da;
    border: 0;
    color: #FFF;
    font-size: 2em;
    padding: 10px 20px;
    width: auto;
}
#map {
    height: 300px;
    width: 100%;
}
#map img {
    max-width: none;
    width: auto;
}
#map .overlay {
    background: #74b9da;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
    color: #FFF;
    font-size: 1.2em;
    margin-top: -40px;
    padding: 10px 30px;
    position: relative;
    width: 300px;
}
#map .overlay h2 {
    color: #FFF;
}
#map .overlay:after {
    border-left: 0 solid transparent;
    border-right: 32px solid transparent;
    border-top: 40px solid #74b9da;
    bottom: -40px;
    content: ".";
    display: block;
    height: 0;
    left: 30px;
    overflow: hidden;
    position: absolute;
    text-indent: -9999em;
    width: 0;
}
.leaflet-popup-content-wrapper {
    background: 0 0;
    box-shadow: none;
    margin-top: -40px;
}
.leaflet-popup-content {
    background: #74b9da;
    border: 0;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    -o-border-radius: 4px;
    border-radius: 4px;
    color: #FFF;
    font-size: 1.2em;
    margin-top: -40px;
    padding: 10px 30px;
    position: relative;
}
.leaflet-popup-content a, 
.leaflet-popup-content h2 {
    color: #FFF;
}
.leaflet-popup {
    margin: 0 0 6px 6px;
}
.leaflet-popup-tip {
    border-left: 0 solid transparent;
    border-right: 20px solid transparent;
    border-top: 20px solid #74b9da;
    margin-top: -3px;
}
@media only screen and (max-width:767px) {
    .equal, 
    .equal2, 
    .equal3, 
    .equal4, 
    .equal5 {
        height: auto!important;
        text-align: left!important;
    }
    .equal .m-clearfix:after, 
    .equal2 .m-clearfix:after, 
    .equal3 .m-clearfix:after, 
    .equal4 .m-clearfix:after, 
    .equal5 .m-clearfix:after {
        content: ".";
        display: block;
        height: 0;
        clear: both;
        visibility: hidden;
    }
    #home-panel-mb-1, 
    #home-panel-mb-2, 
    #home-panel-mb-3, 
    #home-panel-mb-4, 
    #home-panel-mb-5, 
    #home-panel-mb-6, 
    #home-panel-mb-7, 
    #home-panel-mb-8 {
        height: 500px;
        overflow: hidden;
        text-indent: -9999em;
    }
    #home-panel-mb-1 a, 
    #home-panel-mb-2 a, 
    #home-panel-mb-3 a, 
    #home-panel-mb-4 a, 
    #home-panel-mb-5 a, 
    #home-panel-mb-6 a, 
    #home-panel-mb-7 a, 
    #home-panel-mb-8 a {
        cursor: pointer;
        display: block;
        height: 500px;
        width: 100%;
    }
    #home-panel-mb-1 {
        background: url(../images/hp-mb1.jpg) no-repeat top center;
    }
    #home-panel-mb-2 {
        background: url(../images/hp-mb2.jpg) no-repeat top center;
    }
    #home-panel-mb-3 {
        background: url(../images/hp-mb3.jpg) no-repeat top center;
    }
    #home-panel-mb-4 {
        background: url(../images/hp-mb4.jpg) no-repeat top center;
    }
    #home-panel-mb-5 {
        background: url(../images/hp-mb5.jpg) no-repeat top center;
    }
    #home-panel-mb-6 {
        background: url(../images/hp-mb6.jpg) no-repeat top center;
    }
    #home-panel-mb-7 {
        background: url(../images/hp-mb7.jpg) no-repeat top center;
    }
    #home-panel-mb-8 {
        background: url(../images/hp-mb8.jpg) no-repeat top center;
    }
    .footer-tiles {
        display: none;
    }
}
@media only screen and (max-width:520px) {
    .team *, 
    .team .half .half {
        float: none;
        text-align: left;
        width: 100%;
    }
    .team * img, 
    .team .half .half img {
        margin: 0;
        width: 100%;
    }
    .team * h3, 
    .team .half .half h3 {
        margin: 20px 0 0;
    }
}
@media only screen and (min-width:768px) {
    .large-6 {
        position: relative;
        width: 50%;
    }
    .bg-body, body {
        background: #3c3c3e url(../images/bg.jpg);
    }
    i.tm {
        font-size: 80%;
        font-style: normal;
    }
    .search-box {
        display: inline-block;
        margin-top: 7px;
        vertical-align: middle;
    }
    .search-box input[type=text] {
        display: inline-block;
        font-size: 2.5em;
        max-width: none;
        padding: 0 20px;
        width: 290px;
    }
    .icon-arrow-send:after {
        background: url(../images/send.svg) no-repeat;
        height: 52px;
        width: 52px;
    }
    .icon-arrow-send:hover:after {
        -webkit-animation: send .6s steps(4) infinite;
        -moz-animation: send .6s steps(4) infinite;
        -ms-animation: send .6s steps(4) infinite;
        -o-animation: send .6s steps(4) infinite;
        animation: send .6s steps(4) infinite;
    }
    .formset .fieldset {
        padding-bottom: 20px;
    }
    .formset .fieldset label {
        display: inline-block;
        height: 50px;
        line-height: 50px;
        margin-right: 2%;
        text-align: right;
        width: 28%;
    }
    .formset .fieldset input, 
    .formset .fieldset textarea {
        display: inline-block;
        margin: 0;
        width: 65%;
    }
    .formset .fieldset .submit {
        margin-left: 30%;
    }
    .on nav.main {
        left: 0;
        position: fixed;
        top: 0;
        width: 100%;
        z-index: 10;
    }
    .hero .feature-banner {
        bottom: 0;
        position: absolute;
        width: 100%;
        z-index: 3;
    }
    .half {
        float: left;
        width: 50%;
    }
    .third {
        float: left;
        width: 33.3%;
    }
    .two-thirds {
        float: left;
        width: 66.6%;
    }
    .quart {
        float: left;
        width: 25%;
    }
    .three-quarts {
        float: left;
        width: 75%;
    }
    .c5 {
        float: left;
        width: 5%;
    }
    .c10 {
        float: left;
        width: 10%;
    }
    .c15 {
        float: left;
        width: 15%;
    }
    .c20 {
        float: left;
        width: 20%;
    }
    .c30 {
        float: left;
        width: 30%;
    }
    .c35 {
        float: left;
        width: 35%;
    }
    .c40 {
        float: left;
        width: 40%;
    }
    .c45 {
        float: left;
        width: 45%;
    }
    .c55 {
        float: left;
        width: 55%;
    }
    .c60 {
        float: left;
        width: 60%;
    }
    .c65 {
        float: left;
        width: 65%}
    .c70 {
        float: left;
        width: 70%;
    }
    .mobile {
        display: none;
    }
    .desktop {
        display: block;
    }
    .intro {
        min-height: 300px;
    }
    header {
        height: 159px;
        position: relative;
        z-index: 4;
    }
    header h1 {
        background: url(../images/logo.svg) no-repeat 0 0;
        background-size: 100% auto;
        display: inline-block;
        height: 107px;
        position: relative;
        right: auto;
        top: auto;
        width: 109px;
    }
    header h1 a {
        display: block;
        height: 107px;
        width: 109px;
    }
    header h2 {
        background: url(../images/tagline.svg) no-repeat 0 0;
        background-size: 100% auto;
        display: inline-block;
        height: 60px;
        margin: 38px 0 0 10px;
        overflow: hidden;
        padding: 0;
        text-indent: -9999em;
        width: 182px;
    }
    header nav.main {
        background: #575656;
        display: block;
        height: 52px;
    }
    header nav.main ul li {
        display: inline-block;
        height: 52px;
        line-height: 50px;
        text-align: center;
    }
    header nav.main ul li a {
        color: #FFF;
        font-size: 22px;
        padding: 0 22px;
        display: block;
        height: 60px;
    }
    header nav.main ul li:first-child {
        background: #dc9c51 url(../images/logo-txt.svg) no-repeat 0 0;
        background-size: 100% auto;
        overflow: hidden;
        text-indent: -9999em;
        width: 109px;
    }
    header nav.main ul li:first-child a {
        padding: 0;
    }
    header nav.main ul li:first-child:hover {
        background: #dc9c51 url(../images/logo-txt.svg) no-repeat 0 0;
        background-size: 100% auto;
    }
    header nav.secondary {
        display: block;
        position: relative;
    }
    header nav.secondary ul {
        padding-right: 2em;
        padding-top: 52px;
        position: relative;
        text-align: right;
        z-index: 3;
    }
    header nav.secondary ul li {
        color: #c5c6c6;
        display: inline-block;
        font-size: 16px;
    }
    header nav.secondary ul li a {
        color: #c5c6c6;
        padding: 0 10px;
    }
    header nav.secondary ul li a:hover {
        color: #FFF;
    }
    header nav.secondary ul li:first-child:after {
        content: "|";
    }
    header nav.secondary ul li.country-selector {
        cursor: pointer;
        position: relative; 
    }
    header nav.secondary ul li.country-selector i {
        display: none; 
    }
    header nav.secondary ul.countries {
        background: #353534;
        display: none;
        list-style: none;
        padding: 45px 0 0;
        position: absolute;
        right: 10px;
        margin: 0;
        text-align: left;
        top: 38px;
        width: 170px;
        z-index: 2; 
    }
    header nav.secondary ul.countries li {
        display: block;
        font-family: 'Aller Typo W01 Regular',Arial, Helvetica, sans-serif;
        font-style: normal;
        font-weight: normal; 
    }
    header nav.secondary ul.countries li a {
        display: block;
        font-size: 0.9em;
        padding: 2px 10px; 
    }
    header nav.secondary ul.countries li a:hover {
        background: rgba(255, 255, 255, 0.1); 
    }
    header nav.secondary ul.countries li:first-child:after {
        content: ""; 
    }
    .feature-banner h2 {
        font-size: 1.8em;
    }
    .feature-banner.billboard h2 {
        font-size: 5em;
    }
    .feature-banner.billboard.small h2 {
        font-size: 3.5em;
    }
    #home-panel-1 {
        background: url(../images/hero-home.jpg) top center no-repeat;
    }
    #home-panel-2 {
        background: url(../images/hero-ourbeverages.jpg) top center no-repeat;
    }
    #home-panel-3 {
        background: url(../images/hero-home3.jpg) top center no-repeat;
    }
    #home-panel-4 {
        background: url(../images/hero-fairtrade.jpg) top center no-repeat;
    }
    #home-panel-5 {
        background: url(../images/hero-home5.jpg) top center no-repeat;
    }
    #home-panel-6 {
        background: url(../images/hero-home6.jpg) top center no-repeat;
    }
    #home-panel-7 {
        background: url(../images/hero-home7.jpg) top center no-repeat;
    }
    #home-panel-8 {
        background: url(../images/hero-home8.jpg) top center no-repeat;
    }
    .great-coffee {
        background: url(../images/great-coffee.svg) top center no-repeat;
    }
    #home-panel-1, 
    #home-panel-2, 
    #home-panel-3, 
    #home-panel-4, 
    #home-panel-5, 
    #home-panel-6, 
    #home-panel-7, 
    #home-panel-8, 
    .great-coffee {
        background-size: cover;
        background-attachment: fixed;
        height: 654px;
        margin: 0 auto;
        max-width: 100%;
        position: relative;
        text-align: center;
        width: 100%;
    }
    #home-panel-1 article, 
    #home-panel-2 article, 
    #home-panel-3 article, 
    #home-panel-4 article, 
    #home-panel-5 article, 
    #home-panel-6 article, 
    #home-panel-7 article, 
    #home-panel-8 article, 
    .great-coffee article {
        height: 100%;
        width: 100%;
    }
    #home-panel-1 article a, 
    #home-panel-2 article a, 
    #home-panel-3 article a, 
    #home-panel-4 article a, 
    #home-panel-5 article a, 
    #home-panel-6 article a, 
    #home-panel-7 article a, 
    #home-panel-8 article a, 
    .great-coffee article a {
        display: block;
        height: 100%;
        width: 100%;
    }
    #home-panel-1 img, 
    #home-panel-2 img, 
    #home-panel-3 img, 
    #home-panel-4 img, 
    #home-panel-5 img, 
    #home-panel-6 img, 
    #home-panel-7 img, 
    #home-panel-8 img, 
    .great-coffee img {
        display: inline-block;
        margin: 0 15%;
        vertical-align: middle;
        width: 60%;
    }
    #home-panel-1 img.mobile, 
    #home-panel-2 img.mobile, 
    #home-panel-3 img.mobile, 
    #home-panel-4 img.mobile, 
    #home-panel-5 img.mobile, 
    #home-panel-6 img.mobile, 
    #home-panel-7 img.mobile, 
    #home-panel-8 img.mobile, 
    .great-coffee img.mobile {
        display: none;
    }
    #home-panel-1 .divhelper, 
    #home-panel-2 .divhelper, 
    #home-panel-3 .divhelper, 
    #home-panel-4 .divhelper, 
    #home-panel-5 .divhelper, 
    #home-panel-6 .divhelper, 
    #home-panel-7 .divhelper, 
    #home-panel-8 .divhelper, 
    .great-coffee .divhelper {
        display: inline-block;
        height: 100%;
        vertical-align: middle;
    }
    #home-panel-8 img {
        display: none;
    }
    .great-coffee {
        background-attachment: scroll;
        height: 540px;
        top: -100px;
    }
    .team .intro {
        min-height: 320px;
    }
    .team .content, 
    .team .half, 
    .team .m-clearfix {
        height: 100%;
    }
    .team .content div {
        display: inline-block;
        vertical-align: middle;
    }
    .team .content div.divhelper {
        height: 100%;
    }
    .bean-panel {
        height: 1308px;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%;
        z-index: 10;
    }
    .bean-panel .bean-wrapper {
        height: 1308px;
        overflow: hidden;
        position: relative;
    }
    .bean {
        background: url(../images/bean.svg) no-repeat 0 0;
        background-size: 100% auto;
        height: 65px;
        position: absolute;
        top: 0;
        width: 65px;
        z-index: 10;
    }
    .bean.bean1 {
        left: 38%!important;
    }
    .bean.bean2 {
        left: 22%!important;
    }
    .bean.bean3 {
        background: url(../images/bean2.svg) no-repeat 0 0;
        background-size: 100% auto;
        left: 73%!important;
    }
    .bean.bean4 {
        background: url(../images/bean3.svg) no-repeat 0 0;
        background-size: 100% auto;
        left: 50%!important;
    }
    .bean.bean5 {
        left: 39%!important;
    }
    .bean.bean6 {
        background: url(../images/bean4.svg) no-repeat 0 0;
        background-size: 100% auto;
        left: 59%!important;
    }
    .bean.bean7 {
        background: url(../images/bean2.svg) no-repeat 0 0;
        background-size: 100% auto;
        left: 69%!important;
    }
    .handle {
        background: url(../images/grinder.svg) no-repeat 0 0;
        display: block;
        height: 362px;
        position: absolute;
        right: 16%;
        top: 33%;
        transition: none;
        width: 130px;
        z-index: 2;
    }
    .fr1 .handle {
        background-position: -130px 0;
    }
    .fr2 .handle {
        background-position: -260px 0;
    }
    .fr3 .handle {
        background-position: -390px 0;
    }
    .fr4 .handle {
        background-position: -520px 0;
    }
    .fr5 .handle {
        background-position: -650px 0;
    }
    .fr6 .handle {
        background-position: -780px 0;
    }
    .fr7 .handle {
        background-position: -910px 0;
    }
    .fr8 .handle {
        background-position: -780px 0;
    }
    .fr9 .handle {
        background-position: -650px 0;
    }
    .fr10 .handle {
        background-position: -520px 0;
    }
    .fr11 .handle {
        background-position: -390px 0;
    }
    .fr12 .handle {
        background-position: -260px 0;
    }
    .fr13 .handle {
        background-position: -130px 0;
    }
    .fr14 .handle {
        background-position: 0 0;
    }
    .scroll-for-more {
        background: url(../images/scroll-for-more.svg) no-repeat 0 0;
        bottom: 120px;
        display: block;
        height: 90px;
        position: absolute;
        left: 50%;
        margin-left: -85px;
        transition: none;
        width: 170px;
        z-index: 2;
        -webkit-animation: scrollformore .8s steps(4) infinite;
        -moz-animation: scrollformore .8s steps(4) infinite;
        -ms-animation: scrollformore .8s steps(4) infinite;
        -o-animation: scrollformore .8s steps(4) infinite;
        animation: scrollformore .8s steps(4) infinite;
    }
    .scroll-for-more a {
        display: block;
        height: 90px;
        width: 170px;
    }
    #map {
        height: 600px;
    }
    .farmers {
        background: url(../images/farmers.svg) no-repeat 0 0;
        display: block;
        height: 172px;
        position: absolute;
        right: 22%;
        top: 90px;
        transition: none;
        width: 340px;
        z-index: 2;
        -webkit-animation: farmers .6s steps(4) infinite;
        -moz-animation: farmers .6s steps(4) infinite;
        -ms-animation: farmers .6s steps(4) infinite;
        -o-animation: farmers .6s steps(4) infinite;
        animation: farmers .6s steps(4) infinite;
    }
    .read-more {
        background: url(../images/read-more.svg) no-repeat 0 0;
        bottom: 60px;
        display: block;
        height: 55px;
        position: absolute;
        left: 50%;
        margin-left: -158px;
        transition: none;
        width: 317px;
        z-index: 2;
        -webkit-animation: readmore .8s steps(4) infinite;
        -moz-animation: readmore .8s steps(4) infinite;
        -ms-animation: readmore .8s steps(4) infinite;
        -o-animation: readmore .8s steps(4) infinite;
        animation: readmore .8s steps(4) infinite;
    }
    .picker {
        background: url(../images/picking.svg) no-repeat 0 0;
        display: block;
        height: 140px;
        position: absolute;
        left: 24%;
        top: 18%;
        transition: none;
        width: 166px;
        z-index: 2;
        -webkit-animation: picker .8s steps(4) infinite;
        -moz-animation: picker .8s steps(4) infinite;
        -ms-animation: picker .8s steps(4) infinite;
        -o-animation: picker .8s steps(4) infinite;
        animation: picker .8s steps(4) infinite;
    }
}
@media only screen and (min-width:992px) {
    h1, h2.h1 {
        font-size: 2em;
    }
    h1.shout, 
    h2.h1.shout {
        font-size: 2.5em;
    }
    .scroll-for-more {
        bottom: 40px;
    }
    header h2 {
        height: 75px;
        margin: 28px 0 0 20px;
        width: 260px;
    }
    header nav.main ul li a {
        font-size: 28px;
        padding: 0 32px;
    }
    header nav.secondary ul {
        padding-top: 50px;
    }
    header nav.secondary ul li {
        font-size: 18px;
    }
    header nav.secondary ul.countries {
        width: 300px; 
    }
    header nav.secondary ul li.country-selector i {
        background: url(../images/country-select.svg) no-repeat 0 0;
        background-size: 100% auto;
        display: inline-block;
        height: 38px;
        margin-top: -5px;
        vertical-align: middle;
        width: 120px; 
    }
    header nav.secondary ul li.country-selector:hover i {
        background: url(../images/country-select.svg) no-repeat 0 -38px;
        background-size: 100% auto; 
    }
    .intro {
        min-height: 400px;
    }
    .content .centered-50 {
        display: block;
        margin-left: auto;
        margin-right: auto;
        max-width: 50%;;
    }
    .content .centered-60 {
        display: block;
        margin-left: auto;
        margin-right: auto;
        max-width: 60%;;
    }
    .content .centered-70 {
        display: block;
        margin-left: auto;
        margin-right: auto;
        max-width: 70%;
    }
    .content .centered-80 {
        display: block;
        margin-left: auto;
        margin-right: auto;
        max-width: 80%;
    }
    .content {
        padding: 20px 40px;
    }
    .half .content {
        max-width: 620px;
    }
    .feature-banner h2 {
        font-size: 2em;
    }
}
@media only screen and (min-width:1224px) {
    header nav.main ul li a {
        font-size: 32px;
        padding: 0 50px;
    }
    .handle {
        right: 22%;
    }
}
@media only screen and (min-width:1600px) {
    #home-panel-1 img, 
    #home-panel-2 img, 
    #home-panel-3 img, 
    #home-panel-4 img, 
    #home-panel-5 img, 
    #home-panel-6 img, 
    #home-panel-7 img {
        width: 50%;
    }
    #home-panel-8 img {
        width: 100%;
    }
    .team .intro {
        min-height: 400px;
    }
}

@media all and (device-width: 768px) and (device-height: 1024px) and (orientation:portrait) {
  #home-panel-1,
  #home-panel-2,
  #home-panel-3,
  #home-panel-4,
  #home-panel-5,
  #home-panel-6,
  #home-panel-7,
  #home-panel-8 { 
    background-size: auto 1024px;
    background-position: top center !important;
    background-attachment: scroll !important;
  }
  .great-coffee {
    background-size: auto 650px;
    background-position: top center !important;
    background-attachment: scroll !important;
    height: 650px;
  }
  .on nav.main {
    left: auto;
    position: relative;
    top: auto;
  }
}

@media all and (device-width: 768px) and (device-height: 1024px) and (orientation:landscape) {
  #home-panel-1,
  #home-panel-2,
  #home-panel-3,
  #home-panel-4,
  #home-panel-5,
  #home-panel-6,
  #home-panel-7,
  #home-panel-8 { 
    background-size: auto 768px;
    background-position: top center !important;
    background-attachment: scroll !important;
  }
  .great-coffee {
    background-size: auto 450px;
    background-position: top center !important;
    background-attachment: scroll !important;
    height: 450px;
  }
  .on nav.main {
    left: auto;
    position: relative;
    top: auto;
  }
  #map {
    height: 400px;
  }
}