a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline
}

html {
    scroll-behavior: smooth
}

body {
    line-height: 1
}

a {
    text-decoration-skip-ink: auto
}

button {
    outline: 0
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
    content: '';
    content: none
}

q {
    display: inline;
    font-style: italic
}

q:before {
    content: '"';
    font-style: normal
}

q:after {
    content: '"';
    font-style: normal
}

input[type=button],
input[type=password],
input[type=reset],
input[type=search],
input[type=submit],
input[type=text],
textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

td,
th {
    padding: 2px
}

big {
    font-size: 120%
}

small,
sub,
sup {
    font-size: 80%
}

sup {
    vertical-align: super
}

sub {
    vertical-align: sub
}

dd {
    margin-left: 20px
}

kbd,
tt {
    font-family: courier;
    font-size: 12px
}

ins {
    text-decoration: underline
}

del,
s,
strike {
    text-decoration: line-through
}

dt {
    font-weight: bold
}

address,
cite,
var {
    font-style: italic
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent
}

  /* font faces */
  @font-face {
    font-family: "GLOCK Sans Light";
    src: url("../fonts/GLOCKSans-Light.woff2") format("woff2");
  }
  
  @font-face {
    font-family: "GLOCK Sans Bold";
    src: url("../fonts/GLOCKSans-Bold.woff2") format("woff2");
  }
  
  @font-face {
    font-family: "GLOCK Sans Regular";
    src: url("../fonts/GLOCKSans-Regular.woff2") format("woff2");
  }
  
  @font-face {
    font-family: "Roboto Mono Light";
    src: url("../fonts/RobotoMono-Light.ttf") format("truetype");
  }
  
  @font-face {
    font-family: "Roboto Mono Regular";
    src: url("../fonts/RobotoMono-Regular.ttf") format("truetype");
  }

:root {
    --black: #000000;
    --orange: #F58220;
    --gray: #FAFAFA;
    --ltgray: #EFEFEF;
    --drkgray: #191919;
    --white: #FFFFFF;
    --normal-font: GLOCK Sans, Helvetica Neue, Helvetica, Arial, sans-serif;
    --bold-font: GLOCK Sans Bold, Helvetica Neue, Helvetica, Arial, sans-serif;
    --italic-font: GLOCK Sans Italic, Helvetica Neue, Helvetica, Arial, sans-serif
}

body {
    background-color: var(--black);
    color: var(--white);
    scroll-behavior: smooth;
}

main {
    margin-top: 88.5px;
}

@media (max-width:767.98px) {
    main {
        margin-top: 74.5px;
    }
}

div.logo-block {
    display: flex;
    justify-content: center;
}

.bg-black {
    background-color: var(--black)
}

.bg-drkgray {
    background-color: var(--drkgray)
}

.bg-gray {
    background-color: var(--gray)
}

.bg-ltgray {
    background-color: var(--ltgray)
}

@media (min-width:992px) {
    .bg-lg-ltgray {
        background-image: -webkit-gradient(linear, left top, left bottom, from(#FFFFFF), color-stop(29%, #FDFDFD), color-stop(64%, #DCDCDC), color-stop(70%, #FFFFFF));
        background-image: -webkit-linear-gradient(top, #FFFFFF 0%, #FDFDFD 29%, #DCDCDC 64%, #FFFFFF 70%);
        background-image: -o-linear-gradient(top, #FFFFFF 0%, #FDFDFD 29%, #DCDCDC 64%, #FFFFFF 70%);
        background-image: linear-gradient(180deg, #FFFFFF 0%, #FDFDFD 29%, #DCDCDC 64%, #FFFFFF 70%)
    }
}

.bg-orange {
    background-color: #c7e2c5;
}

@media (min-width:992px) {
    .bg-lg-orange {
        background-color: var(--orange)
    }
}

.bg-shooter {
    background-image: url(../img/follow-the-four-shooter.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center
}

@media only screen and (-o-min-device-pixel-ratio:2/1),
only screen and (-webkit-min-device-pixel-ratio:2),
only screen and (min--moz-device-pixel-ratio:2),
only screen and (min-device-pixel-ratio:2),
only screen and (min-resolution:2dppx),
only screen and (min-resolution:192dpi) {
    .bg-shooter {
        background-image: url(../img/follow-the-four-shooter@2x.jpg)
    }
}

.bg-follow-the-four {
    background-image: url(../img/follow-the-four-by-glock.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center
}

@media only screen and (-o-min-device-pixel-ratio:2/1),
only screen and (-webkit-min-device-pixel-ratio:2),
only screen and (min--moz-device-pixel-ratio:2),
only screen and (min-device-pixel-ratio:2),
only screen and (min-resolution:2dppx),
only screen and (min-resolution:192dpi) {
    .bg-follow-the-four {
        background-image: url(../img/follow-the-four-by-glock@2x.jpg)
    }
}

.bg-orange-glow {
    background-image: -webkit-radial-gradient(50% 50%, circle, rgba(77, 52, 30, 0.77) 0%, rgba(0, 0, 0, 0) 30%);
    background-image: -o-radial-gradient(50% 50%, circle, rgba(77, 52, 30, 0.77) 0%, rgba(0, 0, 0, 0) 30%);
    background-image: radial-gradient(circle at 50% 50%, rgba(77, 52, 30, 0.77) 0%, rgba(0, 0, 0, 0) 30%)
}

.parallax-window {
    min-height: 400px;
    background: transparent
}

.parallax-mirror {
    z-index: 0 !important
}

.z-index-1 {
    z-index: 1
}

.z-index--1 {
    z-index: -1
}

.stripe {
    background-color: var(--white);
    width: 100%;
    height: 8px;
    margin-bottom: 8px
}

.stripe-vertical {
    background-color: var(--white);
    width: 8px;
    height: 100%;
    margin-left: 8px
}

.stripe-orange {
    background-color: var(--orange);
    height: 10px;
    margin-bottom: 0px
}

.logo {
    height: 54px;
    -webkit-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    transition: all 0.2s ease
}

.rule-graphic {
    margin-top: -30px
}

@media (min-width:992px) {
    .rule-graphic {
        margin-bottom: -30px
    }
}

.fade-in-init {
    opacity: 100%
}

.opacity-20 {
    opacity: 0.2
}

.border-drkgray {
    border: 7px solid var(--drkgray)
}

sup {
    font-size: 60%;
    vertical-align: middle
}

@media (max-width:991.98px) {
    .ftf-pic {
        zoom: 0.5;
        -moz-transform: scale(0.5)
    }
}

@media (max-width:991.98px) {
    .bg-follow-the-four {
        background-image: url(../img/follow-the-four-by-glock-mobile.jpg);
        background-repeat: no-repeat;
        background-size: cover;
        background-position: center
    }
}

@media only screen and (max-width:991.98px) and (-o-min-device-pixel-ratio:2/1),
only screen and (max-width:991.98px) and (-webkit-min-device-pixel-ratio:2),
only screen and (max-width:991.98px) and (min--moz-device-pixel-ratio:2),
only screen and (max-width:991.98px) and (min-device-pixel-ratio:2),
only screen and (max-width:991.98px) and (min-resolution:2dppx),
only screen and (max-width:991.98px) and (min-resolution:192dpi) {
    .bg-follow-the-four {
        background-image: url(../img/follow-the-four-by-glock-mobile@2x.jpg)
    }
}

@media (min-width:768px) and (max-width:991.98px) {
    .bg-follow-the-four--padding {
        padding: 175px 0
    }
}

.border-black {
    border-bottom: 4px solid black
}

.border-btm-orange {
    border-bottom: 4px solid var(--orange)
}

html {
    font-family: var(--normal-font);
    font-weight: 400;
    font-size: 16px;
    line-height: 1.5;
    background-color: var(--black)
}

body {
    text-rendering: geometricPrecision;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: var(--normal-font);
    line-height: 1.1;
    color: var(--white)
}

a {
    font-family: var(--normal-font)
}

.small,
small {
    font-family: var(--normal-font);
    font-size: 0.75rem
}

.btn,
button {
    font-family: var(--bold-font);
    font-weight: bold;
    font-size: 1.125rem;
    text-transform: uppercase;
    text-decoration: none;
    display: block
}

p {
    font-family: var(--normal-font);
    font-size: 1.125rem;
    line-height: 1.33;
    font-weight: 400
}

.smaller {
    font-family: var(--normal-font);
    font-size: 1rem;
    line-height: 1.33;
    font-weight: 400
}

.larger {
    font-size: 1.25rem;
    line-height: 1.6
}

strong {
    font-family: var(--bold-font);
    font-weight: bold
}

h1 {
    font-family: var(--bold-font);
    font-weight: bold;
    font-size: 7.125rem;
    line-height: 0.87;
    letter-spacing: -4.81px;
    text-shadow: 0 0 34px rgba(0, 0, 0, 0.5)
}

@media (max-width:575.98px) {
    h1 {
        font-size: 4.3rem;
        letter-spacing: -2.9px
    }
}

.h1--ty {
    font-family: var(--bold-font);
    font-size: 2.5rem;
    color: var(--gray);
    letter-spacing: -1.69px;
    line-height: 1.1
}

@media (max-width:575.98px) {
    .h1--ty {
        font-size: 1.75rem;
        letter-spacing: -1.18px
    }
}

.subhead {
    font-family: var(--bold-font);
    font-size: 1.8125rem;
    line-height: 1;
    letter-spacing: 9.58px
}

@media (max-width:575.98px) {
    .subhead {
        font-size: 1.1rem
    }
}

h2 {
    font-family: var(--bold-font);
    font-weight: bold;
    font-size: 3rem;
    line-height: 0.98;
    letter-spacing: -2.02px;
    text-transform: uppercase;
    color: var(--black)
}

@media (max-width:575.98px) {
    h2 {
        font-size: 2.25rem;
        letter-spacing: -1.52px
    }
}

h3 {
    font-family: var(--bold-font);
    font-weight: bold;
    font-size: 2.5rem;
    line-height: 1.075
}

.h3--lh-small {
    line-height: 0.925
}

@media (max-width:1199.98px) {
    h3 {
        font-size: 2rem
    }
}

@media (max-width:575.98px) {
    h3 {
        font-size: 1.625rem;
        line-height: 1.154
    }
}

h4 {
    font-family: var(--bold-font);
    font-weight: bold;
    font-size: 1.875rem;
    line-height: 1.33
}

@media (max-width:575.98px) {
    h4 {
        font-size: 1.5rem
    }
}

h5 {
    font-family: var(--bold-font);
    font-weight: bold;
    font-size: 1.25rem;
    line-height: 1.043;
    text-transform: uppercase
}

.display-1 {
    font-family: var(--bold-font);
    font-size: 5.976875rem;
    line-height: 0.8
}

@media (min-width:992px) and (max-width:1199.98px) {
    .display-1 {
        font-size: 4rem
    }
}

.display-2 {
    font-family: var(--italic-font);
    font-style: italic;
    font-size: 1.40875rem;
    color: var(--black);
    letter-spacing: 7.44px
}

.display-3 {
    font-family: var(--bold-font);
    font-size: 1.473125rem;
    letter-spacing: 11.87px;
    text-transform: uppercase;
    padding-left: 6px
}

@media (min-width:992px) and (max-width:1199.98px) {
    .display-3 {
        font-size: 1rem
    }
}

.large {
    font-size: 1.0625rem;
    line-height: 1.4117647059
}

.larger {
    font-size: 1.25rem;
    line-height: 1.6
}

@media (max-width:575.98px) {

    .larger,
    .large {
        font-size: 1.15rem;
        line-height: 1.45
    }
}

.text-orange {
    color: var(--orange) !important
}

.text-black {
    color: var(--black) !important
}

.text-gray {
    color: #949CA1 !important
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: none
}

.btn {
    color: var(--white);
    background-color: #333333;
    border-radius: 0px;
    width: auto;
    padding: .75rem 3.3125rem 11px 3.3125rem;
    line-height: 1.1;
    text-transform: uppercase;
    text-align: center;
    border: none;
    visibility: visible;
    display: inline-block
}

.btn svg {
    visibility: visible
}

.btn:hover {
    color: var(--white)
}

.btn--blue {
    background-color: #1877F2
}

.btn--sky {
    background-color: #1DA1F2
}

.btn--pink {
    background-color: #E1306C
}

.btn--link {
    font-size: 1.4375rem;
    background-color: transparent;
    color: var(--orange);
    letter-spacing: 0
}

.btn--orange {
    border: solid 2px black;
    /* padding-left: 1.25rem; */
    background-color: #c7e2c5;

    color: black;
    line-height: 1.3;
    position: relative;
    -webkit-transition: background-color 125ms ease-out, color 125ms ease-out, -webkit-box-shadow 125ms ease-out;
    transition: background-color 125ms ease-out, color 125ms ease-out, -webkit-box-shadow 125ms ease-out;
    -o-transition: background-color 125ms ease-out, box-shadow 125ms ease-out, color 125ms ease-out;
    transition: background-color 125ms ease-out, box-shadow 125ms ease-out, color 125ms ease-out;
    transition: background-color 125ms ease-out, box-shadow 125ms ease-out, color 125ms ease-out, -webkit-box-shadow 125ms ease-out
}

.btn--orange:active,
.btn--orange:hover {
    color: var(--white);
    text-decoration: none;
    background-color: #333333;
    -webkit-box-shadow: 0 0.0625rem 0.0625rem 0 rgba(0, 0, 0, 0.7);
    box-shadow: 0 0.0625rem 0.0625rem 0 rgba(0, 0, 0, 0.7)
}

.btn svg {
    margin-top: -3px
}

@media (min-width:767px) {
    .btn--ty {
        width: 75%;
        max-width: 330px;
        margin: 0 auto;
        display: block
    }
}

.bg-ser-white {
    width: 100%;
    background-repeat: no-repeat;
    -webkit-animation-duration: 4s;
    animation-duration: 4s;
    -webkit-animation-timing-function: cubic-bezier(0, 0.9, 0.58, 1);
    animation-timing-function: cubic-bezier(0, 0.9, 0.58, 1);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.bg-ser-white {
    height: 70px;
    background-image: url(../img/serrations-white.svg);
    -webkit-animation-name: bgMoveX;
    animation-name: bgMoveX
}

.bg-ser-white.reverse {
    background-image: url(../img/serrations-white-reverse.svg);
    -webkit-animation-name: bgMoveXReverse;
    animation-name: bgMoveXReverse;
    -webkit-transform: translateX(-30px);
    -ms-transform: translateX(-30px);
    transform: translateX(-30px)
}

.form-control {
    border-radius: 0px;
    border: 0px solid transparent;
    color: var(--black)
}

form label {
    color: var(--black);
    letter-spacing: 0.02px;
    font-size: 0.75rem;
    text-align: left
}

form .form-group {
    margin-bottom: 0.25rem
}

#pledge-now button {
    padding: .75rem 5.125rem 11px 4rem
}

.accordion-item {
    background-color: transparent
}

.accordian-button {
    font-size: 1.125rem
}

.accordian-button .closed {
    display: none
}

.accordian-button .open {
    display: inline
}

.accordian-button.collapsed .closed {
    display: inline
}

.accordian-button.collapsed .open {
    display: none
}

@media (min-width:768px) {
    .collapse.dont-collapse-sm {
        display: block;
        height: auto !important;
        visibility: visible
    }
}

.fade-in {
    -webkit-animation: fadein 0.8s forwards;
    animation: fadein 0.8s forwards
}

@-webkit-keyframes fadein {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes fadein {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@-webkit-keyframes bgMoveX {
    0% {
        background-position: 100px 50%;
        opacity: 0
    }

    to {
        background-position: 0px 50%;
        opacity: 1
    }
}

@keyframes bgMoveX {
    0% {
        background-position: 100px 50%;
        opacity: 0
    }

    to {
        background-position: 0px 50%;
        opacity: 1
    }
}

@-webkit-keyframes bgMoveXReverse {
    0% {
        background-position: -700px 50%;
        opacity: 0
    }

    to {
        background-position: -600px 50%;
        opacity: 1
    }
}

@keyframes bgMoveXReverse {
    0% {
        background-position: -700px 50%;
        opacity: 0
    }

    to {
        background-position: -600px 50%;
        opacity: 1
    }
}

.error-section {
    background: #efefef;
    color: black;
    visibility: hidden
}

.error-section.show {
    visibility: visible;
    font-weight: 400;
    line-height: 1.5;
    border: 3px;
    border-style: solid;
    border-color: #FF0000;
    padding: 1em
}

.grecaptcha-badge {
    visibility: hidden
}

.safety-kit-image-container {
    border: solid 2px #000;
    display: flex;
    justify-content: center;
    align-items: center;
}