/** 
    grahammcculloch.co.za main website stylesheet
    author : johann loubser, the medium design solutions
    created : 9 August 2007
*/
a:link, a:visited {
    color: #C82926;
    font-weight: bold;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

body {
    background: #ffffff url(/images/body_bg.jpg) repeat-y center 3px;
    color: #3E3E40;
    font-family: Verdana, serif;
    font-size: 13px;
    margin: 0 0 0 0;
}

h3 {
    color: #CA3435;
    font-family: "Trebuchet MS", Arial, sans-serif;
    font-size: 20px;
    font-style: italic;
    font-weight: bold;
    margin: -15px 0 10px 0;
    padding: 0 0 0 0;
}

img {
    border: 0;
}

p {
    font-family: Verdana, Arial, sans-serif;
    line-height: 150%;
}

div#wrapper {
    background: transparent url(/images/wrapper_bg.jpg) no-repeat top center;
    height: 500px;
    height: 500px;
    width: 100%;
}

div#header {
    background: #FFFFFF url(/images/header_bg.jpg) no-repeat top left;
    border-bottom: 1px solid #FFFFFF;
    height: 212px;
    margin: auto;
    padding: 0 0 0 0;
    width: 870px;
}

#admin_home div#header {
    background: #FFFFFF url(/images/header_bg.jpg) no-repeat top left;
    border-bottom: 2px solid #FFFFFF;
    height: 173px;
    margin: auto;
    padding: 0 0 0 0;
    width: 870px;
}

div#header #emblem {
    float: left;
    margin: 0 0 0 30px;
    vertical-align: top;
}

div#header h1 {
    float: left;
    font-size: 30px;
    margin: 0 31px 0 11px;
    padding: 0;
    vertical-align: top;
}

div#header h2 {
    color: #707173;
    float: left;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 30px;
    font-style: italic;
    font-weight: normal;
    height: 100px;
    margin: 14px 0 0 0;
    padding: 0;
    text-align: center;
    width: 325px;
}

div#header h2 img {
    margin-bottom: -20px;
}

div#header h2 strong {
    color: #C72A25;
    font-weight: normal;
    text-decoration: underline;
}

div#main_menu {
    background-color: #C72A25;
    border-top: 2px solid #9C221F;
    clear:left;
    height: 37px;
}

div#main_menu ul {
    margin: 0;
    padding: 0;
}

div#main_menu ul li {
    float: left;
    list-style-type: none;
    margin: 0;
    padding: 0;
}

div#main_menu ul li a:link, div#main_menu ul li a:visited {
    background: transparent url(/images/menu_item_bg.gif) no-repeat top right;
    color: #FFFFFF;
    display: block;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 0.1em;
    line-height: 37px;
    text-align: center;
    text-decoration: none;
    width: 102px;
}

div#main_menu ul li a:hover {
    background-color: #AF2522;
    background-image: none;
}

div#main_menu ul li a.current:link, div#main_menu ul li a.current:visited {
    background-color: #9C221F;
    background-image: none;
}

div#main_menu em {
    color: #FFFFFF;
    float: right;
    font-family: Georgia, serif;
    font-size: 16px;
    font-weight: bold;
    line-height: 37px;
    margin-right: 36px;
}

div#header_bottom {
    background: #9c221f url(/images/header_bottom_bg.jpg) repeat-x top left;
    color: #FFFFFF;
    height: 39px;
}

div#header_bottom a:link, div#header_bottom a:visited {
    color: #FFFFFF;
    text-decoration: none;
}

div#header_bottom a:hover {
    border-bottom: 1px dashed #FFFFFF;
}

div#header_bottom em {
    float: left;
    line-height: 38px;
    margin-left: 28px;
}

div#header_bottom div#sunshine {
    float: right;
    height: 39px;
    margin: 0 0 0 0;
    padding: 0 0 0 0;
}

div#header_bottom div#sunshine img {
    float: left;
    margin: 0 7px 0 0;
    vertical-align: middle;
}

div#header_bottom div#sunshine a:link, div#header_bottom div#sunshine a:visited {
    background: #EFAD32 url(/images/sunshine_link_bg.jpg) repeat-x top left;
    border: 1px solid #9D2320;
    color: #FDF0CD;
    display: block;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 12px;
    margin: 9px 36px 0 10px;
    padding: 0 9px 0 9px;
}

div#header_bottom div#sunshine a:hover {
    color: #FFFFFF;
    border-bottom: 0;
}

div#main_content {
    background: #FFFFFF url(/images/main_content_bg_grey.jpg) repeat-x top left;
    height: 500px;
    margin: auto;
    width: 870px;
}

body.body_sunshine_on div#main_content {
    background-image: url(/images/main_content_bg_sun.jpg);
}

body.admin div#main_content {
    background-image: none;
    margin-top: 20px;
}

div#main_content div#intro {
    color: #ECECEC;
    height: 202px;
    font-family: Georgia;
    font-size: 18px;
    font-weight: bold;
    line-height: 150%;
    margin: 0 0 -130px 0;
    padding: 25px 34px 34px 30px;
    text-align: center;
    width: 806px;
}

body.body_sunshine_on div#main_content div#intro {
    color: #FFFFFF;
}

div#main_content div#intro em {
    color: #C92A27;
}

div#main_content h1 {
    color: #000000;
    font-size: 30px;
    font-weight: normal;
    margin: 0 0 12px 0;
    padding: 0 0 0 0;
}

div#main_content h1.page_heading {
    color: #4D4D4F;
    font-family: Georgia;
    font-size: 17px;
    font-weight: bold;
    margin: -2px 0 30px -8px;
}

div#main_content h1.page_heading img {
    margin: 0 22px 0 0;
    vertical-align: middle;
}

div#main_content h1 strong {
    color: #C62827;
    font-family: "Trebuchet MS", sans-serif;
}

div#main_left {
    float: left;
    margin-right: 40px;
    padding: 0 0 0 27px;
    width: 580px;
}

#home div#main_left {
    padding: 0 0 0 0;
    width: 607px;
}

div#main_left img#blog_photo {
    border: 5px solid #000000;
    margin: -23px 0 5px 0;
}

div#main_left div.blog_entry {
    margin: 0;
    padding: 0 0 20px 0;
}

div#main_left div.blog_entry img {
    margin: 0 15px 5px 0;
}

div#main_left div.blog_entry span.date {
    background: transparent url(/images/date_bg.gif) no-repeat scroll 0 12px;
    font-family: Georgia, serif;
    font-size: 14px;
    font-weight: bold;
    display: block;
    text-align: right;
}

div#main_left div.blog_entry span.date strong {
    background-color: #FFFFFF;
    color: #C82926;
    font-size: 20px;
    margin-right: 5px;
    padding-left: 3px;
}

div#main_left div.blog_entry h2 {
    color: #4D4D4F;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.2ex;
    margin: 20px 0 10px 0;
    padding: 0 0 0 0;
}

div#main_left div.blog_entry h2 em {
    color: #c82926;
}

div#main_left p {
    font-size: 13px;
    margin: 0 30px 1em 0;
}

div#main_left ul,
div#main_left ol {
    margin: 20px 70px 30px 40px;
    padding: 0 0 0 0;
}

div#main_left ul li,
div#main_left ol li {
    font-family: Verdana, Arial, sans-serif;
    font-size: 13px;
    line-height: 150%;
    margin-bottom: 15px;
}

div#main_left ul li {
    list-style-image: url(/images/bullet_point.gif);
}

div#main_left div.blog_entry a.more:link, div#main_left div.blog_entry a.more:visited {
    color: #C82926;
    display:block;
    font-size: 17px;
    margin: 0 10px 0 0;
    text-align: right;
    text-decoration: none;
}

div#main_left div.blog_entry a.more:hover {
    text-decoration: underline;
}

div.blog_pager {
    border-top: 1px solid #000000;
    margin: 0 0 0 0;
    padding: 10px 0 10px 0;
}

div.blog_pager strong {
    display: block;
    font-size: 14px;
    font-weight: normal;
}

div.blog_pager a:link, div.blog_pager a:visited {
    color: #999999;
}

div.blog_pager a:hover {
    text-decoration: none;
}

div#main_right {
    float: left;
    margin: 0 0 0 0;
    width: 194px;
}

div#main_right img#newspaper {
    margin: -15px 0 0 5px;
}

div#main_right span#subscribe {
    color: #595959;
    display: block;
    font-size: 14px;
    line-height: 150%;
    letter-spacing: -0.07ex;
    margin: 10px 0 10px 0;
}

div#main_right #subscribe a:link, div#main_right #subscribe a:visited {
    color: #C82926;
    text-decoration: none;
}

div#main_right #subscribe a:hover {
    border-bottom: 1px dashed #C82926;
}

div#main_right #subscribe .gazette {
    color: #000000;
    font-variant: small-caps;
}

div#main_right div#current_news {
    border-top: 1px solid #000000;
    margin: 16px 0 20px 0;
    padding: 16px 0 0 0;
}

div#main_right div#current_news h2 {
    margin-bottom: 0;
}

div#main_right div#current_news ul {
    border-bottom: 1px solid #000000;
    list-style-type: none;
    margin: 10px 0 16px 0;
    padding: 0 0 12px 0;
}

div#main_right div#current_news ul li {
    margin: 0 0 7px 0;
}

div#main_right div#current_news ul li a:link, div#main_right div#current_news ul li a:visited {
    color: #9C9D9F;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 17px;
    font-style: italic;
    text-decoration: none;
}

div#main_right div#current_news ul li a:visited {
    color: #cccccc;
}

div#main_right div#current_news ul li a:hover {
    color: #666666;
}

div#footer {
    color: #B7B7B7;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 10px;
    padding: 0 0 0 27px;
}

div#footer a:link, div#footer a:visited {
    color: #B7B7B7;
}

div#footer a#themedium:link, div#footer a#themedium:visited {
    font-family: Verdana;
    font-size: 11px;
    font-weight: bold;
    text-decoration: none;
}

div#footer a#themedium:hover {
    border-bottom: 1px dashed #B7B7B7;
}

div#footer div {
    border-top: 1px solid #000000;
    padding: 17px 0 20px 0;
}

div#footer_left {
    float: left;
    text-align: right;
    width: 580px;
}

div#footer_right {
    float: left;
    margin: 0 0 0 40px;
    width: 194px;
}

form {
    margin: 0 0 30px 0;
}

form h2 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: 16px;
    font-weight: normal;
    margin: 15px 0 30px 0;
    padding: 0 0 0 0;
}

form label {
    display:block;
    font-size: 14px;
    margin: 12px 0 0 0;
    padding: 3px 0 3px 6px;
    width: 254px;
}

form input {
    border: 1px solid #CCCCCC;
    border-left: 5px solid #CCCCCC;
    color: #CCCCCC;
    font-family: Georgia, sans-serif;
    font-size: 14px;
    padding: 2px 0 2px 3px;
    width: 250px;
}

form textarea {
    border: 1px solid #CCCCCC;
    border-left: 5px solid #CCCCCC;
    color: #CCCCCC;
    font-family: Georgia, sans-serif;
    font-size: 14px;
    height: 100px;
    margin: -1px 0 0 0;
    padding: 2px 0 2px 3px;
    width: 250px;
}

form select {
    border: 1px solid #CCCCCC;
    border-left: 5px solid #CCCCCC;
    color: #999999;
    font-family: Georgia, sans-serif;
    font-size: 14px;
    width: 260px;
}

form input.radio_button {
    width: auto;
}

form div.buttons {
    margin: 20px 0 20px 0;
}

button {
    padding: 10px 15px;
}

input.focus, textarea.focus, select.focus {
    border: 1px solid #999999;
    border-left: 6px solid #999999;
    color: #999999;
}

label.focus {
    background-color: #999999;
    color: #FFFFFF;
}

.custom_message {
    background-color: #e2e2e2;
    border-top: 2px solid #999999;
    color: #666666;
    display: block;
    font-size: 12px;
    height: 17px;
    margin-bottom: 20px;
    margin-top: 10px;
    padding: 10px;
    width: 794px;
}

.custom_message img {
    margin: 1px 8px 0 0;
    vertical-align: top;
}

.custom_message .custom_text {
    float: left;
}

.custom_message a:link, .custom_message a:visited {
    background-color: #999999;
    color: #E2E2E2;
    float: right;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 10px;
    margin-right: -10px;
    margin-top: -12px; 
    padding: 0 3px 0 3px;
    text-decoration: none;
}

.custom_message a:hover {
    background-color: #666666;
}

/* admin */
#main_admin{
    margin-right: 40px;
    padding: 0 0 0 27px;
    width: 810px;
}

#main_admin h3 {
    border-bottom: 1px dashed #000000;
    font-size: 18px;
    font-weight: normal;
    margin: 0;
}

#main_admin form input, #main_admin form textarea {
    width: 300px;
}

#main_admin form select {
    width: 309px;
}

#main_admin table {
    margin: 20px 0 30px 0;
    width: 100%;
}

#main_admin table th {
    background-color: #999999;
    color: #FFFFFF;
    font-weight: normal;
    text-align: left;
}

#main_admin table td, #main_admin table th {
    font-size: 14px;
    padding: 5px;
    vertical-align: top;
}

#main_admin button img {
    margin: 0 5px 0 0;
    vertical-align: top;
}

#admin_footer {
    text-align: right;  
    width: 810px;
}

#main_admin table td.actions {
    vertical-align: middle;
    white-space: nowrap;
}

#main_admin table td.actions a:link,
#main_admin table td.actions a:visited {
    background-color: #CCCCCC;
    color: #FFFFFF;
    padding: 4px;
    text-decoration: none;
}

#main_admin table td.actions a:hover {
    background-color: #999999;
}

#main_admin .action_row {
    display: none;
}

#main_admin table tr.alt td {
    background-color: #EFEFEF;
}

#main_admin td form {
    margin: 0 20px 0 20px;
}

#main_admin form label {
    width: 304px;
}

#main_admin span.mceEditorContainer table.mceEditor {
    height: 0;
    margin: 0 0 0 0;
}

#main_admin span.mceEditorContainer table.mceEditor td {
    height: 0;
}

#main_admin span.mceEditorContainer table.mceEditor iframe.mceEditorIframe {
    height: 300px;
    padding: 5px;
    width: 500px;
}

#main_admin div#admin_welcome {
    margin-bottom: 50px;
}

.noDisplay {
    display: none;
}

p.newsletter_note {
    border-top: 1px solid #000;
    margin-top: 10px;
    padding-top: 10px;
}

.admin_banners {
    height: 120px;
}

.admin_banners ul {
    margin: 10px 0 10px 0;
    padding: 0 0 0 0;
}

.admin_banners ul li {
    display: inline;
}

.admin_banners a:link,
.admin_banners a:visited {
    border: 1px solid #FFFFFF;
    color: #666666;
    display: block;
    float: left;
    font-size: 12px;
    margin: 0 13px 0 0;
    padding: 10px 10px 5px 10px;
    text-align: center;
    text-decoration: none;
    width: 100px;
}

.admin_banners a img {
    margin-bottom: 5px;
}

.admin_banners a:hover {
    border: 1px solid #CCCCCC;
}

.admin_banners a.active_banner:link,
.admin_banners a.active_banner:visited {
    background-color: #CCCCCC;
}

#main_admin #welcome_message {
    height: 200px;
    width: 400px;
}

.admin_list .admin_banners a:link,
.admin_list .admin_banners a:visited {
    margin-right: 4px;
}

.home_lookout_wrapper {
    background: transparent url(/images/lookout_bg.jpg) no-repeat scroll 0 0;
    margin-left: 10px;
    padding: 15px 0 0 17px;
}

.home_lookout_wrapper .lookout_heading {
    float: left;
    margin: 0 27px 0 0;
    padding: 0 0 0 0;
}

.home_lookout_wrapper h2,
#main_right h2 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: 16px;
    letter-spacing: 0.2ex;
    line-height: 130%;
    margin-top: 0px;
    margin-bottom: 20px;
}

.home_lookout_wrapper h2 em {
    color: #CCCCCC;
    font-style: normal;
}

.home_lookout_wrapper h1.page_heading img {
    margin-left: 25px;
}

.welcome_note {
    margin-left: 27px;
}

div#main_content h1.text_page_heading {
    color: #000000;
    display: block;
    font-family: Georgia, serif;
    font-size: 35px;
    font-weight: bold;
    margin-bottom: 30px;
    margin-top: 10px;
    text-align: center;
    width: 205px;
}

div#title_line {
    color: #717173;
    font-family: "Trebuchet MS", sans-serif;
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 0.1ex;
    margin: -83px 0 0 130px;
    position: absolute;
    width: 400px;
}

div#title_line em {
    color: #D74E3B;
    font-style: normal;
}

.page_description {
    color: #4D4D4F;
    display: block;
    font-family: Georgia, serig;
    font-size: 17px;
    font-weight: bold;
    position: absolute;
    margin: 4px 0 0 250px;
    width: 320px;
}

/** SELECTABLE CONTENT STYLES */
div#main_content h1.wtw_headline {
    border-bottom: 1px solid #59595B;
    color: #C82B26;
    font-family: "Trebuchet MS", Arial, sans-serif;
    font-size: 37px;
    font-style: italic;
    font-weight: bold;
    margin: 25px 30px 20px 0;
    padding: 0 60px 30px 60px;
    text-align: center;
}

div#main_content .intro_paragraph {
    border-bottom: 1px solid #59595B;
    border-top: 1px solid #59595B;
    color: #6E6F71;
    font-family: "Trebuchet MS", Arial, sans-serif;
    font-size: 18px;
    font-style: italic;
    line-height: 120%;
    margin-top: 30px;
    padding-bottom: 20px;
    padding-left: 4px;
    padding-right: 4px;
    padding-top: 20px;
    text-align: left;
}

div#main_content .lead_intro_paragraph {
    font-family: "Trebuchet MS", Arial, sans-serif;
    font-size: 15px;
    font-weight: bold;
    line-height: 120%;
    margin: 20px 0 30px 0;
}

div#main_content .pull_quote {
    background: transparent url(/images/pull_quote_bg_top.gif) no-repeat scroll 0 0; 
    font-family: Georgia, "Times New Roman", serif;
    font-size: 20px;
    font-style: italic;
    font-weight: bold;
    margin: 20px 0 20px 0;
    padding: 40px 20px 10px 20px;
    text-align: center;
}


div#main_content .pull_quote_close {
    background: transparent url(/images/pull_quote_bg_bottom.gif) no-repeat scroll right 0; 
    height: 30px;
    margin-bottom: 20px;
    margin-top: -20px;
}

.opening_character {
    float: left;
    font-family: Georgia, "Times New Roman", serif;
    font-weight: bold;
    font-size: 43px;
    line-height: 100%;
    margin: 0 8px -5px 0;
}

div#main_content .g_note {
    background: #949599 url(/images/g_note_bg.gif) no-repeat scroll 7px 7px;
    color: #000000;
    padding: 40px 10px 10px 10px;
}

div#main_content .g_note em,
div#main_content .g_note i{
    color: #FFD135;
    font-weight: bold;
}

.createForm {
    margin-top: 20px;
}

#flickr_panel {
    border-top: 1px solid #000000;
    margin-top: 10px;
    padding-top: 10px;
}

#flickr_panel h2 {
    margin-bottom: 10px;
}

#flickr_panel #thumbnails {
    background-color: #9C9D9F;
    padding: 12px 0 0 0;
    text-align: center;
}

#flickr_panel #thumbnails img {
    border: 1px solid #FFFFFF;
    margin: 0 4px 10px 4px;
}

#flickr_panel #thumbnails img:hover,
#flickr_panel #thumbnails a:hover img {
    border: 1px solid #CCCCCC;
}
#main_admin form.edit_image {
    display: none;
    margin: 5px 0 0 2px;
    padding: 0;
    width: 200px;
}

#main_admin form.edit_image button {
    font-size: 11px;
    padding: 5px;
}

#main_admin form.edit_image input {
    font-size: 11px;
    width: 170px;
}

#main_admin form.edit_image label {
    font-size: 11px;
    width: 174px;
}

#main_admin form.edit_image select {
    width: 200px;
}

#main_admin div.actions {
    padding: 0 0 0 0;
    width: 240px;
}

.caption_wrapper {
    color: #666666;
    font-size: 12px;
    margin: 0 0 0 0;
    padding-bottom: 2px;
    text-align: center;
}

.caption_wrapper img {
    display: block;
}
