@charset "UTF-8";

body {
    background-color: #ebebeb;
    margin: 0;
    min-width: 320px;
}

h1 {
    margin: 15px 15px 5px 0;
}

h2 {
    margin: 5px 0;
}

h3 {
    text-decoration: none;
}

h1, h2, a {
    color: #43a6cf;
    font-weight: normal;
    text-decoration: none;
}

.event-information h1 {
    font-family: ProximaNova-Regular, "Open Sans", Helvetica, Arial, sans-serif;
    text-transform: uppercase;
    margin: 10px 0 0 0;
}

.event-information .support {
    margin-bottom: 5px;
}

h3, h4 {
    text-decoration: none;
}

hr {
    background: #43a6cf;
    border: 0;
    height: 1px;
    margin: 1em 0;
}

fieldset {
    border: 1px solid #ccc;
}

a:hover {
    text-decoration: underline;
}

.block p:not(:last-child) {
    /* todo get rid of this? not sure why paragraphs need padding */
    padding-bottom: 10px;
}

.profile-banner {
    margin: -10px 0;
    width: 100%;
}

.content.profile-image-wrapper {
    float: left;
    margin-bottom: 15px;
    position: relative;
}

.profile-image {
    border: 1px solid #fff;
    border-radius: 5px;
    left: 20px;
    position: absolute;
    bottom: -10px;
}

h3.profile-title {
    font-size: 16px;
    text-align: right;
}

h3.profile-title.padded {
    padding: 5px;
}

#back-to-top, #continue, a.button.unavailable {
    background-color: #888;
}

#continue {
    margin-bottom: 10px;
}

#back-to-top:hover,         #back-to-top:active,
#continue:hover,            #continue:active,
a.button.unavailable:hover, a.button.unavailable:active {
    background-color: #777;
}

#emptyBasket:not(:hover) {
    background-color: #76766f;
}

#Header {
    min-height: 50px;
    width: 100%;
}

#paginate {
    margin-top: 10px;
}

.carousel-margin-breaker {
    background-color: #ebebeb;
    margin: 0 -10px;
    overflow: hidden;
    position: relative;
}

.homepage-inline-banner img {
    width: 100%;
}

.info-description {
    font: normal 12px/1.4 ProximaNova-Regular;
    margin: 0;
    padding: 0 10px 5px;
}

.info-description a {
    color: #fff;
    text-decoration: underline;
}

.info-description p {
    margin: 0;
    padding: 5px 0;
}

.homepage-divider {
    height: 10px;
    background-color: #ebebeb;
    margin: 0 -10px;
}

.hidden {
    visibility: hidden;
}

.ErrorMessage {
    color: red;
}

.error { /* rename this? */
    background-color: pink;
    font-weight: bold;
    padding: 6px 10px;
    font-size: 18px;
}

.error ul {
    margin: 0;
}

#wrapper {
    min-width: 320px;
    width: 100%;
}

#footer {
    clear: both;
    margin: 0;
}

#footer #footer-links {
    background-color: #333;
    color: #43a6cf;
    padding-top: 10px;
}

.footer-copyright {
    color: #d7d7d7;
    font-size: 0.9em;
}

.half {
    width: 50%;
}

.third {
    width: 33.3%;
}

.leaderboard, .bottomboard {
    margin: 0 auto;
    height: 50px;
    max-width: 320px;
    padding: 10px 0;
}

.logo {
    float: left;
    padding: 4px 0 0 0;
    text-align: center;
}

.logo h1 {
    font-size: 0;
    margin: 0;
    padding: 0;
}

.logo img {
    max-width: 50%;
}

a.social {
    display: block;
    float: right;
    margin-right: 5px;
    padding: 1px;
}

.facebook-share a img {
    padding: 0 3px;
    vertical-align: middle;
}

.content {
    box-sizing: border-box;
    margin: 0 auto;
    max-width: 1170px;
    width: 100%;
}

.ad-banner {
    background-color: #333;
    height: 70px;
}

input[type="text"],
input[type="email"],
input[type="number"],
input[type="tel"],
input[type="password"],
select,
textarea,
.form-control-static {
    background-color: #fff;
    border: solid 1px #ccc;
    box-shadow: none;
    color: #333;
    height: 34px;
    padding: 0 5px;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type=number] {
    -moz-appearance: textfield;
}

.form-control-static {
    padding: 9px 5px;
}

.form-control-auto-height {
    height: auto;
}

.crafty-postcode-select select {
    width: 100%;
}

.star {
    padding-top: 10px;
    text-align: center;
    width: 100%;
}

.margin-top {
    margin-top: 1em;
}

.margin-top-bottom {
    margin: 1em 0;
}

.links li {
    list-style: outside none none;
    margin: 7px 0;
}

.padded {
    padding: 10px;
}

#advsearch .adv-search-section {
    margin-top: 0;
}

#WrapperInner {
    margin: 10px auto 0 auto;
    max-width: 1170px;
    width: 100%;
}

#Page {
    float: left;
    width: 100%;
}

#Content {
    overflow: auto;
    background-color: #fff;
    padding: 0 10px 0 10px;
}

#RightColumn {
    display: none;
}

.search {
    height: 100%;
    text-align: center;
}

form#search-form input[name="unified_query"] {
    width: 232px;
    z-index: 1;
}

input#promoCode {
    width: 200px;
}

input.search-form[type="text"], form#newsletter-signup input[type="text"] {
    border-radius: 4px 0 0 4px;
}

input.search-form[type="submit"], form#newsletter-signup input[type="submit"], form#promoform input[type="submit"] {
    border-radius: 0 4px 4px 0;
    float: none;
    height: 36px;
    margin-left: -4px;
    vertical-align: top;
}

input.search-form[type="submit"] {
    background-image: url("/rebrand/images/icons/search.svg");
    background-position: center center;
    background-repeat: no-repeat;
}

.block-header-search {
    text-align: center;
    position: relative;
    z-index: 1;
}

.form-row label {
    background: #43a6cf none repeat scroll 0 0;
    border: 1px solid #43a6cf;
    color: #fff;
    display: inline-block;
    height: 34px;
    padding: 7px 6px;
    text-align: right;
    width: 25%;
}

.form-row label a {
    color: #43a6cf;
    background: #deeef1;
    padding: 2px 5px 2px 4px;
    margin-left: 3px;
}

.form-row label a:hover {
    color: #3c80a7;
    background: #bed0da;
    text-decoration: none;
}

.region-tag {
    display: inline-block;
    background: #ccc;
    padding: 0 5px;
    margin-top: 1px;
    margin-bottom: 2px;
    font-size: 0.9em;
}

input[type="text"], input[type="email"], input[type="number"], input[type="password"], select, form #privacy, form #terms, textarea#message, textarea.questionnaire, .input-field {
    width: 75%;
}

input[type="text"].Counter {
    width: 50px;
}

select#results_order_select, label#results_order_label {
    width: auto;
}

.form-row:first-of-type {
    margin: 0 0 5px;
}

.form-row .notReallyFirst {
    margin: 10px 0 0 0;
}

.form-row {
    margin: 5px 0 0 0;
}

.form-row.diptych {
    margin: 5px 0;
}

.sub-nav {
    display: none;
    padding: 0 10px;
    width: 100%;
}

.sub-nav ul {
    display: inline-block;
    margin: 0 0 5px 0;
    padding-left: 0;
    width: 100%;
    text-align: center;
}

.sub-nav ul:last-child {
    margin: 0;
}

.sub-nav li {
    display: inline-block;
    list-style: outside none none;
    margin-left: 0;
}

.sub-nav li a {
    display: block;
    font-size: 14px;
    padding: 10px 7px;
}

.sub-nav li a.basket, .sub-nav li a.login, .sub-nav li a.logout, .sub-nav li a.tickets, .sub-nav li a.register {
    background-image: none;
    padding: 10px 8px 10px 8px;
}

#Navigation ul#mobile-nav {
    height: auto;
    line-height: normal;
    margin: 5px;
    padding: 0;
    position: absolute;
    width: auto;
}

#Navigation ul.dropdown-menu {
    border-color: #f1f2f3;
    margin: 30px 0 0 1px;
    padding: 0;
    width: auto;
}

#Navigation ul.dropdown-menu li {
    background-color: #fff;
    padding-top: 1px;
}

#Navigation ul.dropdown-menu li:first-child {
    padding-top: 0;
}

#Navigation ul.dropdown-menu li a {
    background-color: #fff;
    color: #44a6cf;
    font-size: 16px;
    font-weight: 400;
    padding: 4px 10px;
    text-decoration: none;
    z-index: 12;
}

#Navigation ul.dropdown-menu li a:focus, #Navigation ul.dropdown-menu li a:active {
    z-index: 12;
}

#Navigation ul.dropdown-menu li a:hover {
    background-color: #44a6cf;
    color: #fff;
}

#ticketsButton {
    padding: 10px 10px 10px 10px;
    margin-top: 10px;
    margin-bottom: 10px;
    width: 100%;
}

a.css-menu-button,
a.css-menu-button:not(:focus) {
    border-radius: 4px;
    height: auto;
    margin: 0;
    position: absolute;
    width: auto;
    z-index: 15;
}

a.css-menu-button:focus {
    z-index: 1;
}

a.menu-over {
    background-color: transparent;
    border-radius: 4px;
    cursor: pointer;
    height: auto;
    left: 0;
    position: absolute;
    top: 0;
    width: auto;
    z-index: 8;
}

a.menu-over:focus ~ .dropdown-menu,
a.menu-over:active ~ .dropdown-menu {
    visibility: hidden;
}

li.css-menu {
    background-color: transparent;
    border: 0;
    height: auto;
    position: relative;
    width: auto;
}

li.css-menu a {
    padding: 5px 3px;
}

li.css-menu, ul.dropdown-menu li {
    width: auto;
}

.logged-in-menu {
    float: right;
}

.section-margins {
    margin: 10px -10px;
}

.section-divider-margins {
    margin: 0 -10px 10px -10px;
}

.form-buttons-margin {
    margin: 10px 0 0;
}

.chatterbox-margin {
    margin: 0 0 15px 0;
}

.block-group.block-group-flex {
    display: block;
}

.BuyBox {
    border-bottom: 1px solid #43a6cf;
    padding: 5px 0 10px 0;
}

.BuyBox h2 {
    color: #0c0c0c;
    font-size: 20px;
    text-transform: uppercase;
}

.BuyBox h2, .BuyBox h4 {
    font-family: ProximaNova-Regular, "Open Sans", Helvetica, Arial, sans-serif;
}

.BuyBox h2 .concession {
    font-size: inherit;
}

.BuyBox input[type="number"],
.BuyBox button[name="-"],
.BuyBox button[name="+"] {
    width: 8px; /* we're not using border-box so padding will be most of the width */
    padding: 0 20px;
}

.BuyBox input[type="number"] {
    border: 1px solid black;
    height: 34px;
    padding: 0 1em;
    width: 50px;
    box-sizing: border-box;
    text-align: center;
}

.BuyBox p {
    margin: 0;
}

#seatingPlan {
    padding: 10px;
    text-align: center;
}

#seatingPlan img {
    max-width: 100%;
}

input[name="+"], button[name="+"], input[name="-"], button[name="-"] {
    background-position: center center;
    background-repeat: no-repeat;
    color: #fff;
    font-size: 0;
    height: 34px;
    width: 34px;
    vertical-align: middle;
    border: none;
}

input[name="+"], button[name="+"] {
    background-image: url("/rebrand/images/icons/white/ico-expand.png");
    background-color: #92c519;
}

input[name="-"], button[name="-"] {
    background-image: url("/rebrand/images/icons/white/ico-collapse.png");
    background-color: #43a6cf;
}

input[name="qty[]"] {
    border: 1px solid black;
    width: 34px;
    height: 32px; /* 34px including border */
    text-align: center;
}

input[name^="donation"] {
    background-image: url("/rebrand/images/icons/white/ico-expand.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-color: #92c519;
    border-color: #92c519;
    color: #fff;
    font-size: 0;
    height: 24px;
    line-height: 24px;
    padding: 0 10px;
}

input[name="buy"], button[name="buy"] {
    background-color: #92c519;
    color: #fff;
    text-transform: capitalize;
    height: 34px;
    border: 0;
    padding: 0 20px;
}

span.donation {
    padding: 4px 8px 12px 2px;
}

input.donationBespoke {
    height: 22px;
    width: 25px;
}

input.donationBespoke.button {
    height: 24px;
    float: right;
}

.donations h3 {
    font-family: ProximaNova-Regular, "Open Sans", Helvetica, Arial, sans-serif;
    color: #43a6cf;
}

select#months {
    width: 200px;
}

#calendarControls {
    height: 34px;
}

#calendarControlsMonth .date, #calendarControls .date {
    margin: 0 auto;
    text-align: center;
}

#calendarControlsMonth .previous, #calendarControls .previous {
    display: block;
    float: left;
    padding-left: 25px;
}

#calendarControlsMonth .next, #calendarControls .next {
    display: block;
    float: right;
    padding-right: 25px;
}

div.EventLocation ul {
    list-style-type: none;
    padding: 0;
}

table {
    margin: 1em 0;
}

table#variantdetails {
    width: 100%;
}

table#variantdetails .right {
    text-align: right;
}

table#variantdetails td.right{
    min-width: 100px;
}

table#variantdetails td{
    vertical-align: top;
}

table#variantdetails p {
    font-family: ProximaNova-Regular, "Open sans", Helvetica, Arial, sans-serif;
    font-weight: normal;
    font-size: 14px;
}

.price {
    padding-bottom: 5px;
    padding-top: 5px;
}

.bottomtext{
    margin-top: 20px;
    margin-bottom: 20px;
}
#venueWebsite {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-group.png") no-repeat scroll left center;
}

#venueTelephone {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-phone.png") no-repeat scroll left center;
}

#StreetmapLink {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-location.png") no-repeat scroll left center;
}

#venueWebsite, #venueTelephone, #StreetmapLink {
    margin: 0;
    padding: 0.5em;
    padding-left: 2.25em;
}

div.EventLocation p {
    clear: right;
    margin: 0;
    padding: 5px;
}

.venue-logo {
    float: left;
    padding: 2px 0 0 2px;
    width: 90px;
}

.venue-details h2, .venue-details h3, .venue-details h4 {
    clear: right;
    display: flex;
    margin: 0;
}

.clearfix {
    clear: both;
    display: block;
    overflow: auto;
}

ul#AboutUs {
    margin: 0;
    padding-left: 0;
    text-align: left;
}

#AboutUs li {
    display: inline-block;
    list-style-type: none;
}

#AboutUs li h1 {
    margin-right: 2px;
}

#AboutUs li:first-child {
    float: left;
    width: 100%;
}

#AboutUs li a {
    background: #76766f;
    color: #ffffff;
    font-size: 0.9em;
    display: block;
    margin-top: 0;
    margin-bottom: 5px;
    margin-right: 3px;
    font-weight: normal;
    padding: 7px 8px 4px;
    text-decoration: none;
}

#AboutUs li a:hover {
    background: #5D5D56;
}

#AboutUs li.active a {
    background: #43a6cf;
}

li.about {
    background: rgba(0, 0, 0, 0) no-repeat scroll 2px 2px;
    padding-left: 40px;
}

li.environ {
    background-image: url("/rebrand/images/icons/colourfilled/ico-feature-enviro.png");
}

li.fees {
    background-image: url("/rebrand/images/icons/colourfilled/ico-feature-fees.png");
}

li.goodcauses {
    background-image: url("/rebrand/images/icons/colourfilled/ico-feature-goodcauses.png");
}

li.organisers {
    background-image: url("/rebrand/images/icons/colourfilled/ico-feature-organisers.png");
}

li.us {
    background-image: url("/rebrand/images/icons/colourfilled/ico-feature-us.png");
}

.FAQClose {
    float: right;
    padding: 0 4px;
    font-size: 24px;
    font-weight: 700;
    line-height: 0.8;
    color: #000;
    text-shadow: 0 1px 0 #fff;
    filter: alpha(opacity=50);
    opacity: .5;
}

.FAQClose:hover {
    text-decoration: none;
    filter: alpha(opacity=90);
    opacity: .9;
}

.FAQOuter {
    border: 1px solid #43a6cf;
}

label.honey {
    display: none;
}

input.honey {
    display: none;
}

a.button, .proceed {
    background-color: #92c519;
    border: none;
    color: #fff;
    padding: 10px 15px;
    line-height: normal;
}

.third {
    width: 33%;
}

.proceedblock {
    margin-bottom: 10px;
}

.button, .Counter {
    border: solid 1px;
    display: inline-block;
    text-align: center;
    height: 34px;
    line-height: 32px;
    vertical-align: middle;
    box-sizing: border-box;
    padding: 0 20px;
}

.button.closed {
    background-image: url("/rebrand/images/icons/white/ico-expand.png");
    background-position: right 4px top 4px;
    background-repeat: no-repeat;
    padding: 10px 34px 10px 20px;
}

.button.open {
    background-image: url("/rebrand/images/icons/white/ico-collapse.png");
    background-position: right 4px top 4px;
    background-repeat: no-repeat;
    padding: 10px 34px 10px 20px;
}

.block.has-button-addon {
    width: 50%;
}

.button-addon {
    width: 25%;
}

.Counter {
    width: 50px;
}

.quantity-block {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-end;
}

.quantity-block .Concessions {
    flex: 1 100%;
    text-align: right;
}

.quantity-block .Counter {
    text-align: left;
}

.button:hover, .button:focus, .button:active {
    cursor: pointer;
    text-decoration: none;
    color: #fff;
    background-color: #85B80C;
    border-color: #85B80C;
}

.button[name="-"]:hover{
    background-color: #3b94b9;
}
div.mock-form-input {
    padding: 8px 5px 0 5px;
    width: 75%;
}

#adv_from_day, #adv_from_month, #adv_to_day, #adv_to_month {
    display: block;
    float: left;
    width: 37.5%;
}

.full-width {
    width: 100%;
}

.full-width-mobile, .mobile-full-width {
    width: 100%;
}

.right {
    float: right;
}

.left {
    float: left;
}

.margin-top-bottom {
    margin: 1em 0;
}

ul.values {
    padding: 0;
}

.values li {
    list-style: outside none none;
    padding: 10px 15px 10px 45px;
    text-decoration: none;
}

.values li.cat-newsletter {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-mailopen.png") no-repeat scroll left 7px top 7px;
}

.values li.cat-fees {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-pig.png") no-repeat scroll left 7px top 7px;
}

.values li.cat-custservice {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-custservice.png") no-repeat scroll left 7px top 7px;
}

.text.right, .text-right {
    text-align: right;
}

.text.centre, .text-center {
    text-align: center;
}

.text.top, .text-top {
    vertical-align: top;
}

.text-bottom {
    vertical-align: bottom;
}

#bookingFeeFAQ {
    display: none;
}

.diptych, .triptych {
    margin: 0;
}

.form-buttons-margin .triptych {
    margin: 2px 0;
}

.quintych {
    margin: 0;
    width: 20%;
}

.no-js-features a {
    display: block;
}

.features, .trending {
    display: none;
}

.slick-list {
    overflow: visible !important;
}

.trender {
    display: block;
    float: left;
    height: 100%;
}

.trender a {
    display: block;
    position: relative;
    text-decoration: none;
}

.trender a.image {
    padding: 5px 10px 0;
}

.trender .info-wrapper {
    padding: 0 10px;
}

.trender .info-title {
    background-color: #fff;
    font-size: 13px;
    height: 48px;
    line-height: 16px;
    padding: 10px;
}

.trending-controls-wrapper,
.marketing-controls-wrapper {
    margin: 0 auto;
    text-align: center;
    width: auto;
}

.trending-controls,
.marketing-controls-1,
.marketing-controls-2 {
    display: inline-block;
    position: relative;
    text-align: center;
}

.trending-image-wrapper {
    position: relative;
}

span.fix-width-title {
    display: block;
    height: 32px;
    overflow: hidden;
    position: relative;
}

span.fix-width-title::after {
    background: linear-gradient(to right, rgba(255, 255, 255, 0), #ffffff 95%) repeat scroll 0 0;
    bottom: 0;
    content: "";
    height: 16px;
    position: absolute;
    right: 0;
    text-align: right;
    width: 30%;
}

#feature-counter {
    bottom: 8px;
    color: #fff;
    font-size: 12px;
    left: 10px;
    opacity: 0.75;
    position: absolute;
}

ul.slick-dots {
    margin: 0;
    padding: 10px 25px 20px 25px;
}

.slick-dots li.slick-active button {
    background-image: url("/rebrand/images/icons/carousel_a.png");
    background-position: center center;
    background-repeat: no-repeat;
    color: #43A6CF;
    opacity: 1;
}

.slick-dots li button {
    background-image: url("/rebrand/images/icons/carousel_i.png");
    background-position: center center;
    background-repeat: no-repeat;
    font-size: 8px;
    height: 20px;
    left: 0;
    line-height: 20px;
    opacity: 0.50;
    position: absolute;
    text-align: center;
    top: 0;
    width: 10px;
}

.slick-dots li {
    cursor: pointer;
    display: inline-block;
    height: 20px;
    margin: 0 5px;
    padding: 0;
    position: relative;
    width: 10px;
}

.slick-dots li button {
    background-color: rgba(0, 0, 0, 0);
    border: 0 none;
    color: rgba(0, 0, 0, 0);
    cursor: pointer;
    display: block;
    font-size: 0;
    height: 20px;
    line-height: 0;
    outline: medium none;
    padding: 5px;
    width: 10px;
}

.slick-next, .slick-prev {
    background-color: rgba(0, 0, 0, 0);
    border: medium none;
    color: rgba(0, 0, 0, 0);
    cursor: pointer;
    display: block;
    font-size: 0;
    height: 20px;
    line-height: 0;
    outline: medium none;
    padding: 0;
    position: absolute;
    top: 10px;
    width: 20px;
}

.features .slick-next, .features .slick-prev {
    height: 100%;
    top: 0;
    width: 40px;
    z-index: 4;
}

.slick-prev {
    background-image: url("/rebrand/images/icons/carousel_l.png");
    background-position: center center;
    background-repeat: no-repeat;
}

.slick-next {
    background-image: url("/rebrand/images/icons/carousel_r.png");
    background-position: center center;
    background-repeat: no-repeat;
}

.slick-prev::before, .slick-next::before {
    color: #43a6cf;
    opacity: 1;
}

.slick-next {
    right: 0;
}

.no-js-features {
    position: relative;
    z-index: 2;
}

.js-features {
    z-index: 1;
}

#calendar th, #calendar td, .septych {
    width: 14.29%
}

#calendar td {
    height: 50px;
    position: relative;
}

#calendar td span.day {
    font-size: 12px;
    left: 2px;
    position: absolute;
    top: 2px;
}

#calendar td span.events a {
    background: rgba(0, 0, 0, 0) url("/rebrand/images/icons/blue/ico-ticket.png") no-repeat no-repeat top 10px center;
    display: block;
    font-size: 14px;
    font-weight: 700;
    height: 20px;
    margin-right: 10px;
    text-align: center;
    padding: 30px 0 0 0;
    width: 100%;
}

#calendar td span.events a {
    text-decoration: none;
}

#calendar td.empty {
    background-color: #f0f0f0;
}

#calendar td:hover[id^=day] {
    background-color: #f5ffff;
}

/*** JavaScript Datepicker ***/
select#date_day, select#date_month, select#date_year {
    width: auto;
}

#calendarSubmit {
    margin-top: -1px;
}

div.wgt-calendar-picker {
    border: 3px solid #43a6cf;
    background-color: #fff;
    font-size: 11px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    -moz-box-shadow: 1px 1px 10px rgba(0, 0, 0, .3);
    -webkit-box-shadow: 1px 1px 10px rgba(0, 0, 0, .3);
    box-shadow: 1px 1px 10px rgba(0, 0, 0, .3);
    margin: 5px auto;
    width: 160px;
}

div.wgt-calendar-control {
    position: relative;
    font: bold 12px/22px sans-serif;
    background-color: #43a6cf;
    color: #fff;
    -moz-border-radius: 1px;
    -webkit-border-radius: 1px;
    border-radius: 1px;
    cursor: default;
}

div.wgt-calendar-control th {
    color: #fff;
}

div.wgt-calendar-control div {
    position: absolute;
    top: 2px;
    font-size: 10px;
    line-height: 20px;
    font-weight: bold;
    letter-spacing: -2px;
    width: 20px;
    text-align: center;
    border: 1px solid #43a6cf;
    cursor: pointer;
    text-indent: 30px;
    overflow: hidden;
}

div.wgt-calendar-control div:hover {
    border-color: #2a8dB6;
    background-color: #2a8dB6;
}

div.wgt-calendar-prev-month {
    left: 2px;
    background: url(//cdn.wegottickets.com/www/images/control_playback_blue.png) 50% 50% no-repeat
}

div.wgt-calendar-prev-year {
    left: 2px;
    background: url(//cdn.wegottickets.com/www/images/control_rewind_blue.png) 50% 50% no-repeat
}

div.wgt-calendar-next-month {
    right: 2px;
    background: url(//cdn.wegottickets.com/www/images/control_play_blue.png) 50% 50% no-repeat
}

div.wgt-calendar-next-year {
    right: 2px;
    background: url(//cdn.wegottickets.com/www/images/control_fastforward_blue.png) 50% 50% no-repeat
}

table.wgt-calendar-days th {
    border: 1px solid #43a6cf;
    cursor: default;
    width: 22px;
    height: 22px;
}

table.wgt-calendar-month td {
    border: 1px solid #43a6cf;
    cursor: pointer;
    width: 22px;
    height: 22px;
    line-height: 22px;
}

table.wgt-calendar-month td:hover, table.wgt-calendar-month td.selected {
    border: 1px solid #43a6cf;
    background: #43a6cf;
    color: #fff;
}

table.wgt-calendar-month td.today {
    border: 1px solid #43a6cf;
}

table.wgt-calendar-month td.blocked {
    color: #ccc;
    border-color: #43a6cf;
    background: #f0f0f0;
    cursor: default;
}

button.wgt-calendar-button {
    background: url(//cdn.wegottickets.com/www/images/calendar.png) 50% 50% no-repeat;
    border: 1px solid #43a6cf;
    -moz-border-radius: 2px;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    width: 20px;
    height: 20px;
    vertical-align: middle;
    background-color: #fff;
    margin: 0 3px;
    cursor: pointer;
}

button.wgt-calendar-button:hover {
    border: 1px solid #2a8db6;
    background-color: #f0f0f0;
}

.relative {
    position: relative;
}

#bookingFeeFAQClose {
    position: absolute;
    right: 2px;
    top: 8px;
}

/*### PAGINATION ###*/
a.pagination_link, span.pagination_current, a.pagination_link_text {
    background: transparent;
    border: 0;
    color: #fff;
    display: inline-block;
    height: 16px;
    line-height: 16px;
    min-width: 16px;
    padding: 3px;
    text-align: center;
}

a.pagination_link:hover, a.pagination_link_text:hover, span.pagination_current {
    background: #fff;
    color: #000;
    text-decoration: none;
}

.event-image img {
    display: block;
    margin: 10px 0px 0px 0px;
    width: 100%;
    max-width: 825px;
}

#cookie_agreement {
    background-color: #eeeeee;
    background-image: linear-gradient(to bottom, #eeeeee 0px, #dddddd 100%);
    background-repeat: repeat-x;
    border-color: #cccccc;
    box-shadow: 0 0 2px #777;
    left: 0;
    padding: 2px 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000000000;
}

#cookie_agreement p {
    color: #666;
    display: block;
    margin: 0 auto;
    max-width: 1000px;
    text-align: left;
    font-size: 14px;
}

#cookie_agreement p strong {
    color: #fff;
    font-weight: bold;
}

#cookie_agreement a {
    color: #fff !important;
}

#agree_to_cookies {
    display: block;
    float: right;
    position: relative;
    right: 25px;
}

#agree_to_cookies button {
    display: none;
}

.concession {
    background-color: transparent;
    border-color: transparent;
    text-decoration: none;
    text-transform: uppercase;
    font-size: 1.33em;
    color: black;
    font-family: Museo-300, Helvetica, Arial, sans-serif;
}

.small-hidden, label.small-hidden {
    display: none;
}

label.Required {
    position: relative;
}

label.Required:after {
    content: '*';
    display: block;
    position: absolute;
    right: 1px;
    top: 0;
    color: #d6e3e8;
}

.nodisplay {
    display: none;
}

/* 'Terms and Conditions' and 'Privacy Policy' blocks shown on the customer register form */
.tandc-block,
.ppl-block {
    padding: 0 10px;
    height: 250px;
    overflow-y: scroll;
    background: #e6e6e6;
    border: 1px solid #ccc;
}

.tandc-block .neutral-filled,
.ppl-block .neutral-filled {
    background-color: #999;
}

.trender .date {
    -webkit-box-shadow: 0 3px 2px 1px rgba(85, 85, 85, 0.6);
    -moz-box-shadow: 0 3px 2px 1px rgba(85, 85, 85, 0.6);
    box-shadow: 0 3px 2px 1px rgba(85, 85, 85, 0.6);
    border-top: 0;
    font-size: 12px;
    font-weight: 700;
    height: 32px;
    left: 16px;
    padding: 4px;
    position: absolute;
    text-align: center;
    top: 5px;
    width: 32px;
}

.social-icons {
    padding: 10px 0 5px 0;
    text-align: center;
}

.social-icons a {
    padding: 0 5px;
}

.social-icons a img {
    opacity: 0.4;
}

.social-icons a:hover img {
    opacity: 1;
}

.social-icons a:hover {
    text-decoration: none;
}

.mobile-menu {
    margin: 0 -10px;
}

.mobile-menu a {
    background-position: center 11px;
    background-repeat: no-repeat;
    display: block;
    height: 44px;
    text-align: center;
    width: 100%;
}

.mobile-menu a:hover, .mobile-menu a.active {
    background-color: #43a6cf;
    color: #fff;
    text-decoration: none;
}

.mobile-menu a.environ {
    background-image: url("/rebrand/images/icons/blue/ico-enviro.png");
}

.mobile-menu a.environ:hover, .mobile-menu a.environ.active {
    background-image: url("/rebrand/images/icons/white/ico-enviro.png");
}

.mobile-menu a.fees {
    background-image: url("/rebrand/images/icons/blue/ico-pig.png");
}

.mobile-menu a.fees:hover, .mobile-menu a.fees.active {
    background-image: url("/rebrand/images/icons/white/ico-pig.png");
}

.mobile-menu a.goodcauses {
    background-image: url("/rebrand/images/icons/blue/ico-heart.png");
}

.mobile-menu a.goodcauses:hover, .mobile-menu a.goodcauses.active {
    background-image: url("/rebrand/images/icons/white/ico-heart.png");
}

.mobile-menu a.organisers {
    background-image: url("/rebrand/images/icons/blue/ico-group.png");
}

.mobile-menu a.organisers:hover, .mobile-menu a.organisers.active {
    background-image: url("/rebrand/images/icons/white/ico-group.png");
}

.mobile-menu a.us {
    background-image: url("/rebrand/images/icons/blue/ico-about.png");
}

.mobile-menu a.us:hover, .mobile-menu a.us.active {
    background-image: url("/rebrand/images/icons/white/ico-about.png");
}

.homepage-warning {
    background-color: #E82E66;
    color: #fff;
    margin-left: -10px;
    margin-top: -14px;
    width: calc(100% - 30px);
    padding: 20px 20px 5px 30px;
    font-size: large;
    font-weight: bold;
}

.homepage-warning-ico{
    background-image: url("/rebrand/images/icons/white/ico-warning.svg");
    width: 30px;
    height: 30px;
    float: left;
    margin: 30px;
}

.homepage-success {
    background-color: #8CB63C;
    color: #fff;
    margin-left: -10px;
    margin-top: -14px;
    width: calc(100% - 30px);
    padding: 20px 20px 1px 30px;
    font-size: large;
    font-weight: bold;
}

.homepage-success-ico{
    background-image: url("/rebrand/images/icons/white/ico-info-new.svg");
    width: 30px;
    height: 30px;
    float: left;
    margin: 20px 30px 20px 30px;
}

.eventpage-warning {
    background-color: #E82E66;
    color: #fff;
    margin-left: -10px;
    margin-top: 0;
    width: calc(100% - 30px);
    padding: 25px;
    font-size: large;
    font-weight: bold;
}

.eventpage-warning:empty {
    display: none;
}

@media only screen and (min-width: 480px) {
    .sub-nav li {
        margin-left: 3px;
    }

    .sub-nav li a.login {
        background-image: url("/rebrand/images/icons/white/ico-user.png");
    }

    .sub-nav li a.register {
        background-image: url("/rebrand/images/icons/white/ico-register.png");
    }

    .sub-nav li a.basket {
        background-image: url("/rebrand/images/icons/white/ico-basket.png");
    }

    .sub-nav li a.logout {
        background-image: url("/rebrand/images/icons/white/ico-cancel.png");
    }

    .sub-nav li a.tickets {
        background-image: url("/rebrand/images/icons/white/ico-ticket.png");
    }

    .sub-nav li a.basket, .sub-nav li a.login, .sub-nav li a.logout, .sub-nav li a.tickets, .sub-nav li a.register {
        background-position: 7px 6px;
        background-repeat: no-repeat;
        padding: 10px 15px 10px 35px;
    }


}

@media only screen and (min-width: 768px) {
    #search-form {
        position: absolute;
        bottom: 10px;
        right: 10px;
    }

    #ticketsButton {
        padding: 10px 40px 10px 40px;
        width: initial;
    }

    .logo img {
        min-width: 230px;
    }

    h3.profile-title {
        font-size: 22px;
    }

    .sub-nav {
        display: block;
    }

    .sub-nav ul {
        float: right;
        width: auto;
    }

    .sub-nav ul:last-child {
        margin: 0 0 5px;
    }

    .sub-nav li {
        float: left;
    }

    .sub-nav li a {
        padding: 10px;
    }

    #mobile-nav {
        display: none;
    }

    .block-header-search {
        text-align: right;
    }

    .block-group.block-group-flex:before,
    .block-group.block-group-flex:after {
        display: inherit;
        content: "";
        line-height: 0;
    }

    .block-group.block-group-flex {
        display: flex;
        flex-wrap: wrap;
    }

    #footer {
        padding: 50px 0 0 0;
    }

    .event-image img {
        margin: 10px 0px 0px 0px;
        width: 100%;
    }

    .full-width-mobile {
        width: auto;
    }

    .event-width {
        width: 100%;
    }

    .form-row.diptych:nth-child(2n+1) {
        padding-right: 5px;
    }

    .links a {
        color: #fff;
    }

    .links ul {
        padding: 0;
    }

    .links a:hover {
        color: #2A8DB6;
    }

    .logo {
        padding: 0 10px 5px;
        text-align: left;
    }

    .leaderboard, .bottomboard {
        height: 90px;
        max-width: 728px;
    }

    /*** Section for hiding/showing at different viewports ***/
    .small-hidden, label.small-hidden {
        display: block;
    }

    .medium-hidden, label.medium-hidden {
        display: none;
    }

    /*** Sizing for pocketgrid ***/
    .diptych {
        width: 50%;
        margin: 0;
    }

    .block-group.block-group-flex > .diptych {
        flex: 0 0 50%;
    }

    .triptych {
        width: 33.333333333%;
        margin: 0;
    }

    .block-group.block-group-flex > .triptych {
        flex: 0 0 33.333333333%;
    }

    .form-buttons-margin .triptych {
        margin: 0;
    }

    .quadtych {
        width: 25%;
        margin: 0;
    }

    .block-group.block-group-flex > .quadtych {
        flex: 0 0 25%;
    }

    .star {
        text-align: left;
    }

    /** Newsletter styles **/
    #newsletter {
        color: #43a6cf;
        display: block;
        padding: 80px 0 20px 0;
        text-align: center;
        position: relative;
    }

    #newsletter span.icon {
        background: url('/rebrand/images/icons/footer-newsletter.png') no-repeat transparent;
        height: 68px;
        left: 0;
        margin-left: auto;
        margin-right: auto;
        position: absolute;
        right: 0;
        top: -34px;
        width: 68px;
    }

    #newsletter form {
        margin-top: 20px;
    }

    #newsletter input[name="ml_email"] {
        width: 528px;
    }

    .content.profile-image-wrapper {
        margin-bottom: 5px;
    }

    .slick-dots li, .slick-dots li button, .slick-dots li button::before {
        width: 20px;
    }

    .ad-banner {
        height: 110px;
    }

    .mobile-menu a {
        height: 60px;
    }

    .mobile-menu span {
        clear: both;
        padding-top: 36px;
        vertical-align: bottom;
        width: 100%;
    }

    table#variantdetails td.right{
        min-width: 250px;
    }
}

@media only screen and (min-width: 991px) {
    .homepage-divider {
        height: 25px;
    }

    .social-icons {
        padding: 0 0 40px 0;
        text-align: center;
    }

    .desktop-hidden {
        display: none;
    }

    .search {
        float: right;
    }

    .bottomboard {
        display: none;
    }

    .ChatterBox {
        background-color: #fff;
        margin: 0 0 15px;
        padding: 10px 0;
        width: 100%;
    }

    .ChatterBox blockquote {
        margin: 0 10px;
    }

    .ChatterBox h4 {
        color: #43a6cf;
        font-size: 14px;
        font-weight: 400;
    }

    .ChatterBox img {
        display: block;
    }

    .desktop-third {
        width: 33.3%;
    }

    /*** Section for hiding/showing at different viewports ***/
    #WrapperInner {
        margin-top: 20px;
    }

    /* Navigation layout on larger screens */
    #Page {
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        padding: 0 15px;
        margin-right: -315px;
    }

    #Content {
        margin-right: 315px;
    }

    #RightColumn {
        display: block;
        width: 300px;
        float: left;
    }

    /** THERMOMETER **/
    .thermometer {
        width: 100%;
        margin-bottom: 16px;
    }

    /* group thermometer */
    h2.thermometer-overlay {
        color: #0a96c7;
        position: absolute;
        width: 300px;
        z-index: 1;
        text-align: center;
        height: 5em;
        vertical-align: middle;
        padding: 16px;
        margin: 0;
        box-sizing: border-box;
    }

    /* musicians against homelessness */
    .thermometer.donation406200 #therm-empty .marker,
    .thermometer.donation406200 #therm-empty #therm-total {
        color: black !important;
    }

    .thermometer.donation406200 #therm-empty {
        background-image: url(/rebrand/images/thermometer-empty-blue.png);
    }

    .thermometer.donation406200 #therm-full {
        background-image: url(/rebrand/images/thermometer-full-pink.png);
    }

    #therm-empty {
        background: url(/rebrand/images/thermometer-empty.png) no-repeat;
        height: 463px;
        margin: 0 auto;
        position: relative;
        width: 100%;
    }

    #therm-full {
        background: url(/rebrand/images/thermometer-full.png) bottom left no-repeat;
        bottom: 0;
        position: absolute;
        width: 100%;
    }

    #therm-empty .marker {
        color: #43a6cf;
        font: 8pt arial;
        right: 95px;
        position: absolute;
        width: 40px;
    }

    #therm-empty .marker span {
        float: right;
    }

    #therm-total {
        color: #43a6cf;
        font: 8pt arial;
        margin-bottom: -6px;
        position: absolute;
        left: 87px;
        text-align: right;
        width: 50px;
    }
}

ul.values li.environ {
    background: url("/rebrand/images/icons/blue/ico-enviro.png") no-repeat scroll 8px 5px;;
}

ul.values li.fees {
    background: url("/rebrand/images/icons/blue/ico-pig.png") no-repeat scroll 8px 5px;;
}

ul.values li.goodcauses {
    background: url("/rebrand/images/icons/blue/ico-heart.png") no-repeat scroll 8px 5px;;
}

ul.values li.organisers {
    background: url("/rebrand/images/icons/blue/ico-group.png") no-repeat scroll 8px 5px;;
}

ul.values li.us {
    background: url("/rebrand/images/icons/blue/ico-about.png") no-repeat scroll 8px 5px;
}

@media only screen and (min-width: 1180px) {
    ul#AboutUs {
        text-align: right;
    }

    #AboutUs li:first-child {
        width: auto;
    }

    #AboutUs li a {
        margin-top: 14px;
        margin-bottom: 0;
    }
}

.hideItRealGood {
    display: none;
}

::-ms-reveal,
::-ms-clear {
    display: none !important;
}

.hideShowPassword-toggle {
    background-color: transparent;
    background-image: url('/images/wink.png');
    background-position: 0 center;
    background-repeat: no-repeat;
    border: 2px solid transparent;
    border-radius: 0.25em;
    cursor: pointer;
    font-size: 100%;
    height: 44px;
    margin: 0;
    max-height: 100%;
    padding: 15px;
    overflow: hidden;
    text-indent: -999em;
    width: 46px;
    -moz-appearance: none;
    -webkit-appearance: none;
}

.hideShowPassword-toggle-hide {
    background-position: -44px center;
}

.hideShowPassword-toggle:hover,
.hideShowPassword-toggle:focus {
    border-color: #0088cc;
    outline: transparent;
}

.hideShowPassword-wrapper{
    width: auto !important;
    display: block !important;
}

#customerLoginWarning {
    display: block;
    margin: 10px 0 0 0;
    text-align: center;
    text-decoration: none;
}

#customerLoginWarning h2 {
    border: 1px solid #43a6cf;
    margin: 0;
    padding: 1em;
}

#contactFAQsNotice {
    margin: 0 -10px 0 -10px;
    width: 100%;
}

#contactFAQsNotice h2 {
    background-color: #43a6cf;
    color: #fff;
    padding: 0.5em;
    margin: 0 -10px;
}

.no-wrap {
    white-space: nowrap;
}

.warning-message {
    padding: 10px;
    width: 100%;
    background-color: #E82E66;
    margin-left: -10px;
    text-align: center;
}

.warning-message h4 {
    color: white;
}

.warning-message a {
    color: white;
    text-decoration: underline;
}

.VariantAlert:not(:empty) { /* this element appears even when empty - don't show a pink square when empty */
    background-color: #e82e66;
    color: white;
    font-size: 16px;
    padding: 0.5em;
    width: auto;
}

.stayinformed-block {
    padding: 0 10px;
}

.doorTime {
    font-size: 16px;
}

.secondaryInformation {
    color: black;
}

.map-responsive {
    box-sizing: border-box;
    overflow: hidden;
    padding-bottom: 56.25%;
    position: relative;
    height: 450px;
}

.map-responsive iframe {
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    position: absolute;
}

/* for when you want multiple page 'bodies' use a background-coloured separator to fake it */
.body-separator {
    background-color: #ebebeb;
    width: calc(100% + 20px);
    height: 16px;
    left: -10px;
    position: relative;
}

.margin-bottom {
    margin-bottom: 10px;
}

.two-thirds {
    width: 66.66%;
}

#register h1 {
    font-size: 20px;
}