/*
Theme Name: Northlink 2020
Theme URI: http://northlinkferries.co.uk/
Author: Weber Shandwick Design
Author URI: http://webershandwickdesign.com/
Description: Custom responsive theme for Northlink Ferries
Version: 1.0.0
Text Domain: northlink-responsive
Tags:

Northlink Responsive is based on Underscores http://underscores.me/, (C) 2012-2015 Automattic, Inc.
Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal http://necolas.github.com/normalize.css/

*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
	## Links
	## Menus
# Accessibility
# Alignments
# Clearings
# Widgets
# Content
	## Posts and pages
	## Asides
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
--------------------------------------------------------------*/

@font-face 
{
	font-family: 'Helvetica';
	font-style: normal;
	font-weight: 700;
	src: url('webfonts/Helvetica-Bold.woff') format('woff');
}

/*@font-face 
{
	font-family: 'Neue';
	font-style: normal;
	font-weight: 900;
	src: url('webfonts/HelveticaNeue-Black.woff') format('woff');
}

@font-face 
{
	font-family: 'Neue';
	font-style: normal;
	font-weight: 800;
	src: url('webfonts/HelveticaNeue-Heavy.woff') format('woff');
}*/


@font-face 
{
	font-family: 'Neue';
	font-style: normal;
	font-weight: 700;
	src: url('webfonts/HelveticaNeueBold.woff') format('woff');
}


@font-face 
{
	font-family: 'Neue';
	font-style: normal;
	font-weight: 300;
	src: url('webfonts/HelveticaNeue-Light.woff') format('woff');
}

@font-face 
{
	font-family: 'Neue';
	font-style: normal;
	font-weight: 200;
	src: url('webfonts/HelveticaNeue-Thin.woff') format('woff');
}

/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
html {
	font-family: 'Source Sans Pro', sans-serif;
	/*font-family: 'Neue', 'Open Sans', sans-serif;*/
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust:     100%;
	font-size:12px;
}

body {
	margin: 0;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
	display: block;
}

audio,
canvas,
progress,
video {
	display: inline-block;
	vertical-align: baseline;
}

audio:not([controls]) {
	display: none;
	height: 0;
}

[hidden],
template {
	display: none;
}

a {
	background-color: transparent;
}

a:active,
a:hover {
	outline: 0;
}

abbr[title] {
	border-bottom: 1px dotted;
}

b,
strong {
	font-weight: bold;
}

dfn {
	font-style: italic;
}

h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

mark {
	background: #ff0;
	color: #000;
}

small {
	font-size: 80%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sup {
	top: -0.5em;
}

sub {
	bottom: -0.25em;
}

img {
	border: 0;
}

svg:not(:root) {
	overflow: hidden;
}

figure {
	margin: 1em 40px;
}

hr {
	box-sizing: content-box;
	height: 0;
}

pre {
	overflow: auto;
}

code,
kbd,
pre,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

button,
input,
optgroup,
select,
textarea {
	color: inherit;
	font: inherit;
	margin: 0;
}

button {
	overflow: visible;
}

button,
select {
	text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
}

button[disabled],
html input[disabled] {
	cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

input {
	line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

input[type="search"] {
	-webkit-appearance: textfield;
	box-sizing: content-box;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 2px;
	padding: 0.35em 0.625em 0.75em;
}

legend {
	border: 0;
	padding: 0;
}

textarea {
	overflow: auto;
}

optgroup {
	font-weight: bold;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

td,
th {
	padding: 0;
}
.facebookfeed {
	float: left;
	width: 525px !important;
	height: 904px;
}
#facebookfeedtext {
	width: 190px;
	float: left;
	margin: 0px;
	padding: 0px 6px 0px 0px;
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
body,
button,
input,
select,
textarea {
	color: #404040;
	font-size: 1rem;
	line-height: 1.5;
}

h1,
h2,
h3,
h5,
h6 {
	clear: both;
	font-family: 'Neue', 'Source Sans Pro', sans-serif;
	font-weight:700;	
}

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", Courier, monospace;
	font-size: 15px;
	font-size: 0.9375rem;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
	font-size: 15px;
	font-size: 0.9375rem;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
	box-sizing: border-box;
}

*,
*:before,
*:after { /* Inherit box-sizing to make it easier to change the property for components that leverage other behavior; see http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
	box-sizing: inherit;
}

body {
	background: #fff; /* Fallback for when there is no custom background color defined. */
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
}
blockquote,
q {
	quotes: "" "";
}

hr {
	background-color: #ccc;
	border: 0;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 2.0rem 0rem;
	padding-left:2rem;
}

ul li,
ol li {
	
	padding-left:1rem;
	padding-bottom:0.5rem;
}
ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: bold;
}

dd {
	margin: 0 1.5em 1.5em;
}

img {
	height: auto; /* Make sure images are scaled correctly. */
	max-width: 100%; /* Adhere to container width. */
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	
	
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: #000;
	
}

button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
button:active,
input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
	border-color: #000;
	
}

input,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	font-family: 'Neue', 'Source Sans Pro', sans-serif;
	border: 0px solid;
	border-color: #000;
	border-radius: 0px;
	background-color: #e6e7e8;
	color: rgba(0, 0, 0, 1);
	font-size: 2rem;
	line-height: 1.1;
	padding: 1rem 1rem 0.5rem;
}

select {
	border: 1px solid #000;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #000;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"] {
	
}

textarea {
	
	width: 100%;
}

::-webkit-input-placeholder { /* WebKit, Blink, Edge */
    color:    #fff;
}
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
   color:    #fff;
   opacity:  1;
}
::-moz-placeholder { /* Mozilla Firefox 19+ */
   color:    #fff;
   opacity:  1;
}
:-ms-input-placeholder { /* Internet Explorer 10-11 */
   color:    #fff;
}

/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
	color: #0095d7;
}
a:visited {
	color: #0095d7;
}

a:hover,
a:focus,
a:active {
	color: #0095d7;
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
	clear: both;
	display: block;
	float: left;
	width: 100%;
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation li {
	float: left;
	position: relative;
	padding-left:0px;
}

.main-navigation a {
	display: block;
	text-decoration: none;
}

.main-navigation ul ul {
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	float: left;
	position: absolute;
	top: 1.5em;
	left: -999em;
	z-index: 99999;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul a {
	width: 200px;
}

.main-navigation ul ul li {

}

.main-navigation li:hover > a,
.main-navigation li.focus > a {
}

.main-navigation ul ul :hover > a,
.main-navigation ul ul .focus > a {
}

.main-navigation ul ul a:hover,
.main-navigation ul ul a.focus {
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: auto;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	left: 100%;
}

.main-navigation .current_page_item > a,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_ancestor > a,
.main-navigation .current-menu-ancestor > a {
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

.trailers iframe {
   margin: 0 auto;
   display: block;
}
.trailers {
	margin-bottom: 30px; 
}

a.month-previous {
    color: #fff;
    text-decoration: none;
    font-family: 'Neue', 'Source Sans Pro', sans-serif;
    font-weight: 300;
    background-color: #303535;
    display: block;
    height: 65px;
    width: 250px;
    bottom: 22.1%;
    left: 0px;
    margin-left: 0px;
    margin-right: 15px;
    margin-bottom: 15px;
    margin-left: 100px;
    padding: 1.6rem 2rem;
    text-align: center;
    line-height: 1.1;
    bottom: 0;
    font-size: 2.0rem;
	float: left;
}
a.month-next {
    color: #fff;
    text-decoration: none;
    font-family: 'Neue', 'Source Sans Pro', sans-serif;
    font-weight: 300;
    background-color: #303535;
    display: block;
    height: 65px;
    width: 250px;
    bottom: 22.1%;
    left: 0px;
    margin-left: 0px;
    margin-right: 0px;
    margin-bottom: 15px;
    margin-left: 0px;
    padding: 1.6rem 2rem;
    text-align: center;
    line-height: 1.1;
    bottom: 0;
    font-size: 2.0rem;
float: left;

}
a.month-previous:hover , a.month-next:hover {
    color: #8fc5e5;
}
  .businesslistingarea { grid-template-columns: repeat(3, 1fr); }



@media screen and (min-width: 37.5em) {
	.menu-toggle {
		display: none;
	}
	.main-navigation ul {
		display: block;
	}
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
	margin: 0 0 1.5em;
	overflow: hidden;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	float: left;
	width: 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	float: right;
	text-align: right;
	width: 50%;
}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
	outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.alignleft {
	display: inline;
	float: left;
	margin-right: 1rem;
	margin-top: 1rem;
	margin-bottom: 1rem;
}

.alignright {
	display: inline;
	float: right;
	margin-left: 1rem;
	margin-top: 1rem;
	margin-bottom: 1rem;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-top: 1rem;
	margin-bottom: 1rem;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
	content: "";
	display: table;
	table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
	clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
	margin: 0 0 1.7rem 0;
}

/* Make sure select elements fit in widgets. */
.widget select {
	max-width: 100%;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
.sticky {
	display: block;
}

.hentry {
	margin: 0 0 1.5em;
}

.byline,
.updated:not(.published) {
	display: none;
}

.single .byline,
.group-blog .byline {
	display: inline;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 0rem 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

/*--------------------------------------------------------------
## Asides
--------------------------------------------------------------*/
.blog .format-aside .entry-title,
.archive .format-aside .entry-title {
	display: none;
}

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation, /* Older / Newer Posts Navigation (always hidden) */
.infinite-scroll.neverending .site-footer { /* Theme Footer (when set to scrolling) */
	display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
	margin-bottom: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	vertical-align: top;
	width: 100%;
}

.gallery-columns-2 .gallery-item {
	max-width: 50%;
}

.gallery-columns-3 .gallery-item {
	max-width: 33.33%;
}

.gallery-columns-4 .gallery-item {
	max-width: 25%;
}

.gallery-columns-5 .gallery-item {
	max-width: 20%;
}

.gallery-columns-6 .gallery-item {
	max-width: 16.66%;
}

.gallery-columns-7 .gallery-item {
	max-width: 14.28%;
}

.gallery-columns-8 .gallery-item {
	max-width: 12.5%;
}

.gallery-columns-9 .gallery-item {
	max-width: 11.11%;
}

.gallery-caption {
	display: block;
}












/*--------------------------------------------------------------
## it begins
--------------------------------------------------------------*/


h2 {
    font-family: 'Neue', sans-serif;
    color: #0095d7;
    font-size: 3.0rem;
    text-align: left;
    font-weight: 300;
}






.opsnews-title {
	line-height: 2.5 !important;
	display: block; 
	display: inline; 
	white-space: nowrap;
	overflow: hidden;
}

#page
{
	width:100%;
	position:relative;

	overflow-x:hidden;
}

#masthead
{
	position:absolute;
	z-index: 1500;
	width:100%;
	margin:0;
	padding:0;
}



.branding-holder
{
	position:absolute;
	width:100%;
	padding:1rem 0rem 0rem 0rem;
	background-color: transparent;
	top:0rem;
}

.site-branding, #content, .primary-nav-container, #socialstuff, #footernav, .site-info
{
	position:relative;
	

	max-width:1440px;
	
	margin:0 auto;

	/*border:1px solid red;*/
	
}

.site-branding .site-title
{
	margin:0;
	position:relative;
	width:100%;
}

.site-branding .site-title a
{
	float: right;
    display: block;
    width: 35%;
    padding-top: 6rem;
    padding-bottom: 4rem;
    padding-right: 3rem;
}

.site-branding .site-title a img
{
	width:100%;
	height:auto;
}

#viking
{
	position: absolute;
    top: -0.5rem;
    left: 0%;
    z-index: 1501;
    width: 18rem;
}

#viking img
{
	width:100%;
	height:auto;
}

#site-navigation
{
	width:100%;
	padding:0;
	margin:0;
	position:absolute;
	top:4rem;
	background-color: rgba(0,67,111,0.8);

	z-index:999;

	border-bottom:0px solid #fff;
	border-top:0px solid #fff;
}

.primary-nav-container
{
	


	/*border:1px solid red;*/
}

#primary-menu
{
	float:right;
	padding-right:4rem;
}

#primary-menu li a
{
	color:#fff;
	padding:2.9rem 2rem 2.3rem 2rem;
	font-size:1.6rem;
	line-height: 1.8;
	font-weight: 300;
	display: inline-block;

	font-family: 'Neue', sans-serif;
	/*font-weight: 600;*/
}

#primary-menu li li a
{
	padding:0.2rem 0.5rem 0.4rem 0.5rem;
}


#primary-menu li.current-menu-item > a, #primary-menu li.current-page-ancestor > a, #primary-menu li.current-menu-ancestor > a, #primary-menu li.current-menu-parent > a, #primary-menu li.current-page-parent > a
{
	color: #c4e1f4;
}


   



/*#primary-menu > li + li:before*/
#primary-menu > li + li:before
{
    content: "";
    padding: 0px 0.4rem 0px 0.5rem;
    font-size:2.0rem;
    position:relative;
    top:-0.0rem;
    
    color:#fff;
}

#primary-menu > li.servicestatus a:before
{
	content: " ";
	position: relative;
	margin-right:1rem;
	display: inline-block;
	background-color: #229922;
	border-radius: 50%;
	border:2px solid #fff;
	width: 2rem;
	height: 2rem;
	top: -0.1rem;
    margin-bottom: -0.5rem;
}	

.red #primary-menu > li.servicestatus a:before
{
	background-color: #992222;
}

.amber #primary-menu > li.servicestatus a:before
{
	background-color: #ffa700;
}

.main-navigation ul ul {
	box-shadow: none;
	background-color: #00436f;
	float: left;
	position: absolute;
	top: 3rem;
	left: -999em;
	z-index: 99999;
	padding:1rem;
}

.menu-main-menu-container
{
	margin-right:3rem;
}

.navbarint
{
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	position: relative;
}



#searchbox 
{
	position: absolute;
	top:4rem;
	left:0px;
	z-index:9999;
}

#searchbox input
{
	width:230px;
}

#searchbutton
{
	position: absolute;
	top:2.2rem;
	right:4rem;
	color:#fff;
	

	font-size:1.8rem;
	display:inline-block;
	width:3rem;
	height:3rem;
	line-height:2.5rem;
	padding-top:1rem;
	padding-left:0px;
	
	background-color:transparent;
	border-radius:0%;
	text-align: center;
	margin:0px 0px;
	border:0px solid #000;

	cursor: pointer;
}

#searchbutton i
{
	opacity:1;
}


#mobilebar
{
	display:none;
	width:100%;
	background-color:rgba(0,67,111,0.8);
	color:#fff;
	position: relative;
	top:4rem;
	min-height:5rem;
}

#mobilesearchbutton, #mobilemenubutton, #mobilemenubuttonclose
{
	position: absolute;
	top:1rem;
	font-size: 3rem;
	line-height: 3rem;
	cursor:pointer;
	z-index:10001;
}

#mobilesearchbutton 
{
	font-size:1.5rem;
	
	width:3.0rem;
	height:3.0rem;
	line-height:2.3rem;
	padding-top:0px;
	padding-left:1px;
	color:#fff;
	background-color:transparent;
	border-radius:50%;
	text-align: center;
	margin:0px 2px;
	border:2px solid #fff;
}



#mobilemenubutton, #mobilemenubuttonclose
{
	right:4rem;
}

#mobilemenubuttonclose
{
	display:none;
}

.mobilemenuopen #mobilemenubuttonclose
{
	display:block;
}

.mobilemenuopen #mobilemenubutton
{
	display:none;
}

#mobilesearchbutton
{
	left:4rem;
	display: none;
}

#mobilemenu
{
	display:none;
}

.mobilemenuopen #mobilemenu
{
	display:block;
}





#mobilemenu ul 
{
	list-style: none;
	margin: 8rem 0rem 7rem 0rem;
	padding-left: 0;
}

#mobilemenu ul li
{
	display:block;
	color:#0095d7;
	vertical-align: top;
	width:100%;
	font-weight: normal;
	font-size: 1.8rem;
	font-family: 'Neue', sans-serif;
	/*border-bottom:2px solid #fff;*/
	
}

#mobilemenu ul li a
{
	
	color:#fff;
	display:inline-block;
	text-decoration: none;
	padding:1rem 4rem 1rem 4rem;
}

#mobilemenu ul ul.sub-menu
{
	margin: 1rem 0rem;
}

#mobilemenu ul ul.sub-menu li a
{
	color:#fff;
	font-size: 1.5rem;
}








/* main content */






#content
{
	position:relative;
	z-index:1099;

	margin-bottom:4rem;
}

.entry-content h1, .entry-content h2, .entry-content h3, .entry-content h4, .entry-content h6
{
	color: #0071aa;

}

.entry-content h1
{
	font-size: 2.7rem;
}

.entry-content h2
{
	font-size: 2.2rem;
	margin-top:0rem;
	margin-bottom:0.5rem;
}

.entry-content h3
{
	font-size: 1.5rem;
}
.entry-content h5
{
	font-size: 1.8rem;
	color: #000;
	margin-top:0rem;
	margin-bottom:0.5rem;
}

h4 {
	font-family: 'Neue', 'Source Sans Pro', sans-serif;
	font-weight:700;
	font-size: 1.8rem;
	padding-bottom:0;
	margin-bottom:0;	
}

.homehero 
{
    width: 100vw;
    height: 75vh;
    height: 58.46vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    background-color: #0095d7;
    padding-bottom: 0rem;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    margin-bottom: 10vh;
    margin-top:4rem;
}

.homehero:before
{
	content: ' ';
	position: absolute;
	width: 100%;
	height: 100%;
}

.home .homehero:before
{
	display: none;
}






.herotextholder
{
	width: 100%;
	/*max-width: 1440px;
	margin: 0 auto;*/
	position: absolute;
	bottom:10rem;
	left:0;
}

.homehero h1
{
	font-family: 'Helvetica', sans-serif;

	position: relative;
	color:#fff;
	font-weight: 700;
	font-size: 3.5rem;
	
	text-align: right;
	width: 100%;
	padding-right: 4rem;
	letter-spacing: -0.02em;

	text-shadow: 0px 0px 1rem rgba(0,0,0,0.8);
}

.herointro
{
	width: calc(80% - 0rem);
	margin-left:10%;
	padding: 5rem 10rem 2rem;
	text-align: center;
	font-size:1.5rem;
	margin-bottom: 8rem;
	font-weight: 700;
	min-height: 8rem;
}

.bizintro
{
	width: 100%;
	padding:2rem 1rem;
	text-align: center;
	font-size:1.5rem;
	margin-bottom: 8rem;
	font-weight: 700;
	min-height: 8rem;
}


.herointro h2
{
	font-family: 'Neue', sans-serif;
	color:#0095d7;
	font-size: 2.5rem;
	text-align: center;
	font-weight: 700;
}
.bizintro h2
{
	font-family: 'Neue', sans-serif;
	color:#0095d7;
	font-size: 2.5rem;
	text-align: center;
	font-weight: 700;
}

hr 
{
    border: 0;
    height: 1px;
    margin-top: 2rem;
    margin-bottom: 2rem;
    width: 20%;
}

.herotitleholder
{
	width: 100%;
	position: absolute;
	bottom:0px;
	left:0px;
	background-color: rgba(0,0,0,0.5);

}


.herotitleholder h1
{
	font-family: 'Helvetica', sans-serif;
    position: relative;
    top: 0;
    left: 0;
    color: #fff;
    font-weight: 700;
    font-size: 3.5rem;
    text-align: center;
    width: 100%;
    text-shadow: none;
    margin: 0 0 0 0;
    padding: 0rem 0rem;
	text-shadow: 0px 0px 1rem rgba(0,0,0,0.8);
}




.herotitleholder h1:after
{
	content: ' ';
    position: relative;
    width: 6rem;
    height: 0.3rem;
    background-color: #fff;
    display: block;
    margin: 1rem auto;
    text-shadow: 0px 0px 1rem rgba(0,0,0,0.8);
}

a.prearrow
{
	display: block;
	font-weight: 700;
	text-decoration: none;
	font-size: 1.5rem;

	position: absolute;
	bottom:2rem;
	left:2rem;

}

a.prearrow:before
{
	content: ' ';
	background-image:url('img/rightarrowblue.svg');
	background-size: contain;

	width: 1.5rem;
	height: 1.5rem;

	display: inline-block;
	position: relative;
	top:0.2rem;
	left:0rem;
	margin-right: 0.5rem;

}




#leftcol
{
	
	width:100%;
	width: calc(100% - 4rem);
	min-width: 280px;
	float:none;
	margin-bottom:0%;
	position: absolute;
	z-index: 1000;
	top:calc(75vh - 4rem);
	top:calc(58.46vw - 4rem);
	
	left:2rem;
}

.widget_northlinkbookingwidget
{
	background-color:#c22c74;
	min-height:543px;
	color:#fff;
	width:100%;
	padding:1rem;
}

.widget_northlinkdirectbookingwidget
{
	background-color:#e6e7e8;
	color:#58595b;
	width:100%;
	padding:1.7rem;
	font-size: 1.2rem;
}

.widget_northlinkdirectbookingwidget img
{
	margin-bottom: 1rem;
	width:100%;
}

.widget_xyz_insert_html_widget , .widget_custom_html
{
	background-color:#c22c74;
	min-height:0px;
	color:#fff;
	width:100%;
	padding: 1rem 2rem 1rem 2rem;
	text-align: center;
}

.widget_xyz_insert_html_widget iframe , .widget_custom_html iframe
{
	max-width: 100%;
	margin: 0 auto;
	height: 10rem;
}

.widget_xyz_insert_html_widget img , .widget_custom_html img
{
	margin-bottom: 1rem;
}

.widget_sp_image
{
	position: relative;
}

.widget_sp_image a
{
	line-height: 0;
	display: block;
}

.widget_sp_image img
{
	width:100%;
	height:auto;
}

.widget_sp_image h2
{
	position:absolute;
	bottom:0px;
	left:0px;
	color:#fff;
	background-color:rgba(0,0,40,0.7);
	padding:1.5rem 1rem 1rem 1rem;
	width:100%;
	margin:0px;
	font-size: 2rem;
	text-align: center;
	pointer-events: none;
}

#main
{
	width:100%;
	background-color:#fff;
	padding-left:0rem;
	
	float:none;
	margin-bottom:1%;
}

.home #main
{
	width:100%;
}




.routearea
{
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	background-color:#eeeeee;
	padding-bottom: 4rem;
	  
}

.innerwrapper
{
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	position: relative;
}




.extrablocks
{
	clear: both;
	width: 100%;
	
	position: relative;

	margin-bottom:2rem;


}

.extrablocks.bigblocks
{
	top: -8rem;
}


	
.extrablocks .extrablock
{
	width: 25%;
	display: block;
	float:left;
	height: 0px;
	padding-bottom:17%;
	background-color: #000;
	color: #fff;
	

	background-repeat: no-repeat;
	background-size: cover;
	background-position: 50% 50%;

	text-decoration: none;
}

.extrablocks.bigblocks .extrablock
{
	width: 33.33%;
	padding-bottom:20%;
	

}

.extrablocks .extrablock h2
{
	width: 100%;
	padding: 0rem 2rem;
	font-family: 'Neue', sans-serif;
	color:#fff;
	font-size: 2.2rem;
	text-align: left;
	font-weight: 700;
	text-shadow: 0px 0px 1rem rgba(0,0,0,0.8);

}

.extrablocks.bigblocks .extrablock h2
{
	
	font-size: 3rem;
	
}

.extrablocks .extrablock h2:after
{
	content: ' ';
	display: block;
	width: 1.5rem;
	padding-top:0.5rem;
	border-bottom: 0.3rem solid #fff;
}


.menublocksarea
{
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	background-color:#eeeeee;
	padding-bottom: 4rem;
	margin-top:12rem;
	  
}

.extramenublocksarea
{
	clear: both;
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	background-color:#eeeeee;
	padding-bottom: 4rem;
	margin-top:12rem;
}


.menublocks
{
	clear: both;
	width: calc(100% + 2rem);
	margin-left:-1rem;
	margin-right:-1rem;
	
	position: relative;

	margin-bottom:2rem;


	top: -4rem;


}

.menublocks.guideblocks
{
	top: -14rem;
}


.menublocks .pageblock
{
	width: calc(25% - 2rem);
	margin: 0rem 1rem 2rem 1rem;
	display: block;
	float:left;
	/*height: 0px;
	padding-bottom:17%;*/
	background-color: #fff;
	color: #333333;
	position: relative;
	

	background-repeat: no-repeat;
	background-size: cover;
	background-position: 50% 50%;

	text-decoration: none;
}

.menublocks.guideblocks .pageblock
{
	width: calc(33.33% - 2rem);
}

.menublocks.guideblocks .listings
{
	width: calc(33.33% - 2rem);
}


.picpart
{
	width: 100%;
	position: relative;
	height: 0px;
	display: block;
	text-decoration: none;
	padding-bottom:50%;
	background-repeat: no-repeat;
	background-size: cover;

}

.textpart
{
	min-height: 18rem;
	padding:2rem;
	position: relative;
	font-size: 1.2rem;
}

.guideblocks .textpart 
{
	min-height: 25rem;
}

.textpart h2
{
	width: 100%;
	padding: 0rem;
	margin: 0rem;
	font-family: 'Neue', sans-serif;
	color:#00537E;
	font-size: 2.0rem;
	text-align: left;
	font-weight: 300;
	line-height: 1.1;
	

}


.textpart h2:after
{
	content: ' ';
	display: block;
	width: 2rem;
	padding-top:1rem;
	border-bottom: 0.3rem solid #ccc;
}

.clearboth
{
	clear: both;
}


.businesslisting {
  background-color: #fff;
  color: #000;
  border-style: solid;
  border-width: 1px;
  border-color: #ccc;
  padding: 1rem;
  height: 50rem;
	font-weight: normal;
}
.biztextpart {
    min-height: 18rem;
    padding: 1.5rem;
    position: relative;
    font-size: 1.2rem;
}
.businesslisting h2 {
	width: 100%;
	padding: 0rem;
    margin: 0rem;
    font-family: 'Neue', sans-serif;
    color: #00537E;
    font-size: 2.0rem;
    text-align: left;
    font-weight: 300;
	line-height: 1.1;
}
.businesslisting h2:after {
    content: ' ';
    display: block;
    width: 2rem;
    padding-top: 1rem;
    border-bottom: 0.3rem solid #ccc;
}
.businesslisting h3 {
	text-align: left;
	font-size: 1.4rem;
	font-weight: normal;
}
.businesslisting p {
	text-align: left;
	font-size: 1.3rem;
}
.businesslisting:hover {
  box-shadow: 0 0 11px rgba(33,33,33,.2); 
}
.businesslistingarea {
  margin: 0 auto;
  display: grid;
  grid-gap: 1rem;
}
.businesslisting a {
		font-size: 1.4rem;
		text-decoration: none;
		background-color: #0095d7;
		color: #fff;
		padding: 12px 1px 12px 1px;
		border-color: #015480;
		text-align: center;
		width: 100%;
		box-shadow: 0 3px 0 #0077af;
    	display: block;
		margin-top: 15px
}
.businesslisting a:hover {
		background-color: #015480
		}



.routesplit
{
	width: 100%;
	position: relative;
	top:-7rem;
}

.routehalf
{
	width: 50%;
	float: left;
	font-size: 1.5rem;

}

.routehalf img
{
	width: calc(100% - 8rem);
	height: auto;
	margin-left: 8rem;
}

.routehalf.withtext
{
	padding:0rem 6rem 0rem 12rem;
}

.routehalf > p:first-of-type
{
	font-weight: 700;
	font-size: 1.8rem;
}


.routehalf h2
{
	font-family: 'Neue', sans-serif;
	color:#00537E;
	font-size: 3rem;
	text-align: left;
	font-weight: 700;


}

.routehalf h2:after
{
	content: ' ';
	display: block;
	width: 1.5rem;
	padding-top:0.5rem;
	border-bottom: 0.3rem solid #00537E;
}

.routehalf a.bluerectbutton 
{
	margin-top:4rem;
	display: table;
}
.featurehero
{
	  width: 100vw;
	  position: relative;
	  left: 50%;
	  right: 50%;
	  margin-left: -50vw;
	  margin-right: -50vw;
	  background-color:#000000;
	  color: #fff;
	  

	  background-repeat: no-repeat;
	  background-size: cover;
	  background-position: 50% 65%;
}

.featurehero:after
{
	position: absolute;
	content: ' ';
	width: 100%;
 	height: 100%;
 	top:0;
 	left:0;
 	background-color:rgba(0,0,0,0.5);
 	z-index: 2;
}

.featureheroint
{
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	position: relative;
	z-index: 3;
}

.featurehalfholder
{
	width: calc(100% + 8rem);
	position: relative;
	margin:0rem -4rem;
}

.featurehalf
{
	width: calc(50% - 8rem);
	float:left;
	border:0px solid red;
	margin: 4rem;
	font-size: 1.5rem;

}

.featurehalf.withtext
{
	padding: 0rem 8rem 5rem 8rem;
	float:right;
}

.featurehalf h2
{
	font-family: 'Neue', sans-serif;
	color:#fff;
	font-size: 3rem;
	text-align: left;
	font-weight: 700;


}

.featurehalf h2:after
{
	content: ' ';
	display: block;
	width: 1.5rem;
	padding-top:0.5rem;
	border-bottom: 0.3rem solid #fff;
}


.featurehalf a.bluerectbutton 
{
	margin-top:4rem;
	display: table;
}




.normalcontent
{
	width: calc(80% - 5rem);
	margin-left:20%;
	/*margin-left:10%;*/
	padding:5rem 10rem 2rem;
	text-align: left;
	font-size:1.5rem;
	margin-bottom: 8rem;
	font-weight: 400;
}














.maincontent
{
	width:100%;
	background-color:#fff;
	position:relative;
	
}

#tickertape
{
	padding:0rem;
	font-size:1.2rem;
	color:#000;
	padding:1rem;

	height:3rem;
	margin-bottom: 1rem;
	overflow: hidden;
}

#tickertape ul
{
	margin: auto;
}



#tickertape ul li
{
	list-style: outside none none;
    margin: 0;
    padding: 0;
    display:block;
}

#tickertape ul li a
{
	text-decoration: none;
	color:#000;
}

#tickertape ul li::before, #tickertitle {
    content: "Update: ";
    color:#0095d7;
	font-weight: bold;
	padding-right:1rem;
}





#rightcontent
{
	width:100%;
}

#rightcontent header img
{
	width:100%;
	height:auto;
}

#rightcontent header
{
	line-height: 0;
}

#rightcontent header h1
{
	width:100%;
	margin:0rem 0rem 0rem 0rem;
	background-color: #0095d7;
	color:#fff;
	font-size:3rem;
	font-family: 'Neue', 'Source Sans Pro', sans-serif;
	font-weight:700;
	line-height: 1.1;
	padding:1.5rem 2rem 1.5rem 2rem;
}

#rightcontent header
{
	margin-bottom:2rem;
}

#rightcontent .inpagenav
{
	background-color: #e6e7e8;
    color: #00436f;
    width: 100%;
    line-height:1.5;
    font-size:1.2rem;
    padding:1.5rem 2rem 1.5rem 2rem;
}

#rightcontent .inpagenav a
{
	color: #00436f;
	text-decoration: none;
	padding:0rem 1rem 0rem 1rem;
}

#rightcontent .inpagenav a:hover
{
	color:#0095d7;
}


.entry-content
{
	font-size: 1.5rem;
}


.entry-content p:first-child strong
{
	color:#00436f;
	font-size:1.2rem;
	font-weight: bold;
}

#ourroutes
{
	background-color:blue;
	line-height: 0;
	position:relative;
	height:0px;
	width:100%;
	padding-bottom:75%;
	overflow: hidden;
}

#ourroutes img
{
	position:absolute;
	top:0px;
	left:0px;
	width:100%;
	height:auto;
}

#ourroutes h1
{
	font-size: 4rem;
	line-height: 1.1;
	margin:3rem 3rem 1rem 3rem;
	color: #fff;
	/*text-decoration: underline;*/
	border-bottom: 2px solid #fff;
	
	position: absolute;
	top:0px;
	left:0px;
	padding:0rem;
}

#ourroutes .bluerectbutton
{
	position: absolute;
	bottom:3rem;
	right:3rem;

}

a.bluerectbutton 
{
    padding: 0.8rem 1.5rem;
    background-color: #0095d7;
    color: #fff;
    font-size: 2.0rem;
    font-family: 'Neue', sans-serif;
    font-weight: 700;
    text-decoration: none;
}

a.bluerectbutton:after
{
	content: ' ';
	background-image:url('img/rightarrowblue.svg');
	background-size: contain;

	width: 2rem;
	height: 2rem;

	display: inline-block;
	position: relative;
	top:0.3rem;
	left:0rem;
	margin-left: 0.75rem;

}

a.bluerectbutton span.arrowbutton
{
	padding-top:0.2rem;
	padding-left:0.2rem;
}


/* grid */

.grid
{
	clear:both;
	position: relative;
}



.gridbox {
	position: relative;
	width:32%;
	background-color:#0095d7;
	color:#fff;
	float:left;
	margin-left:1%;
	margin-right:1%;
	margin-top:0%;
	margin-bottom:1.7rem;

	height:0px;
	padding-bottom:35.12%;
	overflow:hidden;
}

.gridbox img {
	height:77.9%;
	width:auto;
	max-width:none;
}
.gridbox.col1 {
	margin-left:0%;
}

.gridbox.col3 {
	margin-right:0%;
}

.gridbox .gridbg {
	position:absolute;
	top:0px;
	left:0px;
}

.gridbox .gridfootertext {
	position:absolute;
	bottom:0px;
	left:0px;
	width:85%;
	padding:0rem 2rem 1.5rem 2rem;
	padding:0rem 1.5rem 1.25rem 1.5rem

}

.gridbox .gridfootertext p {
	margin:0;
	font-size:1.2rem;
    	line-height: 1.3;
}


.gridbox h1
{
	position:absolute;
	bottom:22.1%;
	left:0px;
	background-color:rgba(0,0,0,0.6);
	margin:0;
	padding:1.6rem 2rem;
	text-align: center;
	line-height: 1.1;
	width:100%;
}

.gridbox h1 a
{
	color:#fff;
	text-decoration: none;
}
.gridbox h2
{
	position:absolute;
	bottom:22.1%;
	left:0px;
	background-color:rgba(0,0,0,0.6);
	margin:0;
	padding:1.6rem 2rem;
	text-align: center;

	width:100%;
	font-size: 2em;
}

.gridbox h2 a
{
	color:#fff;
	text-decoration: none;
}
h2 a
{
	text-decoration: none;
}
.textpart h2 a
{
	color:#00537E;
	text-decoration: none;
}

a.arrowbutton, span.arrowbutton
{
	font-size:2rem;
	display:inline-block;
	width:3.0rem;
	height:3.0rem;
	line-height:2.0rem;
	padding-top:0.2rem;
	padding-left:0.2rem;
	color:#fff;
	background-color:transparent;
	border-radius:50%;
	text-align: center;
	margin:0px 2px;
	border:2px solid #fff;
}

a.arrowbutton:hover, a:hover span.arrowbutton;
{
	background-color: rgba(0,0,0,0.8);

}

a.arrowbutton i
{
	line-height:2.2rem;
}



.gridbox a.arrowbutton {
	position:absolute;
	bottom:2rem;
	right:1rem;
}




.prevbutton, .nextbutton, .slidepager, .slidenav
{
	display:none;
}


.panel {
	float: left;
	width:31%;
	margin-left:1%;
	margin-right:1%;
	margin-top:0%;
	margin-bottom:1.7rem;
	color:#fff;
	background-color:#0095d7;
}
.panel a, .panellarge a, .panelmedium a {
	color:#fff;
	text-decoration: none;
}
.panellarge {
	float: left;
	width:48%;
	margin-left:1%;
	margin-right:1%;
	margin-top:0%;
	margin-bottom:1.7rem;
	color:#fff;
	background-color:#0095d7;
}
.panelmedium {
	float: left;
	width:31%;
	margin-left:1%;
	margin-right:1%;
	margin-top:0%;
	margin-bottom:1.7rem;
	color:#fff;
	background-color:#0095d7;
}
.panelimage, .panelfreelistings {
	height: 185px;
	text-align: center;
	margin-top:0%;
	position: relative;
}
.panelimages {
	height: 150px;
	text-align: center;
	margin-top:0%;
	position: relative;
}
.panelimage h1, .panelimages h1 {
	color:#fff;
	bottom:22.1%;
	left:0px;
	background-color:rgba(0,0,0,0.6);
	margin:0;
	padding:1.6rem 2rem;
	text-align: center;
	line-height: 1.1;
	width:100%;
	position: absolute;
	bottom: 0;
	font-size: 2.0rem;
}
.panelfreelistings h1 {
	color:#fff;
	bottom:22.1%;
	left:0px;
	margin:0;
	padding:1.6rem 2rem;
	text-align: center;
	line-height: 1.1;
	width:100%;
	position: absolute;
	bottom: 10px;
	font-size: 2.0rem;
}
a.panelarrowbutton, span.panelarrowbutton
{
	font-size:2rem;
	display:inline-block;
	width:3.0rem;
	height:3.0rem;
	line-height:2.5rem;
	padding-top:0px;
	padding-left:3px;
	color:#fff;
	background-color:transparent;
	border-radius:50%;
	text-align: center;
	margin:10px 2px 0px 0px;
	border:2px solid #fff;
	float: right;
}

a.panelarrowbutton:hover, a:hover span.panelarrowbutton
{
	background-color: rgba(0,0,0,0.8);

}
a.panelarrowbutton i
{
	line-height:2.5rem;
}
.panelcontainer a.panelarrowbutton {
	
	bottom:2rem;
	right:1rem;
}
.paneltext {
	bottom:0px;
	left:0px;
	width:100%;
	padding: 0rem 0.8rem 0rem 1rem;
}
.paneltext p {
margin-bottom: 1em;
}

/* footer */

#socialbarholder
{
	width:100%;
	background-color: #e6e7e8;
	color:#00436f;
}

#socialstuff
{
	padding:1rem 1rem 1rem 1rem;
}

#footerbarholder
{
	width:100%;
	background-color: #262626;
	color:#fff;
	border-top: 1rem solid #0095d7;
}

#footernav
{
	padding:0;
}

.footerint
{
	width: 100%;
	position: relative;
	max-width: 1440px;
	margin: 0 auto;

	padding:4rem 0rem;
}

.footeright
{
	float:right;
	width: 80%;
	position: relative;
	padding: 0rem 4rem;
}

.footermenus
{
	float:left;
	width: 70%;
	position: relative;
}

.footerlinks
{
	float:left;
	width: 30%;
	position: relative;
}
		

.footerinfo
{
	float:left;
	width: 20%;
	position: relative;
}
	


.footermenus
{
	
	position: relative;
}

.menuholder
{
	display: table;
	width: 100%;
	overflow-x: hidden;
	table-layout: fixed;
}
.menurow
{
	display: table-row;
}

.menucol
{
	display: table-cell;
	vertical-align: top;
	width: 25%;
	
}
			
.menucol ul
{
	list-style: none;
	margin: 0 0 2rem 0;
	padding:0;

	min-height: 14rem;
}

.menucol ul ul
{
	min-height: 0;
}

.menucol ul li 
{
	margin: 0;
	padding:0;
	font-size: 1.2rem;
}

.menucol ul li a
{
	text-decoration: none;
	font-weight: bold;
}

.menucol ul ul
{
	margin-top:0.5rem;
}


.menucol ul ul li 
{
	margin: 0;
	padding:0;
	font-size: 1.1rem;
}

.menucol ul ul li a
{
	text-decoration: none;
	font-weight: normal;
	color:#fff;
}

.extramenucol
{

}

.extramenucol ul
{
	list-style: none;
	margin: 0 0 2rem 0;
	padding:0;
	min-height: 14rem;

}

.extramenucol ul li 
{
	margin: 0;
	padding:0;
	font-size: 1.2rem;
}

.extramenucol ul li a
{
	text-decoration: none;
	font-weight: normal;
	color:#fff;
}


.opby
{
	margin-top:1.5rem;
	text-align: center;

}



.opby img 
{
    width: 6rem;
    height: auto;
    position: relative;
    top: 0.8rem;
    margin-left: 0.5rem;
}




.site-info
{
	
	padding:1rem 1rem 1rem 1rem;
	font-size:0.8rem;
}

#tripad
{
	width:35%;
	/*width:468px;*/
	float:left;
	margin-left:15%;
}

#CDSRATINGWIDGET706
{
	width:424px !important;
}

#CDSROWLOC706
{
	max-width:960px !important;;
}
.sociallinks
{
	
}

.sociallinks a
{
	font-size:1.5rem;
	display:inline-block;
	width:2.8rem;
	height:2.8rem;
	line-height:2.8rem;
	padding-top:0px;
	color:#fff;
	background-color:#0095d7;
	border-radius:50%;
	text-align: center;
	margin:0px 2px;
}

#footerright
{
	width:55%;
	margin-left:45%;
	padding-bottom:100px;
}

#footerright a
{
	color:#fff;
	text-decoration: none;
}

#footerlogo 
{
	width:35%;
	float:left;
	position: relative;
}

#footerlogo img
{ 
	width:100%;
	height:auto;
	position: absolute;
	left:0px;
	top:-10px;
	padding-bottom:50px;
}

#copyetc
{
	width:60%;
	float:right;
	margin-top:2rem;
}


#footernav ul 
{
	list-style: none;
	margin: 0;
	padding-left: 0;
}

#footernav ul li
{
	display:inline-block;
	color:#0095d7;
	vertical-align: top;
	width:16%;
	font-weight: bold;
	font-size: 1rem;
	/*margin-left: 0.25em;*/
}

#footernav ul li a
{
	color:#0095d7;
	text-decoration: none;
}

#footernav ul li a span
{
	display:none;
}

#footernav ul ul.sub-menu
{
	margin-top:0.5rem;
}

#footernav ul li li
{
	width:100%;
	color:#fff;
	font-weight: normal;
	font-size: 0.9rem;
	padding-left:0;
	
}

#footernav ul li li a
{
	color:#fff;
}


/* faqs */

.faq-list
{

}

.single-faq
{
	border-bottom: 1px solid #fff;
}

.single-faq h3
{
	background-color: #ddd;
	color:#00436f;
	margin:0;
	padding: 1.2rem 5.5rem 1.2rem 1.5rem;
	font-family: 'Source Sans Pro', sans-serif;
	font-weight: normal;
	cursor: pointer;
	background-image: url('img/whitecross.svg');
	background-repeat: no-repeat;
	background-position: 96% center; 
}

.single-faq h3.expanded
{
	background-image: url('img/whiteminus.svg');
	
	
}

.faq-answer
{
	padding:0.7rem 1.5rem;
}


a.pinklink
{
 	display: block;
 	clear:both;
 	width:100%;
 	margin: 2rem 0rem 1rem 0rem;
 	padding:1.3rem 5.5rem 1.0rem 2rem;
 	background-color: #c22c74;
 	color:#fff;
 	font-weight: 300;
 	font-size: 2rem;
 	text-decoration: none;
 	position:relative;
	font-family: 'Neue', 'Source Sans Pro', sans-serif;
 	background-image: url('img/whitearrow.svg');
	background-repeat: no-repeat;
	background-position: 96% center; 

}

.callout
{
	background-color: #0095d7;
	color:#fff;
	padding:1rem;
	margin-bottom:1rem;

}

.callout h1
{
	margin: 0 0 1rem 0;
    padding-bottom: 0rem;
	border-bottom: 1px solid #fff;
	color:#fff;
}

blockquote 
{
    background-color: #fff;
    color: #00537E;
    padding: 0rem;
    margin: 0 0 0rem 0;
    font-style: normal;
    position: relative;
    border-top: 1px solid #0095d7;
    width: 30%;
    left: -44%;
    height: 0px;
    font-size: 1.8rem;
    margin-bottom:-2rem;
}


.alignleft, .alignnone, .aligncenter, .alignright
{
	display: block;
    float: none;
   	width: 100%;
   	height: auto;
   	margin:0;
   	padding:0;
}

.wp-block-image
{
	display: block;
	float:none;
	width:calc(100% + 25rem);
	width:100%;
    max-width: none;
    margin-right:0;

    margin-left: -20rem;
    margin-left: auto;
    margin-top: 3rem;
    margin-bottom: 3rem;

    position: relative;



}

.wp-block-image figure
{
	position: relative;
	width: 100%;
	height: 40rem;
   	height: auto;
}

.wp-block-image figcaption {
    text-align: center;
	font-size: 1.2rem;
	color: #999;
}
.wp-block-image figcaption a {
	color: #999;
}

figure img
{
	 width: 100%;
	 height: 100%;
	 object-fit: cover;
    	



   
}



/*blockquote:after
{
	position: absolute;
	top:100%;
	left:90%;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 2rem 2rem 0;
	border-color: transparent #a7b6a9 transparent transparent;

}

blockquote p {
	margin-bottom: 1.5em !important;
}*/



/*a.pinklink .pinkrightarrow
{
	position:absolute;
	bottom:0.5rem;
	right:1.5rem;
}

a.pinklink .pinkrightarrow
{
	font-size:2rem;
	display:inline-block;
	width:3.5rem;
	height:3.5rem;
	line-height:3rem;
	padding-top:0px;
	padding-left:3px;
	color:#fff;
	background-color:transparent;
	border-radius:50%;
	text-align: center;
	margin:0px 2px;
	border:2px solid #fff;
}

a.pinklink .pinkrightarrow i
{
	padding-top:0.5rem;
}*/

.sharebox
{
	border: 2px solid #c22c74;
	font-family: 'Neue', 'Source Sans Pro', sans-serif;
	color:#222;
	padding: 0.1rem 1.5rem 0.5rem 1.5rem;
	font-size: 1.5rem;
	font-weight: 300;

	margin-top:2rem;
}

.sharebox a
{
	font-size:2rem;
	display:inline-block;
	width:2.8rem;
	height:2.8rem;
	line-height:2.8rem;
	padding-top:0px;
	color:#fff;
	background-color:#00436f;
	border-radius:50%;
	text-align: center;
	margin:0px 2px;
}

.sharebox a i
{
	padding-top:0.7rem;
}

.sharebox a.share-email
{
	background-color: #fff;
	color:#777;
	font-size:1.5rem;

}



.sharebox a.share-facebook
{
	background-color: #3b5998;
}

.sharebox a.share-twitter
{
	background-color: #55acee;
}

.sharebox a.share-google
{
	background-color: #dd4b39;
}

.sharebox .printbox
{
	float:right;
	padding-top:0.4rem;
}

.sharebox .printbox a
{
	background-color: #777;
	color:#fff;
}



/* ports index */


.portindex
{
	width:49%;
	float:left;
	position:relative;
	height:0;
	padding-bottom:19.23%;
	margin-bottom:4.2rem;
}

.portindex.left
{
	margin-right:2%;
}

.portindex img
{
	width:100%;
	height:100%;
	position: absolute;
}

.portindex a
{
	text-decoration: none;
}

.portindex h1
{
	font-size:1.5rem;
	margin-top:38.46%;
	background-color: #e6e7e8;
    color: #00436f;
    padding:0.7rem 1rem 0.3rem;
    text-decoration: none;

}


/* guide to */

.blogdisplay
{
	position: relative;
	width:100%;
}

.islandblogitem
{
	width:32%;
	/*float:left;*/
	display: inline-block;
	vertical-align: top;
	margin: 1% 1% 1% 1%;
}

.islandblogitem.bcol0
{
	margin-left:0%;
	/*display:block;*/
	
}

.islandblogitem.bcol2
{
	margin-right:0%;
}

.islandblogitem h1
{
	font-size:2rem;
	line-height: 1.2;
	margin-top:0.5rem;
	margin-bottom:0.0rem;
	padding:0;

}
.islandintro {
	font-size:1.2rem;
}

#rightcontent .islandblogitem img
{
	margin:0;
}

.islandblogitem h1 a {
	text-decoration: none;
	color: #0071aa;
}

.staticgrey
{
	background-color: #e6e7e8;
    color: #58595b;
}

.staticgrey  h1 a
{
	color: #58595b;
}

.staticgrey .staticpad
{
	padding: 0rem 1rem 1rem 1rem;
}

.islandblog0
{
	/*width:66%;*/
}


.blogdisclaimer
{
	background-color: #e6e7e8;
    color: #58595b;
    padding:1rem;
    min-height: 100px;
	font-size:1.1rem;
}

.blogdisclaimer img
{ 
	float: left; 
	margin: 0px 10px 0px 0px;
}


#moreblogs h2
{
	color: #0071aa;
	font-size: 2.0rem;
	margin-top:2rem;
	margin-bottom:0.0rem;
}

h2.moreblogs
{
	position: relative;
    top: -3rem;
}


/* forms */

.ninja-forms-field[type="submit"], #subForm input[type="submit"] 
{
	background-color: #0095d7;
	font-size:2rem;
	color:#fff;
}

#subForm input[type="text"] 
{
	margin-top:0rem;
	margin-bottom:1rem;
	width:100%;
}

#subForm td
{
	text-align: left;
}


#subForm tr
{
	vertical-align: middle;
}

#subForm select {
    background-color: #e6e7e8;
    border: 0 solid #000;
    border-radius: 0;
    color: rgba(0, 0, 0, 1);
    font-family: "Neue","Source Sans Pro",sans-serif;
    font-size: 2rem;
    line-height: 1.1;
    padding: 1rem 1rem 0.5rem;
    width:100%;
    margin-bottom:1rem;
}




.row-hover tr:hover td{background-color:#d1f0ff !important;}
.even td {
    background-color: #f0faff !important;
}

table.tablepress tbody tr:first-child td, table.tablepress tbody td{
    border-top: 1px solid #94dbff;
    border-left: 1px solid #94dbff;
    border-right: 1px solid #94dbff;
    border-bottom: 1px solid #94dbff;
}

.tablepress tbody td, .tablepress tfoot th {
    border-top: 1px solid #94dbff !important;
}

table.tablepress.noborder td {
	border: 0px solid #ddd;
}
table.tablepress-id-30 td {
	border: 1px solid #fff !important;;
}
table.tablepress.noborder tbody tr:first-child td {
    border-top: 0px solid #ddd;
    border-left: 0px solid #ddd;
    border-right: 0px solid #ddd;
}

table.tablepress-id-ScrabstertoStromnessOffPeakTimetable td, table.tablepress-id-ScrabstertoStromnessOffPeakTimetable tr
{
	border: 1px solid #10ADE4 !important;
}

table.tablepress-id-ScrabstertoStromnessPeakTimetable td, table.tablepress tablepress-id-ScrabstertoStromnessPeakTimetable tr
{
	border: 1px solid #c22a73 !important;
}

table.tablepress-id-ScrabstertoStromnessWeekendTimetable td, table.tablepress-id-ScrabstertoStromnessWeekendTimetable tr
{
	border: 1px solid #015581 !important;
}

table.tablepress-id-pfjulymonfri td, table.tablepress-id-pfjulymonfri tr
{
	border: 1px solid #60408b !important;
}

table.tablepress-id-pfjulysun td, table.tablepress-id-pfjulysun tr
{
	border: 1px solid #600c3e !important;
}
table.tablepress-id-ScrabstertoStromnessOffPeakTimetable tr:hover td,
table.tablepress-id-ScrabstertoStromnessPeakTimetable tr:hover td,
table.tablepress-id-ScrabstertoStromnessWeekendTimetable tr:hover td,
table.tablepress-id-pfjulymonfri tr:hover td,
table.tablepress-id-pfjulysun tr:hover td {
	background-color:#eee !important;
}
#cinemaposters img {
	width: 127px;
	height: 188px;
	margin-right: 15px;
	margin-bottom: 15px;
	float: left;
}
#comp-pictures img {
	width: 340px;
	height: 185px;
	margin-right: 15px;
	margin-bottom: 15px;
	float: left;
}
table.tablepress-id-48 td, table.tablepress-id-48 tr
{
	border: 1px solid #fff !important;
}

.responsive-iframe
{
	position: relative;
    padding-bottom: 55.94%;
    padding-top: 0px;
    height: 0;
    overflow: hidden;

} 

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

.responsive-iframe.ratio715x400
{
	padding-bottom: 55.94%;
}

.accessbar
{
	position: absolute;
	width: 100%;
	background-color: transparent;
	z-index: 2500;
	height: 4rem;
}

a.reciteme, a.reciteme:visited
{
	position: absolute;
	top:0rem;
	right:8rem;
	background-color:#fff;
	font-size: 1.5rem;
	text-decoration: none;
	z-index: 500;
	display: table;
	padding:0.8rem 2rem;
	color:#00537E;
	font-weight: 400;

}


#searchform 
{
    position: absolute;
    right: 8rem;
    top: 1.9rem;
    width: 17rem;
    opacity: 1;
    display:none;
}

#searchform.active
{
	display:block;
}


#searchform input 
{
    background-color: #00436f;
    line-height: 1.8rem;
    font-size: 1.8rem;
    color: #fff;
    margin-top: 0.5rem;
    font-weight: 300;
    width: 17rem;
}


.mobilesearch input
{
	margin: 0 0 4rem 4rem;

	width: calc(100% - 8rem);

	background-color: #00436f;
    line-height: 1.8rem;
    font-size: 1.8rem;
    color: #fff;

    border-bottom:1px solid #fff;

}




/* responsive */


@media screen and (max-width: 1200px) 
{

	html
	{
		font-size: 12px;
	}

	#primary-menu li a 
	{
	    color: #fff;
	    padding: 2.9rem 1rem 2.3rem 1rem;
	    font-size: 1.5rem;
	    line-height: 1.8;
	    font-weight: 300;
	    display: inline-block;
	}

	#primary-menu li.servicestatus a 
	{
		padding-top:2.7rem;
	}

	#searchbutton 
	{
	    position: absolute;
	    
	}

.businesslistingarea { grid-template-columns: repeat(3, 1fr); }


}

@media screen and (max-width: 1024px) {

	html
	{
		font-size: 12px;
	}

	#mobilebar
	{
		display:block;
	}

	.mobilemenuopen #mobilebar
	{
		background-color: rgba(0,67,111,1);
	}

	.accessbar .innerwrapper
	{
		text-align: center;
	}

	a.reciteme, a.reciteme:visited
	{
		right: 0rem;
		position: static;
		display: inline-block;

	}

	#searchbox, #site-navigation, #tickertape, #searchbutton
	{
		display:none;
	}

	.entry-content, .entry-footer
	{
		padding-left:2rem;
		padding-right:2rem;
	}

	.mobilesearchopen #searchbox
	{
		display:block;
		left: 9rem;
    	top: -5.5rem;
    	width: calc(100% - 9rem);
	}

	#searchbox input 
	{
    	width: calc(100% - 9rem);
	}

	
	#masthead
	{
		
	}

	#viking 
	{
	    left: 0%;
	    position: absolute;
	    top: 0rem;
	    width: 11rem;
	    z-index: 999;
	}

	.site-branding .site-title a 
	{
    	display: block;
    	float: right;
    	padding-bottom: 2rem;
    	padding-right: 3rem;
    	padding-top: 3rem;
    	width: 40%;
	}

	#leftcol
    {
    	/*display: none;*/
    }


	.home #leftcol, #leftcol
	{
		width:100%;
		display:block;
		top:0rem;
		position: relative;
		left:0rem;
		
	   	/**/
    }

    .widget_xyz_insert_html_widget iframe , .widget_custom_html iframe 
    {
	    height: 50vh;
	    min-height: 400px;
	    width: 100%;
	}

.businesslistingarea { grid-template-columns: repeat(2, 1fr); }


    .widget_northlinkbookingwidget
    {
    	min-height: 300px;
    }

	#main, .home #main
	{
		width:100%;
		display:block;
		padding-left:0px;
		margin-bottom:2%;
	}

	#rightcontent
	{
		width:100%;
	}

	#rightcontent img
	{
		float:none;
		margin:1rem 0;
		width:100%;
		height:auto;
	}

#rightcontent .blogdisclaimer img {
	width: 75px !important;
	height: 75px !important;
	float: left;
	margin: 0px 10px 0px 0px;
}
	#rightcontent header img
	{
		margin:0rem 0;
	}

	#ourroutes a.bluerectbutton, a.bluerectbutton
	{
		width:100%;
		text-align: center;
		left:0px;
		bottom:0px;
		font-size: 3.5rem;
		padding:2rem 2rem 1.5rem 2rem;

	}

	a.bluerectbutton span.arrowbutton 
	{
    	padding-top: 2px;
	}


	#newsgrid
	{
		/*display:none;*/
		position: relative;
		width:100%;

		padding-top:2rem;
	}

	.sliderow
	{
		position:relative;
		width:64%;
		height:0px;
		padding-bottom:54.00%;
		margin-left:18%;

		display:block;
		
		clear:both;
		float:none;
		z-index:999;
	}

	.prevbutton, .nextbutton, .slidepager, .slidenav
	{
		display:block;
	}

	.slidenav
	{
		position:absolute;
		clear:both;
		width:100%;
		height:0px;
		padding-bottom:84.00%;

		z-index:998;
	}

	.slidepager
	{
		width:100%;
		text-align: center;
		margin:0.5rem 0rem 1rem 0rem;
	}

	.slidepager span
	{
		padding:0rem 0.25rem;
	}

	.slidepager i.fa-circle
	{
		display:inline;
	}
	
	.slidepager i.fa-circle-o
	{
		display:none;
	}


	.slidepager .cycle-pager-active i.fa-circle
	{
		display:none;
	}
	
	.slidepager .cycle-pager-active i.fa-circle-o
	{
		display:inline;
	}

	.prevbutton, .nextbutton
	{
		display:block;
		position:absolute;
		top:50%;
		width:18%;
		font-size:8rem;
		color:#0095d7;
		cursor: pointer;

		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);

	}




	.prevbutton
	{
		left:1%;
		text-align: left;
	}

	.nextbutton
	{
		right:1%;
		text-align: right;
	}


	#secondrow
	{
		/*display:none;*/
	}

	#thirdrow
	{
		/*display:none;*/
	}

	.gridbox {
		width:100%;
		height:100%;
		float:none;
		padding:0;
		margin:0;
	}

	.gridbox img {
		width:auto;
		height:105%; 


	}

	.gridbox.col1, .gridbox.col2, .gridbox.col3 {
    	margin-left: 0;
    	margin-right: 0;
	}

	.gridbox .gridfootertext, .gridbox .arrowbutton {
		display:none;
	}

	.gridbox h1
	{
		width:100%;
		bottom:0px;
	}






	#tripad
	{
		display:none;
	}

	#sociallinks
	{
		width:100%;
		margin-left:0;
		margin-right:0;
		text-align: center;
	}

	#sociallinks a 
	{
	    font-size: 1.5rem;
	    height: 3rem;
	    line-height: 3.1rem;
	    margin: 0 4px;
	    padding-top: 0;
	    width: 3rem;
	}

	#footernav 
	{
    	padding: 0rem 0rem 5rem 0rem;
	}

	#footernav ul li
	{
		display:inline-block;
		color:#fff;
		vertical-align: top;
		width:100%;
		font-weight: normal;
		font-size: 2rem;
		border-bottom: 2px solid #fff;
		
	}

	#footernav ul li a
	{
		color:#fff;
		text-decoration: none;
		width:100%;
		padding:1rem 5rem;
		display: block;

	}

	#footernav ul li a span.plus
	{
		display:inline-block;
		float:right;
	}

	#footernav ul li a span.minus
	{
		display:none;
		float:right;
	}

	#footernav ul li.expanded a span.plus
	{
		display:none;
		float:right;
	}

	#footernav ul li.expanded a span.minus
	{
		display:inline-block;
		float:right;
	}

	#footernav ul ul.sub-menu
	{
		margin-top:0.5rem;
		display:none;
	}

	#footernav ul li.expanded ul.sub-menu
	{
		display:block;

		margin-bottom:2rem;
	}

	#footernav ul li li
	{
		width:100%;
		color:#0095d7;
		font-weight: normal;
		font-size: 1.5rem;
		border-bottom:0px;
		
	}

	#footernav ul li li a span.plus
	{
		display:none;
		
	}

	#footernav ul li.expanded li a span.minus
	{
		display:none;
	}
	
	#footernav ul li a span
	{
		font-size:1.5rem;
		
		width:3.0rem;
		height:3.0rem;
		line-height:2.5rem;
		padding-top:0px;
		padding-left:1px;
		color:#fff;
		background-color:transparent;
		border-radius:50%;
		text-align: center;
		margin:0px 2px;
		border:2px solid #fff;
	}




	#footerright 
	{
    	margin-left: 0;
    	padding-bottom: 250px;
    	width: 100%;
	}

	#footerlogo 
	{
    	margin-left:2%;
    	width:46%;
	}

	#footerlogo img 
	{
        top: 0px;
    	
	}

	#copyetc
	{
		font-size:1.0rem;
		margin-right:2%;
		margin-top: 4rem;
    	width:46%;
	}



	.single-faq h3
	{
		padding: 1.5rem 5.5rem 1.5rem 1.5rem;
	}

	.sharebox
	{
		display: none;
	}

	.portindex
	{
		width:100%;
		float:none;
		position:relative;
		height:auto;
		margin-bottom:1rem;
		padding-bottom: 0px;
		line-height: 0;
	}

	.portindex.left
	{
		margin-right:0%;
	}

	#rightcontent .portindex img
	{
		width:100%;
		height:auto;
		position: static;
		margin:0;
	}

	
	.portindex h1
	{
		font-size:2rem;
		margin-top:0%;
		background-color: #e6e7e8;
	    color: #00436f;
	    padding:0.7rem 1rem 0.3rem;
	    text-decoration: none;
	    line-height: 1.2;

	}


	/* guide to */

	.blogdisplay
	{
		
	}

	.islandblogitem
	{
		width:100%;
		/*float:left;*/
		display: block;
		margin: 0% 0% 4% 0%;
	}

	.islandblogitem.bcol0
	{
		margin-left:0%;
		/*display:block;*/
		
	}

	.islandblogitem.bcol2
	{
		margin-right:0%;
	}

	.islandblogitem h1
	{
		font-size:2.4rem;
		line-height: 1.2;
		margin-top:0.5rem;
		margin-bottom:0.0rem;
		padding:0;

	}

	.staticgrey .staticpad
	{
		padding: 0rem 1rem 1rem 1rem;
	}

	.islandblog0
	{
		width:100%;
	}

#cinemaposters img {
	width: 127px;
	height: 188px;
	margin-right: 15px;
	margin-bottom: 15px;
	float: left;
}
a.month-previous {
    margin-left: 0px;
    margin-right: 15px;
    margin-bottom: 15px;
    margin-left: 0px;
}
a.month-next {
    margin-left: 0px;
    margin-right: 0px;
    margin-bottom: 15px;
    margin-left: 0px;
}


.home .homehero, .homehero 
{
   	height: 58.46vw;
    margin-bottom: 0;
    margin-top:4rem;
}





.homehero h1 
{
    top: 1rem;
    right: 0rem;
    text-align: center;
    width: 100%;
    position: relative;
    font-size: 2.5rem;
    padding-right:0;
    
}



.herotextholder, .home .herotextholder
{
	position: absolute;
	bottom:2rem;
}

.herointro 
{
    width: 100%;
    margin-left: 0%;
    padding: 2rem 2rem;
    text-align: center;
    font-size: 1.5rem;
    margin-bottom: 0rem;
    font-weight: 700;
    min-height: 0rem;
}
.bizintro 
{
    width: 100%;
    margin-left: 0%;
    padding: 2rem 2rem;
    text-align: center;
    font-size: 1.5rem;
    margin-bottom: 0rem;
    font-weight: 700;
    min-height: 0rem;
}

.page-template-front .herointro 
{
	margin-bottom: 8rem;
}
	
.page-template-front .bizintro 
{
	margin-bottom: 8rem;
}

.extrablocks.bigblocks .extrablock 
{
    width: 100%;
    padding-bottom: 80%;
}

.routesplit
{
	
	top:0rem;
}

.routehalf 
{
    width: 100%;
    float: none;
    font-size: 1.5rem;
}


.routehalf.withtext 
{
    padding: 0rem 2rem 0rem 2rem;
}

.routehalf img 
{
    width: calc(100% - 4rem);
    height: auto;
    margin-left: 2rem;
}

.routehalf a.bluerectbutton 
{
    margin-top: 2rem;
    margin-bottom: 2rem;
    display: table;
}

.extrablocks .extrablock 
{
    width: 100%;
    display: block;
    
    padding-bottom: 60%;
}

.featurehalfholder 
{
    width: 100%;
    position: relative;
    margin: 0rem 0rem;
}

.featurehalf 
{
    width: 100%;
    float: none;
    margin: 0rem;
    font-size: 1.5rem;
}

.featurehalf.withtext {
    padding: 0rem 2rem 5rem 2rem;
}



.footerinfo 
{
    float: none;
    width: 100%;
    position: relative;
    text-align: center;
    max-width: 300px;
    margin: 0 auto;
}

.footeright 
{
    float: none;
    width: 100%;
    position: relative;
    padding: 0rem 2rem;
}

.footerint 
{
    width: 100%;
    position: relative;
    max-width: 1440px;
    margin: 0 auto;
    padding: 4rem 0rem;
}

.footerlinks 
{
    float: none;
    width: 100%;
    position: relative;
    text-align: center;
}

.footermenus 
{
    float: none;
    width: 100%;
    position: relative;
}

.menucol 
{
    display: table;
    vertical-align: top;
    width: 100%;
}

.menucol ul 
{
    list-style: none;
    margin: 0 0 2rem 0;
    padding: 0;
    min-height: 0rem;
}

.menucol ul li a 
{
    text-decoration: none;
    font-weight: bold;
    color: #fff;
    font-size: 1.5rem;
    border-bottom: 1px solid #fff;
    padding-bottom: 1rem;
    display: block;
}

.menucol ul ul 
{
    margin-top: 0.5rem;
    display: none;
}


.extramenucol ul 
{
    list-style: none;
    margin: 0 0 2rem 0;
    padding: 0;
    min-height: 0rem;
}

.sociallinks 
{
    margin-bottom: 2rem;
}



.herotitleholder h1 
{
    text-shadow: 0px 0px 1rem rgba(0,0,0,0.8);
    margin: 0 0 0 0%;
}



.menublocksarea 
{
    width: 100%;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    background-color: #eeeeee;
    padding-bottom: 4rem;
    margin-top: 4rem;
}

.menublocks 
{
    clear: both;
    width: 100%;
    margin-left: 0rem;
    margin-right: 0rem;
    position: relative;
    margin-bottom: 2rem;
    top: -4rem;
}

.menublocks .pageblock 
{
    width: 100%;
    margin:0;
}
	
.textpart 
{
    min-height: 15rem;
}


a.prearrow {
    display: block;
    font-weight: 300;
    text-decoration: none;
    font-size: 1.5rem;
    position: relative;
    bottom: 0rem;
    left: 0rem;
}

.extrablocks.bigblocks 
{
    top: 0rem;
}

.menublocks.guideblocks {
    top: 0rem;
}

.menublocks.guideblocks .pageblock {
    width: 100%;
}

.normalcontent 
{
    width: 100%;
    margin-left: 0%;
    padding: 2rem 2rem;
    text-align: left;
    font-size: 1.5rem;
    margin-bottom: 4rem;
    font-weight: 400;
}


.opsnews-title 
{
    line-height: 1.5 !important;
    display: block;
    display: inline;
    white-space: normal;
    overflow: visible;
}



.entry-content, .entry-footer {
    padding-left: 0rem;
    padding-right: 0rem;
}


	h2.moreblogs
	{
		position: relative;
	    top: 2rem;
	    padding-left:2rem;
	}


	
}

@media screen and (max-width: 790px) {

    .businesslistingarea { grid-template-columns: repeat(1, 1fr); }
	.businesslisting { height: 60rem; }
	
}	


@media screen and (max-width: 560px) {

    .businesslistingarea { grid-template-columns: repeat(1, 1fr); }
	.businesslisting { height: 50rem; }
	#copyetc
	{
		margin-top: -1rem;
    	
	}

	#footerright 
	{
    	
    	padding-bottom: 50px;
    	
	}

	#ourroutes
	{
		padding-bottom:85%;
	}

	#ourroutes h1
	{
		font-size:2.5rem;
		margin: 2rem 2rem 1rem;
		border-bottom: 1px solid #fff;
	}


	#ourroutes a.bluerectbutton, a.bluerectbutton
	{
		font-size: 2.5rem;
	}

	.site-branding .site-title a 
	{
   		padding-bottom: 1.5rem;
    	padding-right: 3rem;
    	padding-top: 2.5rem;
    	
	}

	.gridbox h1
	{
		font-size: 1.5rem;
	}

.panel {
	float: left;
	width:100%;
	margin-left:1%;
	margin-right:1%;
	margin-top:0%;
	margin-bottom:1.7rem;
	color:#fff;
	background-color:#0095d7;
}
a.panelarrowbutton, span.panelarrowbutton
{
	font-size:2rem;
	display:inline-block;
	width:3.0rem;
	height:3.0rem;
	line-height:2.5rem;
	padding-top:0px;
	padding-left:3px;
	color:#fff;
	background-color:transparent;
	border-radius:50%;
	text-align: center;
	margin:0px 2px;
	border:2px solid #fff;
	float: right;
}


#cinemaposters img {
	width: 100%;
	height: auto;
	margin-right: 0px;
	margin-bottom: 15px;
}
a.month-previous {
    margin-left: 0px;
    margin-right: 0px;
    margin-bottom: 15px;
    margin-left: 0px;
}
a.month-next {
    margin-left: 0px;
    margin-right: 0px;
    margin-bottom: 15px;
    margin-left: 0px;
}
}
@media screen and (max-width: 500px) {

    .businesslistingarea { grid-template-columns: repeat(1, 1fr); }
	.businesslisting { height: 50rem; }
}