/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

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

.group:after {
  content: "";
  display: table;
  clear: both; }

/*! Typebase.less v0.1.0 | MIT License */
/* Setup */
html {
  /* Change default typefaces here */
  font-family: serif;
  font-size: 117.5%;
  -webkit-font-smoothing: antialiased; }

/* Copy & Lists */
p {
  line-height: 1.5rem;
  margin-top: 1.5rem;
  margin-bottom: 0; }

ul,
ol {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem; }

ul li,
ol li {
  line-height: 1.5rem; }

ul ul,
ol ul,
ul ol,
ol ol {
  margin-top: 0;
  margin-bottom: 0; }

blockquote {
  line-height: 1.5rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem; }

/* Headings */
h1,
h2,
h3,
h4,
h5,
h6 {
  /* Change heading typefaces here */
  font-family: sans-serif;
  margin-top: 1.5rem;
  margin-bottom: 0;
  line-height: 1.5rem; }

h1 {
  font-size: 4.242rem;
  line-height: 4.5rem;
  margin-top: 3rem; }

h2 {
  font-size: 2.828rem;
  line-height: 3rem;
  margin-top: 3rem; }

h3 {
  font-size: 1.414rem; }

h4 {
  font-size: 0.707rem; }

h5 {
  font-size: 0.4713333333333333rem; }

h6 {
  font-size: 0.3535rem; }

/* Tables */
table {
  margin-top: 1.5rem;
  border-spacing: 0px;
  border-collapse: collapse; }

table td,
table th {
  padding: 0;
  line-height: 33px; }

/* Code blocks */
code {
  vertical-align: bottom; }

/* Leading paragraph text */
.lead {
  font-size: 1.414rem; }

/* Hug the block above you */
.hug {
  margin-top: 0; }

/* ALERTS - Straight from bootstrap*/
.alert {
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25), 0 1px 2px rgba(0, 0, 0, 0.05);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25), 0 1px 2px rgba(0, 0, 0, 0.05); }
  .alert p {
    line-height: 2.2em;
    font-weight: bold;
    margin: 0 0 0 1em;
    padding: 3px 0 0;
    font-size: 1.1em; }

.alert-success {
  background-image: -webkit-linear-gradient(top, #dff0d8 0%, #c8e5bc 100%);
  background-image: -o-linear-gradient(top, #dff0d8 0%, #c8e5bc 100%);
  background-image: -webkit-gradient(linear, left top, left bottom, from(#dff0d8), to(#c8e5bc));
  background-image: linear-gradient(to bottom, #dff0d8 0%, #c8e5bc 100%);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffc8e5bc', GradientType=0);
  border-color: #b2dba1; }

.alert-info {
  background-image: -webkit-linear-gradient(top, #d9edf7 0%, #b9def0 100%);
  background-image: -o-linear-gradient(top, #d9edf7 0%, #b9def0 100%);
  background-image: -webkit-gradient(linear, left top, left bottom, from(#d9edf7), to(#b9def0));
  background-image: linear-gradient(to bottom, #d9edf7 0%, #b9def0 100%);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffb9def0', GradientType=0);
  border-color: #9acfea; }
  .alert-info p {
    line-height: 1em;
    padding: 12px 0 8px; }

.alert-warning {
  background-image: -webkit-linear-gradient(top, #fcf8e3 0%, #f8efc0 100%);
  background-image: -o-linear-gradient(top, #fcf8e3 0%, #f8efc0 100%);
  background-image: -webkit-gradient(linear, left top, left bottom, from(#fcf8e3), to(#f8efc0));
  background-image: linear-gradient(to bottom, #fcf8e3 0%, #f8efc0 100%);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fff8efc0', GradientType=0);
  border-color: #f5e79e; }

.alert-danger {
  background-image: -webkit-linear-gradient(top, #f2dede 0%, #e7c3c3 100%);
  background-image: -o-linear-gradient(top, #f2dede 0%, #e7c3c3 100%);
  background-image: -webkit-gradient(linear, left top, left bottom, from(#f2dede), to(#e7c3c3));
  background-image: linear-gradient(to bottom, #f2dede 0%, #e7c3c3 100%);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffe7c3c3', GradientType=0);
  border-color: #dca7a7; }

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.l-box {
  padding: .8em .4em; }

.is-center {
  text-align: center; }

.is-right {
  text-align: right; }

.is-left {
  text-align: left; }

.is-small {
  font-size: 75%; }

.width {
  width: 100%;
  margin: 0 auto; }

table thead td {
  line-height: 1.1rem; }

.error {
  color: red; }

input.error {
  border: 1px solid red !important; }

/* CALENDAR STYLES */
table.calendar {
  width: 100%;
  margin: 1px 0 15px;
  border: 1px solid #5b545a;
  color: #5b545a;
  padding: 0;
  background-color: #eeeeee; }

table.calendar tr.heading {
  background: #5b545a;
  color: #f6ce76;
  font-size: 12px; }

table.calendar tr.heading th {
  padding: 5px 0 6px;
  text-align: center; }

table.calendar tr.heading a {
  color: #f6ce76;
  text-decoration: none; }

table.calendar tr.heading a:hover {
  color: #d5d3d5; }

table.calendar tr.weekdays {
  font-size: 12px;
  font-weight: bold;
  background: #d5d3d5; }

table.calendar tr.weekdays td {
  padding: 5px 0;
  text-align: center; }

table.calendar tr.days {
  font-size: 11px;
  vertical-align: text-top; }

table.calendar tr.days td {
  text-align: center;
  border: 1px solid #5b545a;
  height: 26px;
  width: 14%;
  padding: 3px;
  line-height: 26px;
  font-size: 18px;
  cursor: pointer; }

table.calendar tr.days td.selected {
  background: #cfcfcf;
  font-weight: bold; }

table.calendar tr.days td div {
  padding: 3px 0; }

table.calendar tr.days td div.eventday {
  font-size: 10px; }

table.calendar tr.days td div.eventday a {
  color: #000;
  text-decoration: none; }

table.calendar div.highlight {
  background: #ffffff; }

body {
  font-family: "Open Sans", sans-serif; }

.pure-button-primary {
  background-color: #2a6078 !important;
  transition: background-color .8s;
  font-weight: bold; }
  .pure-button-primary:hover {
    background-color: #b7bf72 !important; }

.pure-cart-button {
  background-color: #b7bf72 !important; }

.menu-item-cart {
  border: 1px solid #2a6078;
  border-top: 0; }

header {
  padding: 8px 0 0; }
  header h1 {
    line-height: 1.3em;
    margin: 0;
    padding: 0 0 8px;
    text-align: left;
    border-bottom: 2px solid #7eaacf;
    font-size: 1.4rem;
    text-transform: uppercase; }
    header h1 a {
      color: #cccccc;
      text-decoration: none; }
    header h1 img {
      display: block;
      margin: 0 auto;
      height: 100px; }
  header h2 {
    font-size: .797em;
    line-height: 1.2rem;
    text-transform: uppercase;
    color: #D0DAE4;
    background: #2A6078;
    text-align: center;
    padding: 3px 45px;
    margin-top: 0; }
  header #topbarnav {
    border-bottom: 2px solid #7eaacf; }
    header #topbarnav #account-options {
      float: left;
      width: 50%;
      text-align: left; }
    header #topbarnav #mobilenav {
      font-size: .85em;
      padding: .5em 8px .4em;
      text-align: right; }
      header #topbarnav #mobilenav .show-menu {
        text-decoration: none;
        color: #cccccc;
        text-align: right;
        display: block;
        cursor: pointer;
        font-size: 1.4em; }
      header #topbarnav #mobilenav input[type=checkbox] {
        display: none; }
  header nav {
    margin: 0; }
    header nav #nav_fullnav {
      display: none;
      background: #7eaacf;
      border-bottom: 2px solid #fff; }
    header nav.pure-menu-horizontal ul {
      text-align: center; }
      header nav.pure-menu-horizontal ul li {
        display: block !important; }
        header nav.pure-menu-horizontal ul li a {
          display: block;
          color: #fff; }
          header nav.pure-menu-horizontal ul li a:hover {
            background-color: rgba(255, 255, 255, 0.5);
            color: #3d3d3d; }
          header nav.pure-menu-horizontal ul li a:after {
            display: none; }
        header nav.pure-menu-horizontal ul li ul {
          display: none !important; }

#hero {
  margin-top: 0; }
  #hero li {
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    padding: 80px;
    text-align: right; }
    #hero li h1 {
      margin-top: .7rem;
      font-size: 2.828rem;
      line-height: 2.6rem;
      font-family: "Fira Sans", sans-serif;
      font-weight: 800;
      color: #fff;
      margin-bottom: 0; }
    #hero li p {
      width: 100%;
      margin: -6px 0 10px;
      font-size: 1.4rem;
      padding-left: 0;
      line-height: 2.6rem;
      color: #fff;
      font-weight: lighter;
      background-color: rgba(8, 49, 48, 0.55); }
    #hero li .pure-button {
      background-color: #2A6078;
      white-space: normal;
      font-family: "Fira Sans", sans-serif;
      font-weight: 800;
      color: #fff;
      font-size: 1.42rem;
      transition: background-color .8s; }
      #hero li .pure-button:hover {
        background-color: #B9C074; }

#home-sections .section {
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  padding: 20px;
  height: 550px;
  text-align: center; }
  #home-sections .section h3 {
    border-bottom: none;
    color: #000;
    font-size: 1.7rem;
    line-height: 1.9rem; }
  #home-sections .section p {
    width: 95%;
    margin: 23px auto;
    font-size: 1rem;
    line-height: 1.3rem; }

#home-sections #section-4 {
  height: auto; }
  #home-sections #section-4 h3 {
    color: #7eaacf; }
  #home-sections #section-4 h4 {
    font-size: 1.8rem;
    line-height: 2.1rem;
    color: #7eaacf; }

#content {
  padding: 5px;
  max-width: 960px;
  margin: 0 auto; }
  #content h2 {
    margin-top: 0;
    background: #2A6078;
    text-transform: uppercase;
    color: #fff;
    font-size: 1.111rem;
    line-height: 1.8rem;
    padding: 0 11px;
    font-weight: lighter; }
  #content h3 {
    margin-top: 0;
    background: #5ba3c6;
    text-transform: uppercase;
    color: #fff;
    font-size: .989rem;
    line-height: 1.5rem;
    padding: 0 11px;
    font-weight: bold; }
  #content a {
    text-decoration: none; }
  #content h4 {
    margin-top: 0;
    color: #5ba3c6;
    text-align: left;
    padding-left: 11px; }
    #content h4 a {
      color: #5ba3c6;
      transition: color .8s; }
      #content h4 a:hover {
        color: #B9C074; }

#page-hero {
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  margin-top: -31px; }
  #page-hero h1 {
    padding-left: 11px;
    margin-bottom: 0;
    line-height: 105px;
    color: #fff;
    font-weight: bolder;
    font-family: "Open Sans", sans-serif;
    text-transform: uppercase;
    background-color: rgba(0, 0, 0, 0.3); }

#main #content {
  max-width: 100%;
  padding: 0; }

#store_index p {
  color: #2a6078;
  font-size: .828rem;
  padding: 0 11px 21px;
  margin: 0; }

.category-ribbon p {
  margin-top: 0;
  text-align: left;
  color: #2a6078;
  font-size: .87rem;
  line-height: 1rem;
  padding: 3px 11px; }

#product-detail {
  margin-bottom: 51px; }
  #product-detail h1 {
    margin-top: -11px;
    margin-bottom: 0;
    line-height: 1.35rem;
    color: #2A6078;
    font-weight: bold;
    text-transform: uppercase; }
  #product-detail h2 {
    text-align: right; }
  #product-detail p {
    color: #2a6078;
    font-size: .828rem;
    padding-left: 11px; }
  #product-detail ul {
    font-size: .787rem;
    padding-left: 11px; }
    #product-detail ul li {
      color: #2a6078;
      line-height: 1rem; }

#checkout-form legend {
  font-size: .7989rem;
  padding-left: 11px; }

#checkout-form .pure-g {
  padding: 11px; }

.fineprint {
  margin-top: 31px;
  padding: 11px 11px 0;
  border: 1px solid #5ba3c6; }
  .fineprint h5 {
    background: #5ba3c6;
    color: #fff;
    font-size: 1.111rem;
    line-height: 1.8rem;
    margin: -11px -11px 11px;
    padding: 0 11px;
    font-weight: lighter; }
  .fineprint p {
    font-size: .789rem;
    line-height: 1rem;
    padding: 0 0 11px;
    margin: 0;
    color: #0e618a; }

#cart_table.pure-table td {
  padding: .25em;
  font-size: .787rem; }

footer {
  display: grid;
  grid-template-columns: 1;
  text-align: center;
  border-top: 4px solid #cccccc;
  background: #2a6078;
  padding: 15px;
  margin: 45px 0 0 0; }
  footer p {
    margin: 0;
    padding: 0;
    color: #fff; }
    footer p a {
      color: #fff;
      text-decoration: none; }
    footer p#cjgraphix-line {
      font-size: .6rem;
      text-align: center; }
      footer p#cjgraphix-line a {
        color: rgba(255, 255, 255, 0.7); }
  footer ul {
    margin: 0 auto;
    padding: 3px 0;
    text-align: center; }
    footer ul li {
      display: inline-block;
      margin-right: 8px;
      padding: 0 3px 0 0; }
      footer ul li a {
        color: #fff; }

@media screen and (min-width: 800px) {
  header {
    padding: 0 0 0 0; }
    header h1 {
      text-align: left;
      border-bottom: none;
      padding-top: 8px;
      padding-left: 15px;
      padding-right: 45px;
      float: left; }
      header h1 img {
        margin: 0;
        height: 140px; }
    header h2 {
      font-size: 1.121rem;
      line-height: 2.1rem;
      text-transform: uppercase;
      color: #D0DAE4;
      background: #2A6078;
      text-align: right;
      padding: 3px 40px 3px 55px;
      margin-top: 0; }
    header #topbarnav {
      display: none; }
      header #topbarnav #account-options {
        float: right;
        text-align: right;
        font-size: .75rem;
        padding-right: 15px;
        width: auto; }
      header #topbarnav #mobilenav {
        display: none; }
        header #topbarnav #mobilenav .show-menu {
          text-decoration: none;
          color: #cccccc;
          text-align: right;
          cursor: pointer; }
        header #topbarnav #mobilenav input[type=checkbox] {
          display: none; }
    header nav {
      margin: 0 40px 0 0;
      position: relative;
      float: right;
      text-transform: lowercase; }
      header nav #nav_fullnav {
        display: inline-block;
        float: right;
        padding-top: 0;
        border-bottom: 2px solid #fff;
        background-color: #fff; }
      header nav.pure-menu-horizontal {
        width: auto; }
        header nav.pure-menu-horizontal ul {
          text-align: center; }
          header nav.pure-menu-horizontal ul li {
            display: inline-block !important;
            font-size: 1.0rem; }
            header nav.pure-menu-horizontal ul li a {
              display: block;
              color: #2a6078 !important;
              transition: color 1s; }
              header nav.pure-menu-horizontal ul li a:hover {
                color: #b9cd74 !important; }
              header nav.pure-menu-horizontal ul li a:after {
                display: none; }
            header nav.pure-menu-horizontal ul li ul {
              display: none !important; }
  #hero {
    margin: -40px 40px 40px; }
  #main #content {
    max-width: 100%;
    padding: 0 40px; }
  #content {
    padding: 0 15px; }
  #cart_table.pure-table td {
    padding: .5em 1em;
    font-size: 1rem; } }
