@font-face {
  font-family: "Play";
  src: url("../fonts/play-regular-webfont.eot");
  src: url("../fonts/play-regular-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/play-regular-webfont.woff2") format("woff2"), url("../fonts/play-regular-webfont.woff") format("woff"), url("../fonts/play-regular-webfont.ttf") format("truetype"), url("../fonts/play-regular-webfont.svg#Play") format("svg"); }

#window_width {
  display: none;
  position: fixed;
  bottom: 0;
  right: 0;
  padding: 0.25em;
  background-color: rgba(255, 255, 255, 0.5);
  font-size: 0.66em; }

/* global settings */
body {
  position: relative;
  background-color: #00345b;
  font-size: 100%;
  font-family: Helvetica; }

a {
  text-decoration: none;
  color: #333; }

a:hover {
  color: #31a5c6; }

img {
  border: 0 none; }

ul {
  list-style: none; }

p {
  font-family: Helvetica, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1.25rem;
  color: #666666; }

h1 {
  font-family: Play;
  font-size: 2.4rem;
  font-weight: normal;
  margin: 0 0 0.25em 0; }

h2 {
  font-family: Play;
  font-size: 1.8rem;
  margin: 0 0 0.25em;
  padding: 0 0 0.5rem;
  font-weight: normal; }

sup {
  font-size: 0.6em;
  vertical-align: top; }

.clearfix {
  clear: both;
  overflow: hidden; }

.hidden {
  display: none; }

#_loading {
  display: none;
  text-align: center; }

#_reloading {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.5); }
  #_reloading .content {
    position: absolute;
    right: 0;
    left: 0;
    width: 100%;
    margin: 12em auto;
    text-align: center; }
  #_reloading .title {
    margin: 0 0 1em 0;
    color: #00345b; }

#_catalog_item, #_sidebar_section, #_sidebar_item, #_dealer_list, #_filter_item, #_detail_item, #_outfitter_item {
  display: none; }

/* jquery templates */
#_page_bottom {
  height: 1px; }

/* used to trigger update products on scroll */
#featured_products {
  display: none;
  margin: 0 0 0.5em 0; }

#find_a_dealer_modal, .cc-processing {
  display: none;
  z-index: 1000;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 30em;
  max-width: 90%;
  height: 30em;
  max-height: 90%;
  border: 1px solid #999;
  background-color: #fff;
  border-radius: 0.5em;
  -webkit-box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3);
  box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3); }
  #find_a_dealer_modal .heading, .cc-processing .heading {
    background-color: #31a5c6;
    color: #fff;
    padding: 0.5em 0 0.4em 0.66em;
    font-weight: bold;
    border-top-right-radius: 0.4em;
    border-top-left-radius: 0.4em;
    text-transform: uppercase; }
  #find_a_dealer_modal .close_modal, .cc-processing .close_modal {
    position: absolute;
    top: 0;
    right: 0;
    padding: 0.5em;
    font-weight: bold;
    cursor: pointer;
    color: #fff; }
  #find_a_dealer_modal .content, .cc-processing .content {
    padding: 1em; }
  #find_a_dealer_modal .label, .cc-processing .label {
    display: none; }
  #find_a_dealer_modal input[type=text], .cc-processing input[type=text] {
    font-size: 1em;
    width: 7em;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    outline: none;
    padding: 0.25em;
    border: 1px solid #ddd; }
  #find_a_dealer_modal input[type=text]:focus, .cc-processing input[type=text]:focus {
    box-shadow: 0 0 5px #51cbee;
    border: 1px solid #51cbee; }
  #find_a_dealer_modal .button, .cc-processing .button {
    display: inline-block;
    background-color: #31a5c6;
    color: #fff;
    font-size: 0.9em;
    padding: 0.5em 1em;
    margin: 0 1em;
    border-radius: 0.25em;
    cursor: pointer; }
  #find_a_dealer_modal .message, .cc-processing .message {
    padding: 0.75em 0;
    text-align: center;
    color: #333;
    font-size: 0.9em; }
  #find_a_dealer_modal .error, .cc-processing .error {
    color: red; }
  #find_a_dealer_modal .dealer_list_wrapper, .cc-processing .dealer_list_wrapper {
    height: 24em;
    overflow: scroll;
    font-size: 0.9em; }
    #find_a_dealer_modal .dealer_list_wrapper li, .cc-processing .dealer_list_wrapper li {
      border-top: 1px solid #ccc;
      padding: 0.25em 0;
      cursor: pointer; }
    #find_a_dealer_modal .dealer_list_wrapper li:hover, .cc-processing .dealer_list_wrapper li:hover {
      background-color: #e4e4e4; }
    #find_a_dealer_modal .dealer_list_wrapper li.selected, .cc-processing .dealer_list_wrapper li.selected {
      background-color: #e4e4e4; }
    #find_a_dealer_modal .dealer_list_wrapper .price, .cc-processing .dealer_list_wrapper .price {
      float: right;
      text-align: right;
      color: #ce4c24;
      font-size: 1.1em;
      font-family: "Play"; }
    #find_a_dealer_modal .dealer_list_wrapper .distance, .cc-processing .dealer_list_wrapper .distance {
      float: right;
      text-align: right;
      clear: right;
      font-size: 0.9em; }
    #find_a_dealer_modal .dealer_list_wrapper a, .cc-processing .dealer_list_wrapper a {
      color: #31a5c6;
      font-weight: bold; }

.cc-processing {
  height: 16em; }
  .cc-processing ul {
    list-style: none;
    padding: 0.5em 0.5em 0 0.5em;
    font-family: Play;
    font-size: 1.5em; }
    .cc-processing ul li {
      margin-bottom: 1em; }
    .cc-processing ul li.current {
      color: #000; }
    .cc-processing ul .progress {
      float: right;
      color: green; }
  .cc-processing .processing-error {
    text-align: center;
    color: red; }
  .cc-processing .controls {
    margin: 1em 0 0 0;
    text-align: center;
    display: none; }

/* header */
header {
  background: -webkit-linear-gradient(#000, #00345b);
  background: -o-linear-gradient(#000, #00345b);
  background: -moz-linear-gradient(#000, #00345b);
  background: linear-gradient(#000, #00345b); }
  header .meta_wrapper {
    background-color: #00345b;
    text-align: center;
    color: #fff;
    padding: 0.25rem;
    font-size: 0.9rem; }
    header .meta_wrapper .meta_label {
      display: none;
      padding: 0 1em 0 0; }
    header .meta_wrapper a.find_a_dealer {
      color: #31a5c6;
      text-transform: uppercase; }
      header .meta_wrapper a.find_a_dealer .icon {
        vertical-align: middle;
        height: 27px; }
    header .meta_wrapper a.find_a_dealer:hover {
      color: #3bc3ea; }
      header .meta_wrapper a.find_a_dealer:hover .icon {
        -webkit-filter: brightness(1.25); }
  header .content_wrapper {
    text-align: center; }
  header .logo img {
    width: 90%;
    display: block;
    margin: 0 auto; }
  header .search_wrapper {
    background-color: #fff;
    height: 1.5em;
    width: 42%;
    border-radius: 0.25em;
    border: 1px solid #666;
    float: left;
    margin: 0.75em 0em 0.5em 0.5em; }
    header .search_wrapper .search_text {
      background: transparent;
      border: none;
      width: 85%;
      font-size: 1em;
      margin: 0;
      padding: 0.15em 0 0 0.15em; }
    header .search_wrapper .search_text:focus {
      outline: 0; }
    header .search_wrapper .search_button {
      float: right;
      height: 0.8em;
      margin: 0.25em 0.15em 0 0;
      cursor: pointer; }
  header .my_account_wrapper {
    float: right;
    margin: 1.15em 1em 0 0;
    font-family: "Play";
    font-size: 0.85em;
    color: #fff; }
    header .my_account_wrapper a {
      color: #fff; }
    header .my_account_wrapper a:hover {
      color: #fff; }
  header .about_menu {
    float: right;
    font-size: 0.85em;
    color: #fff;
    cursor: pointer;
    margin: 18px 1em -26px 0;
    position: relative;
    z-index: 4;
    clear: both; }
    header .about_menu ul {
      display: none;
      position: absolute;
      right: 0;
      white-space: nowrap;
      z-index: 5;
      background-color: #fff;
      padding: 0.5em;
      margin-top: 0.5em;
      border-radius: 0.5em;
      border-top-left-radius: 0;
      border-top-right-radius: 0;
      border: 1px solid #E3E3E3;
      border-top: none; }
      header .about_menu ul li {
        padding: 0.25em;
        text-align: left; }
  header .shopping_cart_wrapper {
    float: right;
    margin: 0.75em 0.5em 0 0;
    cursor: pointer; }
    header .shopping_cart_wrapper img {
      float: left; }
    header .shopping_cart_wrapper .checkout_count {
      float: left;
      font-size: 1.25rem;
      padding: 0.1em 0 0 0.25em;
      color: #fff; }
  header .nav_wrapper {
    position: relative;
    z-index: 3;
    text-align: left;
    background-color: #31a5c6;
    -webkit-box-shadow: 0 3px 3px -3px #000;
    -moz-box-shadow: 0 3px 3px -3px #000;
    box-shadow: 0 3px 3px -3px #000; }
    header .nav_wrapper .hamburger {
      padding: 0.25em 0 0 0.25em;
      cursor: pointer; }
  header nav {
    position: relative; }
    header nav ul {
      display: none;
      clear: both; }
      header nav ul a:hover {
        color: #00345b; }
      header nav ul li {
        border-top: 1px solid #dbdbdb; }
        header nav ul li a {
          display: block;
          padding: 0.25em; }
      header nav ul ul {
        display: none;
        background-color: #707070; }
        header nav ul ul a {
          display: block;
          width: 100%; }
        header nav ul ul a:hover {
          background-color: #31a5c6; }
  header .recently_viewed {
    display: none;
    position: absolute;
    bottom: -1.55em;
    left: 0;
    height: 1.5em;
    width: 100%; }
    header .recently_viewed .content_wrapper {
      height: 133px;
      display: none;
      overflow-x: scroll;
      overflow-y: hidden;
      background-color: #fff;
      border: 1px solid #ccc;
      color: #000; }
    header .recently_viewed .contents .recently_viewed_item {
      height: 110px;
      width: 140px;
      margin: 5px;
      display: inline-block; }
    header .recently_viewed .contents .thumb_wrapper {
      width: 140px;
      height: 80px;
      position: relative; }
    header .recently_viewed .contents .thumb {
      max-width: 135px;
      max-height: 75px;
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      margin: auto; }
    header .recently_viewed .contents .description {
      font-size: 0.66em; }
    header .recently_viewed .tab {
      padding: 0.25em 1em;
      float: right;
      text-align: center;
      font-size: 0.8em;
      background-color: #00345b;
      color: #fff;
      border-bottom-left-radius: 0.5em;
      border-bottom-right-radius: 0.5em;
      cursor: pointer;
      margin-top: -1px; }
    header .recently_viewed a {
      text-transform: none;
      color: #00345b; }

/* inputs */
select {
  -webkit-appearance: none !important;
  border-radius: 4px;
  background-image: url("../images/arrow-down-dark.png");
  background-position: 98% center;
  background-repeat: no-repeat;
  border: 1px solid #cccccc;
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: rgba(0, 0, 0, 0.75);
  line-height: normal; }

.dotted {
  border-bottom: 2px dotted #31a5c6; }

.error-message {
  color: #c00000;
  text-align: center; }

.info-message {
  color: #0fb432; }

/* main */
.main_wrapper {
  background-color: #f1f1f1;
  padding: 0.5em 0;
  position: relative; }

main.content.about h1 {
  margin: 0.25em; }

main.content.about p {
  padding: 0.5em; }

main.content.about .about-image {
  margin: 1em auto;
  /* Below is just placehlder */
  height: 22em;
  width: 15em;
  text-align: center;
  vertical-align: middle;
  background-color: #fff;
  border: 1px solid #E3E3E3; }

main.content.about h2 {
  margin: 0 0 0.25em 0.25em; }

main.content {
  min-height: 30em;
  max-width: 1080px;
  margin: 0 auto;
  position: relative; }
  main.content aside {
    display: none;
    width: 97%;
    margin: 0 auto;
    position: relative;
    background: -webkit-linear-gradient(left, #e4e4e4, #fff);
    /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(right, #e4e4e4, #fff);
    /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(right, #e4e4e4, #fff);
    /* For Firefox 3.6 to 15 */
    background: linear-gradient(to right, #e4e4e4, #fff);
    /* Standard syntax */ }
    main.content aside .sidebar_content {
      width: 100%;
      clear: both; }
      main.content aside .sidebar_content .search_wrapper {
        padding: 0.25em;
        background-color: #fff;
        border: 1px solid #ccc;
        margin: 0 0 0.25em 0; }
        main.content aside .sidebar_content .search_wrapper .search_text {
          background: transparent;
          border: none;
          width: 85%;
          font-size: 0.9em;
          padding: 0.15em 0.5em; }
        main.content aside .sidebar_content .search_wrapper .search_text:focus {
          outline: 0; }
        main.content aside .sidebar_content .search_wrapper .search_button {
          float: right;
          height: 1em;
          margin: 0.25em;
          cursor: pointer; }
      main.content aside .sidebar_content .sidebar_pane {
        padding: 0 0 0.33em 0;
        margin: 0 0 0.5em 0; }
      main.content aside .sidebar_content .sidebar_pane_scrollable {
        max-height: 299px;
        overflow: scroll; }
      main.content aside .sidebar_content ul {
        font-size: 0.9rem; }
      main.content aside .sidebar_content h6 {
        background-image: url("../images/arrow-down-light.png");
        background-position: 98% center;
        background-repeat: no-repeat;
        background-color: #31a5c6;
        color: #fff;
        font-size: 0.85em;
        padding: 0.25em;
        cursor: pointer;
        text-transform: uppercase; }
      main.content aside .sidebar_content .loading {
        background-color: #f1f1f1;
        text-align: center; }
        main.content aside .sidebar_content .loading h6 {
          background-image: none; }
        main.content aside .sidebar_content .loading img {
          width: 50%; }
      main.content aside .sidebar_content .filter-sidebar {
        font-size: 0.9em;
        width: 100%; }
      main.content aside .sidebar_content li {
        border-bottom: 1px dotted #ccc;
        padding: 0.25em 0.25em 0.33em 0.5em; }
        main.content aside .sidebar_content li .sidebar_count {
          font-size: 0.75em;
          color: #666;
          padding: 0 0 0 0.5em; }
      main.content aside .sidebar_content li:last-of-type {
        border-bottom: 0 none;
        padding: 0.25em 0 0 0.5em; }
      main.content aside .sidebar_content li.subhead {
        color: #00345b;
        margin-top: 1em;
        border-bottom: 0 none;
        border-top: 1px dotted #ccc; }
      main.content aside .sidebar_content li.subhead:first-of-type {
        border-top: 0 none; }
      main.content aside .sidebar_content li.indented {
        padding-left: 0.5em;
        border-bottom: 0 none; }
  main.content #filters {
    display: none;
    padding: 0 0 0.75em 0;
    background-color: #fff; }
    main.content #filters .title {
      font-family: Play;
      color: #fff;
      background-color: #31a5c6;
      margin: 0;
      padding: 0.25em; }
    main.content #filters ul.filter_set {
      font-size: 0.9em;
      color: #666;
      padding: 0.25em 0 0 0.25em; }
      main.content #filters ul.filter_set li {
        border-bottom: 1px dotted #ccc;
        padding: 0.25em 0 0.33em 0;
        cursor: pointer; }
        main.content #filters ul.filter_set li .close {
          float: left;
          padding: 0 0.25em;
          color: #75271B; }
      main.content #filters ul.filter_set li:last-of-type {
        border-bottom: 0 none;
        padding: 0.25em 0 0 0; }
      main.content #filters ul.filter_set li:hover {
        color: #75271B; }
  main.content .content_wrapper {
    width: 95%;
    margin: 0 auto; }
  main.content .marquees {
    display: none;
    margin: 0 0 0.5em 0;
    position: relative; }
    main.content .marquees .blank {
      width: 100%;
      display: block; }
    main.content .marquees .marquee_set {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%; }
      main.content .marquees .marquee_set .marquee_link {
        display: none;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%; }
        main.content .marquees .marquee_set .marquee_link img {
          width: 100%;
          display: block; }
  main.content section.sort {
    display: none; }
    main.content section.sort .results {
      float: left;
      font-size: 1.1em;
      padding: 0.25em 0 0 0; }
    main.content section.sort .sort_by_controls {
      float: right;
      font-family: Play, Helvetica;
      margin: 0 0 0.5em 0; }
    main.content section.sort label {
      color: gray;
      font-size: 0.8em; }
    main.content section.sort select {
      width: 12em; }

.button {
  background-color: #31a5c6;
  color: #fff;
  text-align: center;
  padding: 0.25em;
  cursor: pointer; }

.button:hover {
  background-color: #3bc3ea; }

.dead, .dead:hover {
  background-color: #dbdbdb; }

.button.out-of-stock {
  background-color: #dbdbdb; }

.catalog_item {
  width: 100%;
  margin: 0 0 0.5em 0;
  padding: 0 0 0.25em 0;
  background-color: #fff;
  border: 1px solid #ccc;
  position: relative; }
  .catalog_item .product_image_wrapper {
    position: relative;
    width: 100%;
    height: 200px;
    border-bottom: 1px solid #ccc; }
  .catalog_item .product_image {
    max-width: 95%;
    max-height: 95%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto; }
  .catalog_item .product_logo {
    max-width: 110px;
    max-height: 55px;
    position: absolute;
    bottom: 2px;
    right: 2px;
    padding: 0.25em;
    background-color: rgba(255, 255, 255, 0.8);
    border-top-left-radius: 0.5em; }
  .catalog_item .badge {
    position: absolute;
    bottom: -3px;
    left: 0; }
  .catalog_item .content {
    width: 100%;
    padding: 0.5em;
    position: relative; }
    .catalog_item .content .product_description {
      display: block;
      margin: 0 0 0.5em 0;
      height: 2em;
      font-family: Play, Helvetica;
      color: #00345b;
      text-align: center;
      font-size: 1.15em; }
    .catalog_item .content .facets {
      font-size: 0.8em;
      color: #000;
      line-height: 1.25em; }
    .catalog_item .content .facet_label {
      float: left;
      clear: left;
      padding: 0 2% 0 0;
      text-align: right;
      color: #666; }
    .catalog_item .content .facet_value {
      float: left;
      overflow-x: hidden;
      white-space: nowrap; }
    .catalog_item .content .product_code {
      clear: both;
      float: left;
      margin: 1em 0 0.5em 0;
      font-size: 0.9em; }
    .catalog_item .content .price {
      float: right;
      color: #ce4c24;
      font-family: Play, Helvetica;
      font-size: 1.5em;
      margin: 0.25em 0; }
    .catalog_item .content .controls {
      clear: both; }
    .catalog_item .content .view_details {
      float: left;
      width: 48%;
      background-color: #666;
      color: #fff;
      text-align: center;
      padding: 0.25em; }
    .catalog_item .content .add_to_cart, .catalog_item .content .find_a_dealer, .catalog_item .content .item_in_cart, .catalog_item .content .out-of-stock {
      float: right;
      width: 48%; }

footer {
  font-family: Play, Helvetica;
  padding: 0 0 1em 0;
  background: transparent url("/templates/shootingstore/images/smoking-shells.png");
  background-position: right bottom;
  background-repeat: no-repeat; }
  footer .content {
    width: 95%;
    margin: 0 auto;
    position: relative; }
  footer h3 {
    color: #fff;
    font-size: 1.25em;
    font-weight: normal;
    margin: 0.75em 0 0 0;
    padding: 0; }
  footer h4 {
    color: #31a5c6;
    font-weight: normal;
    font-size: 1.125em;
    padding-left: 0.35em;
    margin: 0.5em 0 0 0; }
  footer a {
    color: #fff;
    font-size: 0.9em;
    margin-left: 1em; }
  footer a:hover {
    color: #31a5c6; }
  footer li {
    line-height: 1.2; }
  footer .grid-1-4 {
    width: 100%;
    margin: 0 0 0.5em 0; }
  footer .social a {
    color: #31a5c6;
    position: absolute;
    bottom: 1em;
    left: 0;
    margin: 0;
    font-size: 1.25em; }
  footer #copyright {
    color: #fff;
    font-size: 0.7em;
    padding: 1em 0 0 0;
    text-align: center;
    position: absolute;
    bottom: 0;
    left: 0; }

@media (min-width: 568px) {
  main.content aside .sidebar_content .sidebar_pane {
    float: left;
    width: 49%;
    margin: 0 2% 0.5em 0; }
  main.content aside .sidebar_content .sidebar_pane:nth-of-type(2n) {
    margin: 0 0 0.5em 0; }
  main.content.about .about-image {
    float: left;
    margin: 0 1em 0 0.5em; }
  .catalog_item {
    float: left;
    width: 49%;
    margin: 0 2% 0.5em 0;
    padding: 0 0 0.5em 0; }
  .catalog_item:nth-of-type(2n) {
    margin: 0 0 0.5em 0; }
  .catalog_item:nth-of-type(2n+1) {
    clear: both; }
  #find_a_dealer_modal .label, .cc-processing .label {
    display: inline-block;
    color: #666;
    padding: 0 1em 0 0; }
  footer .grid-1-4 {
    float: left;
    width: 49%;
    margin: 0 1% 0.5em 0; }
  footer .grid-1-4:nth-of-type(2n) {
    margin: 0 0 0.5em 0; }
  footer #copyright {
    text-align: left; } }

@media (min-width: 720px) {
  .detail_wrapper .half {
    width: 50%;
    padding: 1em; }
  .detail_wrapper .half p {
    width: 90%; }
  .detail_wrapper .price {
    float: none;
    font-size: 2.5em; }
  .detail_wrapper .add_to_cart, .detail_wrapper .item_in_cart {
    float: none;
    display: block;
    margin: 1em 0; }
  .cc-processing {
    height: 20em; }
    .cc-processing ol {
      font-size: 1.75em; } }

@media (min-width: 768px) {
  main.content aside sidebar_content {
    width: 100%; }
    main.content aside sidebar_content .sidebar_pane {
      width: 32.5%;
      margin: 0 1% 0.5em 0; }
    main.content aside sidebar_content .sidebar_pane:nth-of-type(2n) {
      margin: 0 1% 0.5em 0; }
    main.content aside sidebar_content .sidebar_pane:nth-of-type(3n) {
      margin: 0 0 0.5em 0; }
  footer .grid-1-4 {
    width: 32%;
    margin: 0 1% 0.5em 0; }
  footer .grid-1-4:nth-of-type(2n) {
    margin: 0 1% 0.5em 0; }
  footer .grid-1-4:nth-of-type(3n) {
    margin: 0 0 0.5em 0; } }

@media (min-width: 1000px) {
  .detail_wrapper h1 {
    font-size: 1.75em; } }

@media (min-width: 1024px) {
  main.content.about aside {
    width: 24%;
    margin: 1.5em 2% 0 0;
    padding: 1em; }
    main.content.about aside a {
      font-family: "Play";
      font-size: 1.5em;
      color: #31a5c6;
      display: block;
      padding: 0.25em 0; }
    main.content.about aside a:hover {
      color: #00345b; }
  main.content.about section {
    padding-top: 1.5em;
    width: 74%;
    float: left; }
  header .meta_wrapper .meta_label {
    display: inline-block; }
  header .content_wrapper {
    width: 97%;
    margin: 0 auto;
    height: 64px; }
  header .logo img {
    width: auto;
    float: left;
    height: 100%; }
  header .hamburger {
    display: none; }
  header .search_wrapper {
    height: 2em;
    width: 27%;
    border-radius: 0.5em;
    float: left;
    margin: 1.5em 3em 0 3em; }
    header .search_wrapper .search_text {
      width: 85%;
      font-size: 1em;
      margin: 0.15em 0 0 0;
      padding: 0.25em 0.5em; }
    header .search_wrapper .search_button {
      height: 1.25em;
      margin: 0.25em; }
  header .my_account_wrapper {
    float: right;
    margin: 1.25em 2em 0 0;
    font-size: 1em; }
    header .my_account_wrapper a {
      color: #31a5c6; }
    header .my_account_wrapper a:hover {
      color: #3bc3ea; }
  header .about_menu {
    margin: 0.5em 2em 0 0;
    color: #31a5c6;
    clear: none; }
  header .shopping_cart_wrapper {
    float: right;
    margin: 1.75em 0 0 0; }
    header .shopping_cart_wrapper .checkout_count {
      font-size: 1.25rem;
      padding: 0.1em 0 0 0.25em;
      color: #31a5c6; }
  header .shopping_cart_wrapper:hover .checkout_count {
    color: #3bc3ea; }
  header nav {
    display: inherit;
    font-family: Play, Helvetica;
    font-size: 1.15em;
    margin: 0px auto;
    max-width: 1080px;
    text-align: center;
    /* Sass for child selector! Prevents conflits with nested ul */ }
    header nav a {
      color: #fff;
      text-transform: uppercase; }
    header nav a:hover {
      color: #00345b; }
    header nav > ul {
      display: block !important; }
    header nav ul li {
      height: auto;
      display: inline-block;
      border: none; }
      header nav ul li a {
        padding: 0.5em 0.75em;
        display: inline-block; }
      header nav ul li ul {
        display: none;
        position: absolute;
        padding: 1px 0 0 0;
        z-index: 1; }
        header nav ul li ul li {
          text-align: left;
          display: block;
          font-size: 0.9em; }
        header nav ul li ul li:first-of-type {
          font-weight: normal;
          font-size: 0.9em; }
    header nav ul li:first-of-type {
      font-weight: bold;
      font-size: 1.1em; }
  .main_wrapper {
    padding: 1em 0; }
  main.content .catalog_head {
    margin: 0 0 0.25em 1%; }
  main.content aside {
    display: block !important;
    width: 18%;
    margin: 0 1% 0 1%;
    float: left; }
    main.content aside .sidebar_prompt {
      display: inherit;
      font-family: Play, Helvetica;
      background-color: #00345b;
      color: #fff;
      padding: 0.2em 0.25em;
      margin: 0 0 0.5em 0; }
    main.content aside .sidebar_content {
      display: inherit; }
      main.content aside .sidebar_content .search_wrapper {
        margin: 0 0 0.25em 0; }
      main.content aside .sidebar_content .sidebar_pane {
        width: 100%;
        margin: 0 0 0.5em 0; }
      main.content aside .sidebar_content .sidebar_pane:nth-of-type(2n) {
        margin: 0 0 0.5em 0; }
      main.content aside .sidebar_content .sidebar_pane:nth-of-type(3n) {
        margin: 0 0 0.5em 0; }
  main.content .content_wrapper {
    width: 79%;
    float: left; }
  main.content .marquees {
    margin: 0 0 1em 0; }
  .catalog_item {
    float: left;
    width: 32.5%;
    margin: 0 1% 0.5em 0; }
  .catalog_item:nth-of-type(2n) {
    margin: 0 1% 0.5em 0; }
  .catalog_item:nth-of-type(2n+1) {
    clear: none; }
  .catalog_item:nth-of-type(3n) {
    margin: 0 0 0.5em 0; }
  .catalog_item:nth-of-type(3n+1) {
    clear: both; }
  footer .grid-1-4 {
    width: 24%;
    margin: 0 1% 0.5em 0; }
  footer .grid-1-4:nth-of-type(3n) {
    margin: 0 1% 0.5em 0; }
  footer .grid-1-4:nth-of-type(4n) {
    margin: 0 0 0.5em 0; } }

@media (min-width: 1100px) {
  header .content_wrapper {
    width: 1080px;
    margin: 0 auto; }
  header .search_wrapper {
    width: 31%; }
  main.content .catalog_head {
    margin: 0 0 0.25em 0; }
  main.content aside {
    margin: 0 1% 0 0; }
  main.content .content_wrapper {
    width: 80%; }
  footer .content {
    width: 1080px; } }

#_detail_view {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 1.5% 2.5%;
  background-color: rgba(255, 255, 255, 0.5); }

.detail_wrapper {
  height: 100%;
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  padding: 0.5em 1em; }
  .detail_wrapper .loading {
    margin: 2em;
    text-align: center; }
  .detail_wrapper .prev {
    float: left;
    margin: 0 0 1em 0;
    color: #31a5c6; }
  .detail_wrapper .product_image {
    width: 100%;
    background-color: #fff;
    border: 1px solid #ddd;
    margin-bottom: 1em;
    padding: 1em 0 2em 0;
    position: relative;
    clear: both; }
  .detail_wrapper .full_image {
    max-width: 90%;
    max-height: 680px;
    margin: 0 auto;
    display: block; }
  .detail_wrapper .product_logo {
    position: absolute;
    right: 6px;
    bottom: 6px;
    max-width: 180px;
    max-height: 60px; }
  .detail_wrapper .badge {
    position: absolute;
    left: 0px;
    bottom: -3px; }
  .detail_wrapper .my360 {
    position: absolute;
    left: 40%;
    bottom: 6px;
    font-size: 1.25em; }
  .detail_wrapper hr {
    border: none;
    border-top: 1px solid #e1e1e1; }
  .detail_wrapper h1 {
    color: #00345b;
    font-weight: normal;
    font-size: 1.25em;
    margin: 0.5em 0;
    float: left;
    width: 66%;
    clear: left; }
  .detail_wrapper .price {
    font-size: 2em;
    color: #ce4c24;
    font-family: Play, Helvetica;
    float: right; }
  .detail_wrapper .add_to_cart, .detail_wrapper .item_in_cart, .detail_wrapper .find_a_dealer {
    float: right;
    clear: right;
    width: 8em;
    margin: 0.5em 0;
    padding: 0.25em; }
  .detail_wrapper .unavailable {
    float: right;
    clear: right;
    margin: 0.5em 0;
    padding: 0.25em;
    color: #31a5c6;
    font-family: Play, Helvetica;
    font-size: 1em; }
  .detail_wrapper .item-info {
    clear: both;
    margin: 1em 0;
    color: #666; }
    .detail_wrapper .item-info span {
      color: #ce4c24;
      padding: 0 1em 0 0; }
    .detail_wrapper .item-info a {
      color: #ce4c24; }
  .detail_wrapper h3 {
    color: #CC5A39;
    text-align: left;
    font-weight: normal;
    font-size: 1.4375rem;
    line-height: 1.75rem;
    margin: 0 0 0.5em;
    clear: both; }
  .detail_wrapper p {
    font-size: 1rem;
    text-align: left;
    line-height: 1.6;
    width: 100%; }
  .detail_wrapper .half_left {
    width: 100%;
    float: left; }
  .detail_wrapper .half_right {
    width: 100%;
    float: left; }
  .detail_wrapper .half_left a, .detail_wrapper .half_right a {
    color: #ce4c24; }
  .detail_wrapper table {
    border: 1px solid #DDD;
    border-collapse: collapse;
    width: 100%;
    float: right;
    margin-bottom: 2em; }
  .detail_wrapper th {
    text-transform: uppercase;
    color: #CC5A39;
    text-align: center;
    font-weight: bold;
    font-size: 1.4375rem;
    padding: 0.5625rem 0.625rem; }
  .detail_wrapper td {
    padding: 0.5625rem 0.625rem;
    font-size: 0.875rem;
    color: #222;
    text-align: right; }
  .detail_wrapper td.label {
    width: 40%; }
  .detail_wrapper td:nth-of-type(2n) {
    text-align: left;
    color: #CC5A39; }
  .detail_wrapper tr {
    background-color: #F9F9F9; }
  .detail_wrapper tr:nth-of-type(2n) {
    background-color: #F1F1F1; }
  .detail_wrapper .outfitter_container {
    display: none;
    border: 1px solid #e1e1e1;
    border-right: none;
    border-left: none;
    clear: both;
    margin-bottom: 1em; }
  .detail_wrapper .outfitter_logo {
    width: 200px;
    display: block;
    margin: 1em auto; }
  .detail_wrapper .outfitter_tabs {
    text-align: center; }
  .detail_wrapper .outfitter_buttons {
    text-align: center; }
  .detail_wrapper .outfitter_tab {
    float: left;
    padding: 0.5em;
    margin: 0.5em;
    position: relative; }
  .detail_wrapper .outfitter_tab_button {
    cursor: pointer;
    padding: 0.25em;
    margin: 0 1px 0 0;
    color: #fff;
    background-color: #31A5CC;
    display: inline-block;
    margin-bottom: 1em; }
  .detail_wrapper .outfitter_tab_button:hover, .detail_wrapper .outfitter_tab_button.selected {
    background-color: #00345B; }
  .detail_wrapper .outfitter_pane {
    display: none; }
  .detail_wrapper .outfitter_loading {
    padding: 70px 0 0 0;
    text-align: center; }
  .detail_wrapper .outfitter_sort {
    display: none;
    text-align: center;
    border-top: 1px solid #dbdbdb;
    padding: 0.25em; }
    .detail_wrapper .outfitter_sort select {
      width: 15em;
      height: 2.5em; }
    .detail_wrapper .outfitter_sort a {
      color: #31a5c6; }
    .detail_wrapper .outfitter_sort div {
      margin: 0.5em; }
  .detail_wrapper .outfitter_products {
    height: 28em;
    overflow: scroll; }
    .detail_wrapper .outfitter_products table {
      width: 100%;
      text-align: center; }
    .detail_wrapper .outfitter_products tr {
      border-bottom: 1px solid #dbdbdb; }
    .detail_wrapper .outfitter_products td {
      background-color: #fff;
      color: #222; }
    .detail_wrapper .outfitter_products td:first-of-type {
      width: 110px; }
    .detail_wrapper .outfitter_products .outfitter_pane {
      min-height: 29em; }
    .detail_wrapper .outfitter_products .outfitter_image_wrapper {
      width: 110px;
      height: 50px;
      position: relative; }
    .detail_wrapper .outfitter_products .outfitter_thumbnail_image {
      max-width: 95%;
      max-height: 95%;
      position: absolute;
      left: 0;
      top: 0;
      right: 0;
      bottom: 0;
      margin: auto; }
    .detail_wrapper .outfitter_products .outfitter_meta_wrapper {
      font-size: 0.8em;
      margin: 0.5em 0 0 0; }
    .detail_wrapper .outfitter_products .outfitter_meta {
      padding: 0 1em 0 0; }
    .detail_wrapper .outfitter_products .outfitter_meta a {
      color: #31A5CC; }
    .detail_wrapper .outfitter_products .outfitter_price {
      font-size: 1.5em;
      color: #CC5A39; }
    .detail_wrapper .outfitter_products .outfitter_add_to_cart, .detail_wrapper .outfitter_products .outfitter_item_in_cart {
      display: inline-block;
      padding: 0.5em 1em;
      font-size: 0.8em; }

#component_modal {
  display: none;
  z-index: 999;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 50em;
  max-width: 90%;
  height: 37em;
  max-height: 90%;
  border: 1px solid #999;
  background-color: #fff;
  border-radius: 0.5em;
  -webkit-box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3);
  box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3); }
  #component_modal .heading {
    background-color: #31a5c6;
    color: #fff;
    padding: 0.5em 0 0.4em 0.66em;
    font-weight: bold;
    border-top-right-radius: 0.4em;
    border-top-left-radius: 0.4em;
    text-transform: uppercase; }
  #component_modal .close_modal {
    position: absolute;
    top: 0;
    right: 0;
    padding: 0.5em;
    font-weight: bold;
    cursor: pointer;
    color: #fff; }
  #component_modal .content {
    width: 100%;
    height: 100%;
    padding: 1em; }

@media (min-width: 720px) {
  .detail_wrapper .unavailable {
    font-size: 1.25em; } }

@media (min-width: 1000px) {
  .detail_wrapper h1 {
    font-size: 1.75em; }
  .detail_wrapper .unavailable {
    font-size: 1.5em; }
  .detail_wrapper .my360 {
    left: 45%; }
  .detail_wrapper .half_left {
    width: 64%;
    float: left; }
  .detail_wrapper .half_right {
    width: 35%;
    float: right; } }

.checkout section {
  width: 100%;
  padding: 0 1em;
  font-family: Play;
  color: #666666; }

.checkout h1 {
  color: #00345b; }

.checkout .right-sidebar {
  background-color: whitesmoke;
  padding-bottom: 20px;
  margin-top: 1em; }

.checkout .right-sidebar p {
  margin: 0px;
  padding: 10px 15px 0px 15px;
  color: #000;
  font-size: 0.85em;
  line-height: 1.5; }

.checkout .right-sidebar p.sidebar-header {
  background-color: #32a5c6;
  padding: 7px 0px;
  text-align: center;
  margin: 0px;
  color: white; }

.checkout #_preferred_dealer {
  padding: 0 0 0.75em;
  text-align: center; }

.checkout #_preferred_dealer a {
  color: #31a5c6; }

.checkout #_update_list {
  padding: 0; }

.checkout .right-sidebar .sidebar-secondary-heading {
  text-align: center;
  font-size: 1.1em;
  color: #31a5c6;
  margin-bottom: -0.5em; }

.checkout .cart-items {
  margin: 1em 0;
  color: #000;
  width: 100%; }

.checkout .cart-items tr {
  border-bottom: 1px solid #cccccc; }

.checkout .cart-items tr:nth-child(1) {
  font-size: 0.9em;
  color: #4b4b4b; }

.checkout .cart-items tr:nth-child(1) td:nth-child(1) {
  background-color: #f1f1f1; }

.checkout .cart-items tr td:nth-child(3) {
  text-align: center;
  width: 3em; }
  .checkout .cart-items tr td:nth-child(3) input {
    float: right; }

.checkout .cart-items th {
  color: #666; }

.checkout .cart-items td:nth-child(4) {
  text-align: right; }

.checkout .cart-items td {
  padding: 0.5em 0.5em 1em; }

.checkout .cart-items td:nth-child(1) {
  background-color: #fff;
  text-align: center; }

.checkout table.cart-items input {
  width: 3em;
  text-align: center;
  margin: 0.15em 0;
  padding: 1em 0em;
  border-radius: 0.25em;
  display: inline-block;
  border: 1px solid #cccccc; }

.checkout .cart-items div {
  margin: 1em 0; }

.checkout .cart-items .quantity-change {
  display: inline-block;
  font-size: 1.25em;
  font-weight: bold;
  color: #fff;
  cursor: pointer;
  background: #31A5C6;
  border-radius: 0.33em;
  padding: 0.25em 0.5em;
  vertical-align: middle;
  width: 1.5em;
  float: right;
  margin: 0.25em; }

.checkout .cart-description {
  font-size: 0.95em; }

.checkout .item-count {
  font-size: 0.85em; }

.checkout .button {
  background-color: #31A5C6;
  color: #fff;
  margin: 1em 0 0 0;
  padding: 3px 6px;
  border-radius: 3px;
  cursor: pointer;
  display: inline-block; }

.checkout div.quantity-changed, .checkout div.price-changed {
  font-size: 0.75em;
  color: #F34C44;
  margin-bottom: 0; }

.checkout td.cart-image {
  padding: 0 0.5em; }

.checkout td.cart-image img {
  max-height: 50px;
  max-width: 100px;
  vertical-align: middle; }

.checkout .extra-info {
  float: left; }

.checkout .extra-info p {
  font-size: 0.85em;
  color: #000; }

.checkout p.please-note {
  color: #F34C44; }

.checkout .extra-info textarea {
  padding: 0.25em 0.5em;
  border-radius: 0.25em;
  width: 100%;
  border-color: #cccccc;
  margin: 0 0 1em 0;
  font-family: Play;
  font-size: 1em;
  height: 4em; }

.checkout .cart-pricing {
  float: right; }

.checkout .cart-pricing td {
  padding: 0.25em 0.5em;
  text-align: right; }

.checkout .cart-pricing td:nth-child(2) {
  color: #000; }

.checkout .cart-pricing tr:last-child {
  border-top: 1px solid #666666; }

.checkout .complete-order, .checkout .sign-in-complete {
  text-align: center;
  font-size: 1.3em;
  padding: 4em 0; }

.checkout .complete-order a, .checkout .sign-in-complete a {
  color: #31A5C6; }

.checkout .payment-info {
  position: relative; }

.checkout .sign-in-complete, .checkout .find-dealer-complete {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.75);
  text-align: center; }

.checkout .find-dealer-complete {
  padding-top: 3em; }
  .checkout .find-dealer-complete .find_a_dealer_search {
    display: inline-block;
    margin: 1em 0 0 1%;
    background-color: #31a5c6;
    width: 60%;
    color: #fff;
    font-size: 0.9em;
    padding: 0.675em 1em;
    border-radius: 0.25em;
    cursor: pointer; }

.checkout label {
  width: 30%;
  font-size: 0.85em;
  display: inline-block;
  text-align: right; }

.checkout input, .checkout .left-content select {
  width: 60%;
  margin: 0.45em 0 0 1%;
  padding: 0.25em 0.5em;
  border-radius: 0.25em;
  display: inline-block;
  -webkit-appearance: none;
  border: 1px solid #cccccc;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
  color: rgba(0, 0, 0, 0.75);
  font-size: 0.875rem;
  height: 2.3125rem;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.checkout select.month, .checkout select.year {
  width: 28%;
  margin: 0.45em 0.45em 0 1%; }

.checkout input[type="checkbox"] {
  -webkit-appearance: checkbox;
  box-shadow: none;
  width: inherit;
  height: inherit;
  width: 1em; }

.checkout .submit_wrapper .message {
  display: block;
  margin: 0 0 2em 27%;
  text-align: center;
  font-size: 0.9em;
  color: #666; }

.checkout .wait {
  display: none;
  text-align: center;
  margin: 1em; }

.checkout .left {
  float: left; }

.checkout .right {
  float: right; }

.checkout .cc-logos {
  display: block;
  margin: 0.5em 0 0 32%; }

.checkout .legal-age, .checkout .terms-of-use {
  font-size: 0.85em;
  color: #000;
  margin: 0.45em 0 0 32%; }
  .checkout .legal-age label, .checkout .terms-of-use label {
    width: inherit;
    font-size: 1em; }
  .checkout .legal-age a, .checkout .terms-of-use a {
    color: #31A5C6; }

.checkout .submit_button {
  font-size: 1.1em;
  color: #fff;
  padding: 0.5em 1em;
  display: inline-block;
  width: 13em;
  border-radius: 0.5em;
  cursor: pointer;
  text-align: center;
  background: #31A5C6;
  margin: 1em 0 1em 32%; }

.checkout .disabled {
  background: #ccc;
  cursor: default; }

@media (min-width: 1100px) {
  .checkout section {
    padding: 0; }
  .checkout .cart-items img {
    max-width: 190px;
    max-height: 110px; } }

@media (min-width: 800px) {
  .checkout .left-content {
    float: left;
    width: 74%; }
  .checkout .right-sidebar {
    width: 25%;
    max-width: 240px;
    float: right;
    padding-bottom: 10px; }
  .checkout .extra-info {
    width: 65%; }
  .checkout .half {
    width: 48%; }
  .checkout .button {
    margin: 0 0 0 1em; }
  .checkout .cart-items tr td:nth-child(3) {
    width: 9em; }
  .checkout .cart-items img {
    max-width: 10em; } }

.main_wrapper input.error, .main_wrapper select.error {
  border: 1px solid #F34C44; }

/* about us page */
#_dealer_details {
  display: none; }

.dealer_details {
  z-index: 999;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 30em;
  max-width: 90%;
  height: 15em;
  max-height: 90%;
  border: 1px solid #999;
  background-color: #fff;
  border-radius: 0.5em;
  -webkit-box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3);
  box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.3); }
  .dealer_details .heading {
    background-color: #31a5c6;
    color: #fff;
    padding: 0.5em 0 0.4em 0.66em;
    font-weight: bold;
    border-top-right-radius: 0.4em;
    border-top-left-radius: 0.4em;
    text-transform: uppercase; }
  .dealer_details .close_modal {
    position: absolute;
    top: 0;
    right: 0;
    padding: 0.5em;
    font-weight: bold;
    cursor: pointer;
    color: #fff; }
  .dealer_details .content {
    padding: 1em; }
    .dealer_details .content p {
      margin: 0;
      padding: 0; }

      .add_to_cart {display:none !important;}
      .out-of-stock {display:none !important;}
      .unavailable {display:none !important;}

      #covid19 {width:60%; margin:auto; border:2px solid red; padding:20px; margin-bottom:12px; }
      #covid19 h1 {color:red};
