/*
Theme Name: CaterMap
Theme URI: http://www.catermap.co.uk/
Description: Strawberry fresh
Version: 1.0
Author: Craig Buckler, Optimalworks Ltd
Author URI: http://www.optimalworks.net/
*/
*
{
	padding:0;
	margin:0;
}

/* layout */
body
{
	font-size: 85%;
	color: #444;
	background-color: #117;
	border: 0 none;
}

body, #catermap
{
	font-family: georgia, "times new roman", times, serif;
}

#skip, #header, #footer, h1, h2, h3, q cite, legend, input, select, textarea
{
	font-family: arial, helvetica, freesans, sans-serif;
}

#header, #quote, #main, #footer
{
	clear: both;
	width: 100%;
	min-width: 764px;
	overflow: auto;
	z-index: 0;
}

div.content
{
	height: 1%;
	max-width: 65em;
	padding: 0 2% !important;
	padding: 0 20px;
	margin: 0 auto;
	z-index: 0;
}


/* columns */
.row
{
	clear: both;
	position: relative;
	display: inline;
	float: left;
	width: 100%;
	overflow: hidden;
}

.col
{
	position: relative;
	display: inline;
	float: left;
	left: 100%;
	overflow: hidden;
}


/* skip */
#skip
{
	padding: 0;
	margin: 0;
}

#skip a
{
	position: absolute;
	display: block;
	left: 0;
	top: 0;
	font-size: 0.9em;
	text-decoration: none;
	padding: 0.2em 0.5em;
	color: #33e;
	background-color: #282898;
	z-index: 10;
}

#skip a span
{
	display: none;
}

#skip a:focus, #skip a:hover
{
	color: #b9b9ec;
}

#skip a:focus span, #skip a:hover span
{
	display: inline !important;
	display: none;
}

/* header */
#header
{
	height: 128px;
	background: url("images/header.png") 0 0 repeat-x;
}

#catermap
{
	display: block;
	float: left;
	height: 100px;
	outline: 0 none;
}

#catermap img
{
	font-size: 5em;
	line-height: 80px;
	margin: 12px 0 0 0;
	color: #fff;
}

/* menu */
#menu
{
	position: relative;
	float: right;
	height: 128px;
	padding: 0;
	margin: 0;
	border-right: 1px solid #06064b;
	overflow: hidden;
}

#menu li
{
	display: inline;
	float: left;
	padding: 0;
	margin: 0;
	border-left: 1px solid #06064b;
}

#menu a
{
	display: block;
	width: 5.6em;
	height: 30px;
	line-height: 30px;
	font-size: 1.1em;
	text-align: center;
	text-transform: lowercase;
	text-decoration: none;
	padding: 70px 0 0 0;
	color: #b9b9ec;
	outline: 0 none;
}

#menu li.open a, #menu li.active a, #menu a:focus, #menu a:hover
{
	font-weight: bold;
	color: #fff;
	background-color: #117;
}

/* sub-menu */
#menu ul
{
	position: absolute;
	display: none;
	height: 28px;
	padding: 0;
	margin: 0;
	right: 0;
	bottom: 0;
}

#menu li.open ul, #menu li.active ul
{
	display: block;
}

#menu ul li
{
	padding: 0;
	margin: 0 0.6em;
	background-color: transparent;
	border: 0 none;
}

#menu li.open ul a, #menu li.active ul a
{
	display: block !important;
	display: inline;
	width: auto;
	height: 28px;
	line-height: 26px;
	font-size: 0.9em;
	font-weight: normal !important;
	padding: 0;
	margin: 0;
	color: #b9b9ec;
}

#menu ul li.active a
{
	font-weight: bold !important;
	color: #fff;
}

#menu ul li a:focus, #menu ul li a:hover
{
	color: #fff;
}

/* quote */
#quote
{
	background: #fff url("images/shadequote.png") 0 0 repeat-x;
}

q
{
	display: block;
	width: 15em;
	font-size: 2.4em;
	font-style: italic;
	text-align: center;
	padding: 40px 0 40px 0.5em;
	color: #7a7af7;
}

q span
{
	display: block;
}

q strong
{
	font-weight: normal;
	color: #5656af;
}

q cite
{
	display: block;
	font-size: 0.55em;
	font-style: normal;
	text-align: right;
	margin-top: 0.5em;
	color: #777;
}


/* quote backgrounds */
#quote div.content
{
	height: auto !important;
	height: 300px;
	min-height: 300px;
	background: url("images/background/strawberries.jpg") 95% 98% no-repeat;
}

#independen #quote div.content { background-image: url("images/background/aubergine.jpg"); }

#training #quote div.content { background-image: url("images/background/cauliflower.jpg"); }

#contactus #quote div.content { background-image: url("images/background/courgettes.jpg"); }

#services #quote div.content,
#aboutus #quote div.content { background-image: url("images/background/onions.jpg"); }

#collegesan #quote div.content { background-image: url("images/background/peppersred.jpg"); }

#references #quote div.content { background-image: url("images/background/pepperyellow.jpg"); }

#clients #quote div.content { background-image: url("images/background/pupils.jpg"); }

#whatwedo #quote div.content { background-image: url("images/background/radish.jpg"); }

#schools #quote div.content { background-image: url("images/background/sprouts.jpg"); }

#whatitcost #quote div.content { background-image: url("images/background/tomatos.jpg"); }


/* main content */
#main
{
	background: #ebebff url("images/shadecontent.png") 0 0 repeat-x;
	overflow: hidden;
}

#article
{
	width: 60%;
	padding: 30px 1px;
	margin-left: -100%;
}


/* sidebar */
#sidebar
{
	width: 35%;
	padding-bottom: 10000px;
	margin-bottom: -10000px;
	margin-left: -35%;
	background-color: #e1e1f4;
}

#sbinner
{
	padding: 30px 20px;
	background: url("images/shadesidebar.png") 0 0 repeat-x;
}

/* how */
#how
{
	width: 100%;
	font-size: 1.8em;
	letter-spacing: -0.05em;
	margin: 0;
	overflow: auto;
}

#how a
{
	display: block;
	width: 100%;
	outline: 0 none;
}

#how img
{
	display: inline;
	float: right;
	margin: 0 0 2px 2px;
}

/* news */
#newslist
{
	list-style-type: none;
	padding: 0;
	margin: 0 0 1em 0;
}

#newslist li
{
	clear: both;
	padding: 0;
	margin: 0 0 0.5em 0;
}

#newslist a
{
	display: block;
	font-size: 1.3em;
	font-style: italic;
	padding: 0.3em 0;
}

#newslist .allnews a
{
	text-align: right;
}


/* news navigation */
ul#newsnav
{
	clear: left;
	float: left;
	width: 100%;
	list-style-type: none;
	padding: 4px 0 6px 0;
	margin: 3em 0 0 0;
	border-top: 1px solid #e1e1f4;
}

ul#newsnav li
{
	display: inline;
	float: left;
	width: 45%;
	padding: 0;
	margin: 0;
	background-image: none;
}

ul#newsnav li a
{
	display: block;
}

ul#newsnav li strong
{
	display: block;
	float: left;
	padding: 0;
	margin: 0;
}

ul#newsnav li span
{
	display: block;
	padding: 0;
	margin: 0 0 0 4em;
}

ul#newsnav li.next
{
	float: right;
	text-align: right;
}

ul#newsnav li.next strong
{
	float: right;
}

ul#newsnav li.next span
{
	display: block;
	margin: 0 4em 0 0;
}

/* contact button */
p#contact
{
	clear: both;
	margin: 2em 0;
}

#contact a
{
	position: relative;
	display: block;
	width: 235px;
	height: 72px;
	text-align: center;
	padding: 0;
	margin: 0 auto;
	color: #ccc;
	background-color: #005;
}

#contact a span
{
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url("images/contact.png") 0 0 no-repeat;
}

#contact a:hover, #contact a:focus
{
	color: #fff;
	background-color: #008;
}

#contact a:hover span, #contact a:focus span { background-position: 0 -72px; }

#contact a strong
{
	display: block;
	font-size: 1.6em;
	font-weight: normal;
	padding-top: 0.5em;
}

/* social bookmarking */
#share p
{
	font-size: 0.85em;
	font-style: italic;
	margin-bottom: 0.4em;
}

#share ul
{
	height: 16px;
	list-style-type: none;
	padding: 0;
	margin: 0;
}

#share li
{
	display: inline;
	float: left;
	width: 16px;
	height: 16px;
	padding: 0;
	margin: 0 6px 0 0;
}

#share a
{
	display: block;
	width: 16px;
	height: 16px;
	text-indent: -9999px;
	background-image: url("images/bookmark.png");
	background-repeat: repeat-x;
	outline: 0 none;
}

a.delicious { background-position: 0 0; }
a.digg { background-position: -16px 0; }
a.buzz { background-position: -32px 0; }
a.twitter { background-position: -48px 0; }
a.stumbleupon { background-position: -64px 0; }
a.google { background-position: -80px 0; }
a.yahoo { background-position: -96px 0; }
a.live { background-position: -112px 0; }
a.reddit { background-position: -128px 0; }
a.furl { background-position: -144px 0; }
a.spurl { background-position: -160px 0; }
a.blinklist { background-position: -176px 0; }
a.facebook { background-position: -192px 0; }
a.linkedin { background-position: -208px 0; }
a.slashdot { background-position: -224px 0; }
a.technorati { background-position: -240px 0; }


/* page navigation */
#pagenav
{
	clear: both;
	display: inline;
	float: right;
	list-style-type: none;
	padding: 0;
	margin: 2em 0 0 0;
}

#pagenav li
{
	display: inline;
	float: left;
	padding: 0;
	margin: 0 0 0 3px;
}

#pagenav a, #pagenav strong, #pagenav span
{
	display: block;
	width: 1.5em;
	height: 1.5em;
	text-align: center;
	text-decoration: none;
	line-height: 1.5em;
	border: 1px solid #039;
}

#pagenav a:hover, #pagenav a:focus { background-color: #fff; }

#pagenav li.control a, #pagenav li.control span { width: 3.4em; }

#pagenav strong
{
	color: #fff;
	background-color: #039;
}

#pagenav span
{
	color: #ccc;
	border-color: #ccc;
}

/* footer */
#footer
{
	background: #117 url("images/shadefooter.png") 0 0 repeat-x;
}

#footer div.row
{
	padding-top: 20px;
	padding-bottom: 20px;
}

#copyright
{
	font-size: 0.9em;
	width: 30em;
	margin-left: -100%;
	text-align: left;
}

#optimalworks
{
	font-size: 0.9em;
	width: 24em;
	margin-left: -24em;
	text-align: right;
}

#footer p
{
	margin: 0.2em 0;
	color: #b9b9ec;
}

#footer a, #footer a:link, #footer a:visited { text-decoration: none; color: #b9b9ec; }
#footer a:focus, #footer a:hover { color: #fff; }


/* typography */
h1, h2, h3
{
	clear: both;
	font-size: 2.2em;
	font-weight: normal;
	line-height: 1em;
	letter-spacing: -0.02em;
	margin: 1.6em 0 0.1em 0;
	margin-bottom: 0.1em;
}

h1.main, .main h1 { margin-top: 0; }

h2
{
	font-size: 1.6em;
}

h3
{
	font-size: 1.2em;
	font-weight: bold;
}

p
{
	margin: 0 0 1em 0;
}

ul, ol, dl
{
	margin: 1em 0 1.5em 4em;
}

ul
{
	list-style-type: disc;
}

li
{
	margin: 0.5em 0;
}

dt
{
	font-size: 1.1em;
	font-weight: bold;
	margin-bottom: 0.1em;
}

dd
{
	font-style: italic;
	margin: 0 0 1.5em 0;
}

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

blockquote
{
	width: 75%;
	font-style: italic;
	text-align: center;
	padding: 10px 15px;
	margin: 1em auto 0 auto;
	color: #555;
	background: url("images/quote.png") 100% 0 no-repeat;
}

blockquote p
{
	font-size: 1.5em;
	line-height: 1.1em;
	margin: 0 0 1em 0;
}

acronym
{
	text-decoration: underline;
	border: 0 none;
}

img
{
	border: 0 none;
}

img.photo
{
	display: inline;
	float: right;
	padding: 4px;
	margin: 0 0 4px 6px;
	background-color: #fff;
	border: 1px solid #ccc;
}

h1 a, h2 a, h3 a { display: block; }
a, a:link { text-decoration: none; color: #039; }
a:visited { color: #68a; }
a:focus, a:hover { color: #c00; }


/* forms */
form { height: 1%; }

fieldset
{
	height: 1%;
	padding: 10px 6px;
	margin: 2em auto;
	border: 0 none;
	border-top: 1px solid #bbe;
}

fieldset legend
{
	font-size: 1.4em;
	font-weight: normal;
	padding: 0 4px;
}

fieldset p
{
	clear: both;
	padding: 5px 0;
	margin: 0 10px;
}

fieldset ol
{
	list-style-type: none;
	padding: 0;
	margin: 0;
}

fieldset li
{
	clear: both;
	height: 1%;
	padding: 0;
	margin: 2px 10px;
	overflow: auto;
}

fieldset li.checkbox
{
	padding-left: 42%;
}

label
{
	float: left;
	width: 40%;
	font-size: 0.9em;
	text-align: right;
	line-height: 1.1em;
	padding: 0;
	margin: 0 2% 0 0;
}

.checkbox label
{
	display: inline;
	float: left;
	width: 80%;
	font-weight: normal;
	text-align: left;
	line-height: 1.4em;
	margin: 0 0 0 6px;
}

input, select, textarea
{
	width: 53%;
	font-size: 1.25em;
	font-weight: bold;
	text-align: left;
	padding: 1px 2px 2px 2px;
	margin: 0;
	color: #117;
	background: #f3f3ff url("images/shadeinput.png") 0 0 repeat-x;
	border: 1px solid #bbe;
}

.inputsml
{
	width: 25%;
}

.checkbox input
{
	display: inline;
	float: left;
	width: auto;
	padding: 0;
	margin: 0.3ex 0;
	border: 0 none;
	color: #fff;
	background: transparent none !important;
	background-color: #ebebff;
}

input:focus, select:focus, textarea:focus { background: #fff none; }

input.button
{
	display: block;
	font-size: 1em;
	font-weight: bold;
	width: 10em;
	text-align: center;
	padding: 2px 0 4px 0;
	margin: 2px 0 0 42%;
	color: #ccc;
	background: #117 url("images/shadebutton.png") 0 0 repeat-x;
	border: 1px solid #117;
	cursor: pointer;
}

input.button:focus, input.button:hover
{
	color: #fff;
	background: #117 url("images/shadebuttonh.png") 0 100% repeat-x;
}

.error label, p.error { font-weight: bold; color: #c00; }
.error input, .error select, .error textarea { border-color: #c00; }
p.help { display: none; }
.error p.help
{
	display: block;
	font-size: 0.8em;
	padding: 0;
	margin: 12px 0 0 42%;
	color: #c00;
}


/* refer form styles */
#refer label
{
	display: block;
	float: none;
	width: auto;
	text-align: left;
	padding: 5px 0 2px 0;
}

#refer input
{
	width: 96%;
}

#refer input.button
{
	width: 6.5em;
	padding: 1px 0 2px 0;
	margin: 0 auto;
}

#refer p
{
	font-size: 0.9em;
	font-weight: bold;
	text-align: center;
	padding: 0.4em 0 0 0;
	margin: 0;
	color: #0cad49;
	white-space: nowrap;
	overflow: hidden;
}

#refer p.error { color: #c00; }
#refer p.active { background: url("images/ajax.gif") 50% 100% no-repeat; }

/* calendar */
span.date
{
	display: block;
	float: left;
	width: 1.2em;
	height: 1.6em;
	font-family: arial, sans-serif;
	font-weight: bold;
	font-style: normal;
	font-size: 1.7em;
	text-align: center;
	line-height: 1em;
	padding: 0;
	margin: 0 0.25em 0 0;
	color: #555;
	border: 1px solid #ddd;
	border-top: 0 none;
	background: #fff url("images/shadedate.png") 100% 100% no-repeat;
	overflow: hidden;
}

a span.date
{
	cursor: pointer;
}

#article span.date
{
	float: right;
	font-size: 1.2em;
	margin: 0;
}

span.date strong
{
	display: block;
	font-size: 0.4em;
	line-height: 1em;
	text-transform: uppercase;
	padding: 1px 0;
	margin: 0 0 2px 0;
	color: #fff;
	background-color: #117;
}

/* hCard microformat */
div.vcard
{
	width: 22em;
	font-size: 1.1em;
	margin: 0 auto;
	padding: 10px 15px;
	background: #fff;
	border-left: 35px solid #117;
	border-right: 1px solid #117;
	border-bottom: 1px solid #117;
}

div.vcard p
{
	font-weight: bold;
	margin: 0;
}

div.vcard ol, div.vcard li
{
	list-style-type: none;
	padding: 0;
	margin: 0;
	line-height: 1.1em;
}

div.vcard dl
{
	clear: left;
	margin: 0.2em 0;
}

div.vcard dt
{
	float: left;
	font-size: 1em;
	width: 4.2em;
	margin: 0;
}

div.vcard dd
{
	font-style: normal;
	margin: 0;
}

div.vcard a, div.vcard a:visited, div.vcard a:hover { color: #555; text-decoration: none; }

a.add
{
	display: block;
	font-size: 0.9em;
	font-style: italic;
	text-align: center;
	margin: 6px 0;
}