@charset 'UTF-8';
@charset 'UTF-8';
/*
Theme Name: Canonball Master Theme
Theme URI: http://www.canonball.com
Description: CB Master Bootstrap For All WP Themes
Author: Canonball
Author URI: http://www.canonball.com
Version: 0.1
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section,
summary,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}
body {
  background: #fff;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none;
}
:focus {
  outline: 0;
}
ins {
  text-decoration: none;
}
del {
  text-decoration: line-through;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section,
summary,
video {
  display: block;
}
input:required {
  box-shadow: none !important;
}
.clear {
  width: 100%;
  height: 1px;
  clear: both;
  display: block;
  content: '';
}
.skip-link {
  display: none;
}
.colgroup {
  clear: both;
}
.col {
  width: 95%;
  float: left;
  margin: .75em 1%;
  padding: 0 1.5%;
}
.col_1 {
  width: 95%;
  float: left;
  margin: .75em 1%;
  padding: 0 1.5%;
}
.col_2 {
  width: 95%;
  float: left;
  margin: .75em 1%;
  padding: 0 1.5%;
}
@media screen and (min-width: 500px) {
  .col_2 {
    width: 45%;
  }
}
.col_3 {
  width: 95%;
  float: left;
  margin: .75em 1%;
  padding: 0 1.5%;
}
@media screen and (min-width: 500px) {
  .col_3 {
    width: 28.333%;
  }
  .col_3.span_2 {
    width: 61.66%;
  }
}
.col_4 {
  width: 95%;
  float: left;
  margin: .75em 1%;
  padding: 0 1.5%;
}
@media screen and (min-width: 500px) {
  .col_4 {
    width: 45%;
  }
  .col_4.sidebar {
    width: 95%;
  }
  .col_4.span_2,
  .col_4.span_3 {
    width: 95%;
  }
  .col_4.span_3 + .col_4 {
    margin-left: auto;
    margin-right: auto;
    float: none;
    clear: both;
  }
}
@media screen and (min-width: 770px) {
  .col_4 {
    width: 20%;
  }
  .col_4.sidebar {
    width: 20%;
  }
  .col_4.span_2 {
    width: 45%;
  }
  .col_4.span_3 {
    width: 70%;
  }
  .col_4.span_3 + .col_4 {
    margin-left: 1%;
    margin-right: 1%;
    float: left;
    clear: none;
  }
}
h1 {
  font-size: 2em;
  font-size: 2rem;
  font-weight: normal;
  color: #000000;
  margin: 0 0 0.5rem 0;
}
h2 {
  font-size: 1.75em;
  font-size: 1.75rem;
  font-weight: normal;
  color: #999999;
  margin: 0 0 0.5rem 0;
}
h3 {
  font-size: 1.5em;
  font-size: 1.5rem;
  font-weight: normal;
  color: #cccccc;
  margin: 0 0 0.75rem 0;
}
h4 {
  font-size: 1.4em;
  font-size: 1.4rem;
  font-weight: normal;
  color: #000000;
  margin: 0 0 0.75rem 0;
}
h5 {
  font-size: 1.25em;
  font-size: 1.25rem;
  font-weight: normal;
  color: #000000;
  margin: 0 0 1rem 0;
}
h6 {
  font-size: 1.15em;
  font-size: 1.15rem;
  font-weight: normal;
  color: #000000;
  margin: 0 0 1rem 0;
}
p {
  font-size: 1em;
  line-height: 1.25em;
}
blockquote {
  quotes: '\201C' '\201D' '\2018' '\2019';
  position: relative;
}
blockquote p:before {
  content: open-quote;
  position: absolute;
  left: -0.4em;
  left: -0.4rem;
}
blockquote p:after {
  content: no-close-quote;
}
blockquote p:last-child:after {
  content: close-quote;
}
.responsive {
  width: 100%;
  height: auto;
}
.standard_table {
  margin: 1em auto;
  margin: 1rem auto;
  width: 100%;
}
.standard_table th,
.standard_table tr,
.standard_table td {
  display: block;
}
.standard_table thead {
  background: #000000;
}
.standard_table thead tr {
  display: none;
}
.standard_table thead th {
  color: #fff;
  padding: 1em;
  padding: 1rem;
}
.standard_table tbody tr {
  background: #cccccc;
}
.standard_table tbody tr:nth-child(2n) {
  background: #dfdfdf;
}
.standard_table tbody td {
  padding: 1rem;
}
body {
  font-size: 16px;
  padding-top: 0;
  background: #fff;
}
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  clear: both;
}
.head {
  padding-top: 1rem;
  margin-bottom: 5px;
  z-index: 100;
  display: block;
  background: #000000;
  width: 100%;
  min-height: 165px;
  position: relative;
  border-bottom: 0.2rem solid #999999;
  text-align: center;
  color: #fff;
}
.head h1,
.head h2 {
  text-align: center;
}
.head h1 {
  margin: .75rem 0 0;
}
.head h2 {
  margin-top: 0;
}
.brand {
  display: block;
  margin: 0 auto .5em;
  text-align: center;
}
@media screen and (min-width: 500px) {
  .brand {
    text-align: left;
  }
}
.menu {
  clear: both;
}
.menu a {
  text-transform: uppercase;
  font-weight: 600;
  font-size: 75%;
  display: block;
  float: none;
  width: 100%;
  padding: 1rem 0;
  text-align: center;
  margin: 0;
  background-color: #fff;
  transition: all 0.5s;
  -moz-transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  color: #000;
  text-decoration: none;
}
.menu a:hover {
  background-color: #999999;
  color: #fff;
}
.menu .current_page_item a {
  background-color: #999999;
  color: #fff;
}
.hero {
  width: 100%;
}
.hero img {
  width: 100%;
  height: auto;
}
.copy,
.content {
  margin: 1.5rem auto;
  font-size: 1rem;
  line-height: 1.2rem;
  clear: both;
}
.copy p,
.content p {
  margin: 0 0 2rem;
}
.copy h1,
.content h1 {
  color: #000000;
  margin-bottom: 1.25rem;
}
.copy h2,
.content h2 {
  color: #999999;
  margin: 0 0 .5rem 0;
  line-height: 4rem;
}
.copy ul,
.content ul {
  margin-bottom: 2.5rem;
}
.copy li,
.content li {
  list-style: disc outside none;
  margin: .75rem 0 .75rem 1.25rem;
}
.copy .colorcaps,
.content .colorcaps {
  margin: 1.75rem 0;
}
.copy .colorcaps strong,
.content .colorcaps strong {
  font-weight: 600;
  color: #999999;
  font-size: 1.75rem;
}
.icon {
  display: inline;
  height: 1.65em;
  width: auto;
  padding-right: .5em;
}
.page-content .hero {
  max-height: 415px;
}
.page-content .alignleft {
  width: 100%;
  max-width: 350px;
  height: auto;
  margin-top: 25px;
}
.gform_fields li {
  list-style: none;
}
.gform_fields input,
.gform_fields textarea {
  width: 100%;
}
.gform_fields label {
  color: #000000;
}
.gform_fields label .gfield_required {
  color: #999999;
}
.gform_button {
  width: 30%;
  max-width: 400px;
  min-width: 260px;
  padding: 1rem;
  color: #fff !important;
  background: #000000;
  border: 0.1rem solid #000000;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  margin-left: 1rem;
  text-align: center;
  transition: all 0.5s;
  -moz-transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
}
.gform_button:hover {
  color: #000000 !important;
  background: #000000;
}
.gform_button a {
  color: #fff;
  text-align: center;
  font-size: 125%;
}
.gform_button a:hover {
  color: #000000;
  text-decoration: none;
}
@media screen and (min-width: 460px) and (max-width: 779px) {
  
}
@media screen and (min-width: 780px) {
  
}
.col_3 {
  width: 95%;
  float: left;
  margin: .75em 1%;
  padding: 0 1.5%;
  margin: 1%;
  padding: 0;
}
@media screen and (min-width: 768px) {
  .col_3 {
    width: 31.333%;
  }
  .col_3.span_2 {
    width: 61.66%;
  }
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #373636;
}
li,
p {
  color: #676767;
}
body {
  background: #e165cb url(images/bg.jpg);
  font-size: 16px;
  font-family: 'Open Sans', 'Droid Sans', 'Helvetica Neue', 'HelveticaNeue', Helvetica, Arial, sans-serif;
}
header {
  border-top: 30px solid #000;
}
header article {
  margin-top: 0 !important;
}
.brand {
  margin: 0 0 0 2.5%;
}
.brand img {
  margin-left: 1%;
  margin-bottom: -5px;
}
.main_menu {
  clear: both;
  width: 98%;
  margin: 0 auto;
  background: #fff;
  padding-top: 2.5%;
}
.main_menu .mobile-menu {
  position: relative;
  width: 98%;
  padding: .8em 0 .95em;
  height: .9em;
  margin: 0 auto;
  text-align: center;
  cursor: pointer;
}
.main_menu .mobile-menu span:before {
  display: block;
  position: absolute;
  top: .4em;
  left: 1.25em;
  width: 32px;
  height: 32px;
  background: url(images/icons/mobilemenu.png) no-repeat top left;
  content: '';
}
.main_menu .menu {
  display: none;
}
.main_menu .menu .current_page_item a {
  background-color: #000;
}
.main_menu .menu li {
  cursor: pointer;
}
.main_menu .menu li a:hover,
.main_menu .menu li a:active {
  background-color: #fff784;
  color: #000;
}
.main_menu .menu .sub-menu {
  display: none;
}
@media screen and (min-width: 768px) {
  .main_menu .mobile-menu {
    display: none;
  }
  .main_menu .menu {
    width: 95%;
    margin: 0 2.5%;
    background-color: #000;
    height: 2.5rem;
    padding-top: 1rem;
  }
  .main_menu .menu li {
    display: inline-block;
    margin: 0;
    position: relative;
  }
  .main_menu .menu li a {
    display: inline;
    background: none;
    color: #fff;
    font-size: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .main_menu .menu li a:hover {
    background-color: #fff784;
    color: #000;
  }
  .main_menu .menu .sub-menu {
    display: none;
    position: absolute;
    width: 100%;
    z-index: 10;
    margin-top: 1rem;
  }
  .main_menu .menu .sub-menu li {
    display: block;
    background: #fff784;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
  .main_menu .menu .sub-menu li:hover {
    background: #000;
  }
  .main_menu .menu .sub-menu li:hover a {
    color: #fff;
  }
  .main_menu .menu .sub-menu li a {
    display: block;
    width: 95%;
    padding: 2% 2.5%;
    font-size: 90%;
    text-align: center;
    color: #000;
  }
  .main_menu .menu .sub-menu li a:hover {
    color: #fff;
    background-color: #000;
  }
}
@media screen and (min-width: 960px) {
  .main_menu .menu li a {
    padding-left: 1.75rem;
    padding-right: 1.75rem;
  }
}
@media screen and (min-width: 1175px) {
  .main_menu .menu li a {
    padding-left: 2.75rem;
    padding-right: 2.75rem;
  }
}
.slide__container {
  margin: 0 auto;
  width: 98%;
  background: #fff;
}
.slide__container .slide {
  margin: 0 2.5%;
  width: 95%;
  padding-top: 2.5%;
}
.slide__container .slide img {
  width: 100%;
  height: auto;
}
#blocks {
  background: #fff;
  box-sizing: border-box;
  margin: 0 1%;
  width: 98%;
}
.block.col_3 img {
  width: 100%;
  height: auto;
}
.block.first_row {
  padding-top: 1%;
}
.block.third_row {
  padding-bottom: 1%;
}
.block.col_1 {
  background-color: #9aa6d0;
  width: 95%;
  margin: 1%;
}
.block.col_1 blockquote {
  padding: 1em;
  width: 90%;
  position: relative;
  margin-left: 5%;
}
@media screen and (min-width: 1000px) {
  .block.col_1 blockquote {
    margin-top: 1em;
  }
}
.block.col_1 blockquote p {
  font-size: 1.55em;
  color: #fff;
}
.block.col_1 blockquote p:before {
  font-size: 2.5em;
  font-weight: bold;
  top: 1rem;
  left: -1rem;
  font-family: Helvetica, Arial;
  color: #fff225;
}
.block.col_1 cite {
  float: right;
  margin: -1rem 1rem 1rem;
  padding-bottom: 1em;
  font-weight: 700;
  color: #fff;
}
.hero {
  width: 98%;
  margin: 0 auto;
  background: #fff;
  text-align: center;
}
.hero img {
  width: 95%;
  padding-bottom: 2.5%;
}
.hentry {
  margin: 0 auto;
  background-color: #fff;
  padding: 0 2.5% 2.5%;
}
.hentry.col_1 {
  width: 93%;
  float: none;
}
.hentry.col_3 {
  width: 63.3%;
}
.hentry .internal-border {
  border: 1px solid #ddd;
  width: 96%;
  padding: 2%;
  margin: 0 auto;
}
.hentry .entry-title {
  font-size: 4em;
  font-weight: 300;
  color: #ec008c;
  margin: 0 auto .5em;
  padding-bottom: .5em;
  border-bottom: 1px solid #ddd;
  width: 98%;
}
.hentry p {
  font-size: 1.1em;
  line-height: 1.65em;
  width: 98%;
  margin: 0 auto 1.5em;
}
.hentry a {
  color: #adc47f;
  font-weight: bold;
  text-decoration: none;
  border-bottom: 1px solid #adc47f;
}
.hentry a:hover,
.hentry a:active {
  color: #bbb;
  border-bottom: 0 none;
  text-decoration: none;
  font-style: italic;
}
.location_search {
  width: 100%;
}
.location_search .location_search_title {
  font-size: 2em;
  font-weight: 400;
  padding-bottom: 1em;
}
.location_search .location_search_row {
  display: block;
  float: none;
  width: 95%;
  margin-bottom: 1em;
}
@media screen and (min-width: 767px) {
  .location_search .location_search_row {
    float: left;
    width: 25%;
  }
}
.location_search .location_search_row#location_search_0_tr {
  display: none;
}
.location_search .location_search_row#location_search_5_tr {
  clear: both;
  float: none;
  padding-top: 1em;
}
.location_search .location_search_row .location_search_cell {
  display: block;
  font-weight: bold;
}
.location_search input,
.location_search select {
  margin: .5em 0;
  width: 300px;
  height: 3em;
  border: 1px solid #bbb;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  appearance: none;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  border-radius: 0;
  padding: 0 1em;
}
@media screen and (min-width: 767px) {
  .location_search input,
  .location_search select {
    width: 15em;
  }
}
.location_search select {
  padding: .5em 1em;
  width: 325px;
}
@media screen and (min-width: 767px) {
  .location_search select {
    width: 16em;
  }
}
.location_search input[type='submit'] {
  cursor: pointer;
}
.press {
  width: 98%;
  margin: 0 auto 2.5em;
  clear: both;
}
.press .press__image {
  width: 100%;
}
.press .press__image img {
  width: 100%;
  height: auto;
}
.press .press__copy {
  width: 100%;
}
.press h2 {
  font-size: 1.5em;
  margin: 0 auto 1em;
}
@media screen and (min-width: 767px) {
  .press .press__image {
    width: 150px;
    height: 150px;
    overflow-y: hidden;
    float: left;
    margin: 0 3em 0 0;
  }
  .press .press__copy {
    width: 65%;
    float: left;
  }
}
.press:after {
  width: 100%;
  height: 1px;
  clear: both;
  display: block;
  content: '';
}
footer {
  background-color: #fff;
  margin: 0 auto;
  padding: 0 0 2.5%;
  width: 98%;
}
footer .menu {
  width: 95%;
  margin: 0 auto;
  background: #fff784;
}
footer .menu a {
  background: none;
  color: #000;
  font-weight: bold;
}
footer .menu a:hover {
  background: #000;
  color: #fff;
}
footer .menu .current_page_item a {
  background-color: #000;
}
@media screen and (min-width: 768px) {
  footer .menu {
    padding: 2% 0;
    text-align: center;
  }
  footer .menu li {
    display: inline;
  }
  footer .menu li a {
    display: inline;
    width: auto;
    padding: 1rem 2%;
  }
}
.results div {
  width: 100%;
  float: none;
}
@media screen and (min-width: 768px) {
  .results div.result_address {
    float: left;
    width: 40%;
  }
  .results div.result_phone {
    float: left;
    width: 30%;
  }
  .results div.result_links {
    float: left;
    display: table-cell;
    width: 30%;
    text-align: right;
    vertical-align: bottom;
  }
}
