/* fonts */
@font-face {
    font-family: 'FGD';
    src: url('fradm.eot');
    src: url('fradm.eot?#iefix') format('embedded-opentype'),
         url('fradm.woff') format('woff'),
         url('fradm.ttf') format('truetype'),
         url('fradm.svg#fradm') format('svg');
    font-weight: normal;
    font-style: normal;
}

/* meyer reset */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { border: 0; font: inherit; font-size: 100%; margin: 0; padding: 0; vertical-align: baseline; }
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
body { line-height: 1; }
ol, ul { list-style: none; }
blockquote, q { quotes: none; }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
table { border-collapse: collapse; border-spacing: 0; }


/* core */
a { border-bottom: 1px dashed #900; color: #900; text-decoration: none; }
a:hover { border-bottom: 1px solid #900; }
body { background: #e49c00; color: #222; font: 13px/1.5 sans-serif; padding: 0 8px; }
em { font-style: italic; }
h1 { color: #000; clear: both; font-family: FGD, sans-serif; font-size: 40px; letter-spacing: -1px; line-height: 1.02; margin: 4px 0 6px; }
h2 { color: #000; clear: both; font-family: FGD, sans-serif; font-size: 32px; letter-spacing: -1px; line-height: 1.02; margin: 12px 0 6px; }
h3 { color: #000; clear: both; font-family: FGD, sans-serif; font-size: 24px; letter-spacing: -1px; line-height: 1.02; margin: 12px 0 6px; }
input { -webkit-appearance: none; }
p { color: #000; font-size: 14px; line-height: 20px; padding-bottom: 16px; }
section { float: right; text-align: left; width: 71%; }
strong { font-weight: bold; }
#container { margin: 0 auto; max-width: 960px; }
#outer { background: #fc0; margin: 0 -8px; padding: 0 8px; }
#inner { margin: 0 auto; max-width: 960px; overflow: auto; padding: 4px 0 20px; }
.center { text-align: center;}
.leftColumn { float: left; width: 48%; }
.rightColumn { float: right; width: 48%; }
.topGap { clear: both; padding-top: 25px; }
.transparent {
    -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
    filter: alpha(opacity=30);
    -moz-opacity:0.3;
    -khtml-opacity: 0.3;
    opacity: 0.3;
}
@media screen and (max-width: 680px) {
    h1 { font-size: 32px; }
    section { float: none; padding: 0 6px; width: auto; }
    .topGap { padding-top: 40px; }
}
@media screen and (max-width: 400px) {
    h1 { font-size: 28px; padding-top: 5px; }
    h2 { font-size: 26px; }
    section p { font-size: 17px; }
}


/* my account */
#account { background: #000; line-height: 1.1; margin: 0 -8px; padding: 8px 20px; overflow: auto; text-align: center; }
#account a { color: #fff; border: 0; text-decoration: none; }
#account a:hover { color: #fc0; }
#account table { float: right; }
#account td { border-left: 1px solid #444; padding: 0 11px; text-align: center; vertical-align: middle; }
#account td:first-child { border-left: 0; }
#accountEmail { color: #ccc; float: left; }
@media screen and (max-width: 440px) {
    #account { padding: 10px 4px; }
    #account table { width: 100%; }
    #account td { padding: 0 7px; width: 50%; }
    #accountEmail { display: none; }
}


/* header */
header { margin: 0 auto; max-width: 960px; text-align: center; }
header h1, header h2 { display: none; }
#logoLink, #logoLink:hover { border: 0; display: block; overflow: hidden; }
#logoCall { background: #e49c00; border-bottom: 0; border-radius: 10px; display: block; margin: -2px 3% 2px; overflow: hidden; padding: 8px; }
@media screen and (max-width: 950px) { #logoCall { margin: -2px 1% 2px; } }
@media screen and (max-width: 900px) { #logoCall { margin: -2px 0 2px; } }
#logoCall img { display: block; width: 100%; }
#logoWide { vertical-align:text-bottom; max-width: 861px; width: 100%; }
#logoNarrow { display: none; width: 100%; }
@media screen and (max-width: 600px) {
    #logoWide { display: none; }
    #logoNarrow { display: block; }
}


/* homepage: booking */
#homepageHeadline { margin-top: 2px; }
#homepageBooking div { background: #f4b900; cursor: pointer; float: left; min-height: 116px; position: relative; text-align: center; width: calc(50% - 1px); }
#homepageBooking div:hover { background: #e49c00; }
#homepageBooking div div { background: black; bottom: 0; height: 15px; min-height: 15px; overflow: hidden; position: absolute; width: 100%; }
#homepageBooking div div:hover { background: black; }
#homepageBooking div span { background: #e50000 url('../images/homepageArrow.png') no-repeat right top; border-radius: 3px 3px 0 0; bottom: 0; color: #fff; font-size: 12px; left: 8px; line-height: 14px; padding: 4px 18px 2px 8px; position: absolute; text-transform: uppercase; }
#homepageBooking div:hover span { padding-bottom: 6px; }
#homepageBooking h2 { font-size: 28px; margin: 8px 0 4px; }
#homepageBooking p { font-size: 13px; line-height: 1.2; margin: 0 16px; }
#homepageBooking1 { border-radius: 8px 0 0 8px; border-right: 1px solid #fc0; }
#homepageBooking1 div { border-radius: 0 0 0 8px; }
#homepageBooking3 { border-left: 1px solid #fc0; border-radius: 0 8px 8px 0; }
#homepageBooking3 div { border-radius: 0 0 8px 0; }
@media screen and (max-width: 900px) {
    #homepageBooking h2 { font-size: 26px; }
    #homepageBooking p { margin: 0 4px; }
}
@media screen and (max-width: 550px) {
    #homepageBooking div { min-height: 120px; }
    #homepageBooking h2 { font-size: 22px; }
    #homepageBooking p { margin: 0 12px; }
}
@media screen and (max-width: 440px) {
    #homepageBooking div { margin-top: 8px; min-height: 50px; width: 100%; }
    #homepageBooking h2 { font-size: 26px; }
    #homepageBooking p { font-size: 16px; margin: 0 12px 12px; }
    #homepageBooking1,
    #homepageBooking2,
    #homepageBooking3 { border-radius: 8px; border-right: 0; }
    #homepageBooking1 { margin-top: 0px !important; }
    #homepageBooking1 div, #homepageBooking2 div, #homepageBooking3 div { border-radius: 0 0 8px 8px; }
}


/* homepage: carousel */
#homepageCarousel { border-top: 18px solid #fc0; clear: both; }
#homepageCarouselBody { background: #f4b900; border-radius: 8px; }
#homepageCarouselBody div { display: none; height: 264px; padding: 12px; position: relative; }
#homepageCarouselBody div:first-child { display: block; }
#homepageCarouselBody div div { bottom: 4px; display: block; height: auto; padding: 0; position: absolute; width: auto; }
#homepageCarouselBody div div a { background: #e50000 url('../images/homepageArrow.png') no-repeat right 4px; border-bottom: none; border-radius: 3px 3px 0 0; color: #fff; cursor: pointer; font-size: 13px; line-height: 14px; margin-left: 6px; padding: 6px 20px 6px 10px; text-transform: uppercase; }
#homepageCarouselBody h2 { margin-top: 0; width: 85%; }
#homepageCarouselBody p { width: 55%; }
#homepageCarouselApp { background: url('../images/homepageApp.jpg') no-repeat 100% 50%; }
#homepageCarouselApp table { margin: 18px 0; width: 100%; }
#homepageCarouselApp td { text-align: center; width: 50% !important; }
#homepageCarouselApp a { border-bottom: none; }
#homepageCarouselLoyalty { background: url('../images/homepageLoyalty.png') no-repeat 110% 110%; }
#homepageCarouselBeesafe { background: url('../images/homepageBeesafe.png') no-repeat 98% 100%; }
#homepageCarouselPrices { background: url('../images/homepagePrices.png') no-repeat 100% 100%; }
#homepageCarouselFeedback q { color: #000; clear: both; display: block; font-size: 15px; font-style: italic; line-height: 21px; margin-bottom: 8px; width: 95%; }
#homepageCarouselFeedback p span { font-family: serif; font-size: 20px; line-height: 21px;}
#homepageCarouselDots { padding: 5px; text-align: center; }
#homepageCarouselDots span { background: url('../images/homepageDot.png'); cursor: pointer; display: inline-block; height: 14px; margin: 2px; overflow: hidden; width: 14px; }
#homepageCarouselDots span.selected { background: url('../images/homepageDotSelected.png'); cursor: normal; }
@media screen and (max-width: 800px) {
    #homepageCarouselLoyalty { background: url('../images/homepageLoyalty.png') no-repeat 120% 120%; }
}
@media screen and (max-width: 680px) {
    #homepageCarouselBody > div { border-bottom: 4px solid #fc0; }
    #homepageCarouselBody div { background-image: none; display: block; height: auto; }
    #homepageCarouselBody h2 { font-size: 24px; width: 100%; }
    #homepageCarouselBody p { width: 100%; }
    #homepageCarouselBody p { padding-bottom: 30px; }
    #homepageCarouselDots { display: none; }
}
@media screen and (max-width: 360px) {
    #homepageCarouselBody div div a { font-size: 12px; line-height: 13px; margin-left: 2px; padding: 6px 18px 6px 6px; }
}
@media screen and (max-width: 300px) {
    #homepageCarouselBody div { height: auto; }
    #homepageCarouselBody div div a { background-image: none; font-size: 10px; line-height: 11px; margin-left: 0; padding: 6px 4px; }
}


/* homepage: sidebar */
#homepageSidebar { clear: left; float: left; padding: 0; width: 27%; }
#homepageSidebar div div { background: #f4b900; margin: 0; padding: 8px; }
#homepageSidebar div div:first-child { border-bottom: 1px solid #fc0; border-radius: 8px 8px 0 0; padding-bottom: 0; }
#homepageSidebar div div:last-child { border-radius: 0 0 8px 8px; padding-bottom: 8px; }
#homepageSidebar div div:last-child:hover { background: #e49c00; }
#homepageSidebar h2 { font-size: 28px; line-height: 1.05; margin: 0; }
#homepageSidebar p { font-size: 13px; line-height: 1.4; padding-bottom: 12px; }
@media screen and (max-width: 680px) {
    #homepageSidebar { display: none; width: 100%; }
    #homepageSidebar h2 { margin-bottom: 6px; }
    #homepageSidebar p { font-size: 14px; padding-bottom: 8px; }
}
@media screen and (max-width: 400px) {
    #homepageSidebar p { font-size: 16px; padding-bottom: 6px; }
}


/* homepage: cards */
#homepageCards { clear: both; font-size: 13px; margin-bottom: -4px; padding: 8px 6px 0; text-align: center; }
#homepageCards img { height: 32px; width: 471px; }
@media screen and (max-width: 327px) {
    #homepageCards img { height: auto; margin: 5px 0; width: 100%; }
}

/* navigation */
nav { clear: left; float: left; padding: 0; width: 27%; }
nav * { background: #f4b900; border-bottom: 1px solid #fc0; color: #000; cursor: pointer; display: block; font-size: 15px; padding: 4px 5px 4px 8px; text-decoration: none; }
nav *:hover, #navigation .selected { background: #e49c00; border-bottom: 1px solid #fc0; font-weight: bold; }
nav *:first-child { border-radius: 8px 8px 0 0; padding-top: 7px; }
nav *:last-child { border-radius: 0 0 8px 8px; padding-bottom: 7px; }
@media screen and (max-width: 680px) {
    #navigation { display: none; }
}


/* book now */
#booknow { background: #000; border-radius: 8px; float: left; margin-bottom: 6px; text-align: center; width: 27%; }
#booknow div { padding: 3px 7px 7px 7px; }
#booknow div a { background: #a00; border: 0; border-radius: 7px; color: #fff; cursor: pointer; display: block; font-size: 19px; font-weight: bold; line-height: 1.2; margin-top: 3px; padding: 5px 12px; text-decoration: none; text-transform: uppercase; }
#booknow div a:hover { background: #600; color: #ff0; }
#booknow div span { color: #fff; font-family: FGD, sans-serif; font-size: 26px; letter-spacing: -1px; line-height: 1.1; }
#bookmark { background: #e49c00; border-radius: 8px; float: left; margin-bottom: 6px; text-align: center; width: 27%; }
#bookmark div { padding: 7px; }
#bookmark div span { color: #000; font-family: FGD, sans-serif; font-size: 19px; letter-spacing: 0px; line-height: 1.1; }
@media screen and (max-width: 800px) {
    #booknow div span { font-size: 19px; letter-spacing: 0; }
}
@media screen and (max-width: 680px) {
    #booknow, #bookmark {width: 100%; }
    #booknow div a { padding: 12px 5px; }
    #booknow div span { font-size: 17px; letter-spacing: 0; }
}
@media screen and (max-width: 600px) {
    #booknow, #bookmark { margin-top: 5px; }
    #booknow div span { font-size: 16px;  }
    .leftColumn, .rightColumn { font-size: 15px; width: 100%; }
}
@media screen and (max-width: 400px) {
    #booknow div span { font-size: 18px; }
    .leftColumn, .rightColumn { width: 100%; }
}


/* forms */
label { color: #000; display: block; float: left; font-size: 16px; font-weight: bold; line-height: 1; padding: 10px 0 0; text-align: right; width: 38%; }
label span { display: block; font-size: 12px; }
input[type=date],
    input[type=email],
    input[type=password],
    input[type=tel],
    input[type=text],
    textarea { border: 1px solid #000; border-radius: 5px; float: right; font-size: 16px; font-weight: bold; padding: 5px; width: 57%; }
input[type=button], input[type=submit] { background: #900; border: 1px solid #000; border-radius: 6px; color: #fff; cursor: pointer; float: right; font-size: 19px; font-weight: bold; margin-top: 4px; padding: 5px 20px; text-transform: uppercase; white-space: normal; }
input[type=button]:hover, input[type=submit]:hover { background: #600; color: #ff0; }
input[type=checkbox] { -webkit-appearance: checkbox; }
select { border: 1px solid #000; border-radius: 5px; font-size: 16px; font-weight: bold; padding: 5px; }
textarea { font-family: sans-serif; font-size: 16px; font-weight: bold; height: 70px; }
textarea.comments { height: 100px; }
.formField { margin-bottom: 5px; overflow: auto; }
@media screen and (max-width: 820px) {
    form .leftColumn, form .rightColumn { width: 100%; }
    label { margin-right: 1%; }
    input[type=date],
        input[type=email],
        input[type=password],
        input[type=tel],
        input[type=text],
        textarea { float: left; width: 50%; }
    input[type=submit] { float: left; margin-left: 39%; width: 35%; }
}
@media screen and (max-width: 680px) {
    label { margin-right: 1%; width: 28%; }
    input[type=date],
        input[type=email],
        input[type=password],
        input[type=tel],
        input[type=text],
        textarea { width: 62%; }
    input[type=submit] { margin-left: 29%; width: 42%; }
}
@media screen and (max-width: 400px) {
    .formField { margin-bottom: 2px; }
    label { margin: 0; padding: 7px 0 0; text-align: left; width: 100%; }
    label span { display: inline; }
    input[type=date],
        input[type=email],
        input[type=password],
        input[type=tel],
        input[type=text],
        textarea { padding: 10px 2.5%; width: 94%; }
    input[type=submit] { margin: 15px 0 0 0; width: 100%; }
}


/* wide form */
form.wide label { width: 22%; }
form.wide input[type=date],
    form.wide input[type=email],
    form.wide input[type=password],
    form.wide input[type=tel],
    form.wide input[type=text],
    form.wide textarea { float: left; margin-left: 1%; width: 60%; }
form.wide p { clear: both; margin-left: 23%; padding-bottom: 0; }
form.wide input[type=submit] { float: left; margin-left: 23%; }
form.wide select { float: left; margin-left: 1%; }
form.wide table { float: left; margin-left: 1%; }
form.wide .formFieldRemember { padding: 2px 0 4px 23%; }
form.wide .formFieldRemember label { display: inline; float: none; font-weight: normal; width: auto; }
select.wide { width: 75%; }
@media screen and (max-width: 900px) {
    form.wide label { text-align: left; width: 100%; }
    form.wide input[type=date],
        form.wide input[type=email],
        form.wide input[type=password],
        form.wide input[type=tel],
        form.wide input[type=text],
        form.wide textarea { margin-left: 0; padding: 5px 1%; width: 97%; }
    form.wide p { margin-left: 0; }
    form.wide input[type=submit] { float: left; margin-left: 0; }
    form.wide select { margin-left: 0; }
    form.wide table { margin-left: 0; }
    form.wide .formFieldRemember { padding-left: 0; }
    select.wide { width: 99%; }
}
@media screen and (max-width: 400px) {
    form.wide input[type=date],
        form.wide input[type=email],
        form.wide input[type=password],
        form.wide input[type=tel],
        form.wide input[type=text] { padding: 10px 2.5%; width: 94%; }
    form.wide textarea { padding: 10px 2.5%; width: 92%; }
    form.wide input[type=submit] { width: 99%; }
    form.wide .formFieldRemember { padding-top: 8px; }
    select.wide { width: 100%; }
}


/* booking form */
#bookingTime { white-space: nowrap; }
#bookingConfirm div { color: #000; font-size: 16px; font-weight: bold; }
#bookingConfirm .bookingConfirmLeft { float: left; text-align: right; width: 34%; }
#bookingConfirm .bookingConfirmRight { float: right; width: 65%; }
#bookingConfirm input, #bookingConfirm p { margin: 20px 0; }
#bookingConfirm p { font-weight: normal; }
@media screen and (max-width: 500px) {
    #bookingConfirm .bookingConfirmLeft  { float: none; font-weight: normal; margin: 0 0 -6px 10px; text-align: left; width: 95%; }
    #bookingConfirm .bookingConfirmRight  { float: none; margin: 0 0 6px 10px; text-align: left; width: 95%; }
    #bookingConfirm input, #bookingConfirm p { margin: 10px 0 20px; width: 100%; }
}


/* topup form */
form.topup label { width: 50%; }
form.topup input[type=text] { float: left; margin-left: 1%; width: 45%; }
form.topup select { float: left; margin-left: 1%; min-width: 150px; }
.topupPayButton { margin-left: 51%; }
.topupPayButton input { float: left; }
.topupPayButton p { clear: both; padding-top: 10px; }
@media screen and (max-width: 860px) {
    form.topup label { text-align: left; width: 100%; }
    form.topup input[type=text] { margin-left: 0; width: 97%; }
    form.topup select { margin-left: 0; }
    .topupPayButton { margin: 8px 0 0 0; }
    .topupPayButton input { margin-left: 0; width: auto; }
}
@media screen and (max-width: 500px) {
    form.topup input[type=text] { padding: 5px 2%; width: 95%; }
    form.topup select { margin-left: 0; width: 100%; }
    .topupPayButton { margin: 8px 0 0 0; }
    .topupPayButton input { margin: 8px 0 8px 0; width: 100%; }
}


/* topup */
#topup { margin: -12px 0 12px; text-align: center; }
#topup input { float: none; margin: 0 4px 8px; }
#topupGuide, #topupPayPal, #topupSagePay { display: none; }
@media screen and (max-width: 500px) {
    #topup input { margin: 0 0 8px; width: 100%; }
}


/* form errors */
div.formError { background: #900; border-radius: 10px; color: #fff; font-size: 16px; line-height: 1.1; margin-bottom: 8px; padding: 10px; }
div.formSuccess { background: #070; border-radius: 10px; color: #fff; font-size: 16px; line-height: 1.1; margin-bottom: 8px; padding: 10px; }
.formFieldError label { color: #900 !important; }
.formFieldError input[type=email],
    .formFieldError input[type=tel],
    .formFieldError input[type=text],
    .formFieldError select,
    .formFieldError textarea { background: #ff0; border: 1px solid #900; color: #000; }


/* what our customers say */
blockquote { background: #f4b900; border-radius: 10px; margin-bottom: 7px; padding: 12px 15px; }
blockquote q { color: #000; display: block; font-size: 16px; font-style: italic; line-height: 21px; margin-bottom: 8px; }
blockquote q span { font-family: serif; font-size: 20px; line-height: 21px;}
blockquote footer { color: #000; font-size: 13px; font-style: italic; margin: -3px 0 0 70%; }
@media screen and (max-width: 600px) {
    blockquote footer { margin: -3px 0 0 0; text-align: right; }
}


/* my locations */
.location { border-top: 1px dotted #111; }
.nickname { color: #000; font-size: 16px; font-weight: bold; padding: 5px 5px 0; }
.nickname a { font-size: 12px; font-weight: normal; margin-left: 8px; }
.address { border-bottom: 1px dotted #111; font-style: italic; padding: 0 5px 5px; }


/* price list */
#priceListNarrow { display: none; }
.priceList table { width: 100%; }
.priceList .blank { background: #fc0; }
.priceList .dark { background: #d48c00;}
.priceList td { background: #e49c00; border: 3px solid #fc0; color: #000; font-size: 18px; font-weight: bold; line-height: 1; padding: 8px 2px; text-align: center; vertical-align: middle; }
.priceList td span { font-size: 14px; }
@media screen and (max-width: 510px) {
    #priceListWide { display: none; }
    #priceListNarrow { display: block; }
    .priceList .dark { background: #cf8900; }
}
@media screen and (max-width: 350px) {
    .priceList td { font-size: 14px; }
    .priceList td span { font-size: 10px; font-weight: normal; }
}
@media screen and (max-width: 250px) {
    .priceList td { font-size: 12px; }
    .priceList td span { font-size: 8px; }
}


/* footer */
footer { font-size: 12px; line-height: 1.2; margin: 16px auto; max-width: 960px; overflow: auto; }
footer a { border: 0; color: #222; text-decoration: none; }
footer a:hover { border: 0; text-decoration: underline; }
footer div { display: inline; float: left; width: 50%; }
footer div:last-child ul:last-child { margin-right: 0; width: 50%; }
footer div:last-child ul:last-child li { padding: 4px 0 3px 0; }
footer li { padding: 4px 0 3px 11px; }
footer li.link { background: url('../images/footer.gif') no-repeat 0 8px; }
footer ul { float: left; margin-right: 3%; width: 47%; }
footer ul li:first-child { color: #111; border-bottom: 1px solid #c28400; margin-bottom: 4px; padding: 0 0 4px 0 !important; }
@media screen and (max-width: 680px) {
    footer { font-size: 14px; }
    footer div { display: block; width: 100%; }
    footer div ul:last-child { margin-right: 0; width: 50%; }
    footer li { padding: 6px 0 5px 11px; }
    footer ul { margin: 0 2% 15px 0; width: 48%; }
}
@media screen and (max-width: 320px) {
    footer { font-size: 15px; }
    footer div ul:last-child, footer div:last-child ul:last-child { margin-right: 0; width: 100%; }
    footer ul { display: block; width: 100%; }
}


/* copyright */
#copyright { color: #7e5917; font-size: 11px; margin: 20px auto; max-width: 960px; text-align: right; }
@media screen and (max-width: 370px) {
    #copyright span { display: block; }
}
