:root {
    --lightGray: #EEEEEE;
    --black: #000000;
    --primary: #FF3131;
    --gray: #D9D9D9;
    --size: 6rem;
    --transition-duration: 500ms;
    --transition-easing: ease-out;
}

.grecaptcha-badge{z-index: 10000;}

/* --- Global --- */
html,body { padding: 0; margin: 0; font-family: 'Inter', sans-serif; font-style: normal; font-weight: 400; font-size: 16px; scroll-behavior: smooth; line-height: 1.3em;}
.contentContainer { max-width: 1600px; margin: 0 auto; }
.scrollSnap { overflow: scroll; height: 100vh; scroll-snap-type: y mandatory; scroll-behavior: smooth; }
/*.service { scroll-snap-align: center; }*/
h1,.h1, h2, .h2 { font-family: 'Exo 2',sans-serif; font-style: italic; font-weight: bold; line-height: 1em; }
h1,.h1 { font-size: 40px; }
h2,.h2 { font-size: 32px; }
h3,.h3 { font-size: 24px; }
span[onclick] {color: #004986;font-weight: bold;}
span[onclick]:hover {cursor: pointer; text-decoration: underline;}
section { max-width: 1600px; padding: 0 30px; box-sizing: border-box; margin: 0 auto; }
.fullBgImg { background-size: cover; background-position: bottom; background-color: var(--black); background-image: url("../img/hero-parking-enforce-car-2000.jpg"); position: fixed; color: #000; z-index: 1; width: 100%; max-width: unset; height: 70vh; max-height: 800px; }
.heading { justify-content: center; flex-direction: column; align-items: center; }
.subHead { color: #000000; font-family: 'Roboto', sans-serif; font-size: 48px; font-style: normal; font-weight: 700; line-height: 56px; }
hr { border: 0; height: 0; background: #333; background-image: linear-gradient(to right, #ccc, #333, #ccc); margin: 100px 0; }

/* --- Buttons --- */
button, .btn { width: fit-content; background-color: var(--primary); color: #ffffff; font-weight: 600; font-size: 16px; display: inline-block; border-radius: 5px; padding: 15px 20px; border: none; margin: 0 10px 10px 0; text-transform: none; text-decoration: none; line-height: 18px;}
button:hover, .btn:hover { opacity: 0.8; cursor: pointer; }
button.secondary { background-color: var(--gray); color: #000000; }
button a { text-decoration: none; color: #000; }

/* --- Nav --- */
.navBar { position: fixed; top: 0; width: 100%; overflow: hidden; padding: 10px 0 0; box-sizing: border-box; margin: 0; z-index: 2; background-color: rgba(0, 0, 0, 1); }
.navBar .contentContainer { position: relative; }
.navBar .logo { /*overflow: hidden;*/ /*height: 50px;*/ box-sizing: border-box; display: flex; align-items: center; padding-left: 20px; font-size: 25px; color: #ffffff; }
.navBar .logo img { height: 45px; width: auto; }
.navBar .logo img:hover { cursor: pointer; }
.navBar .navBurger { color: #ffffff; position: absolute; top: 5px; right: 0; font-size: 1em; line-height: 1em; padding-right: 20px; }
#homeNavTop .navBar .navBurger { color: #ffffff; }
.navBar .navLinks { padding: 0; width: 100%; margin-top: 10px; max-height: 0; transition: max-height 600ms; overflow: hidden; }
.home .navBar .navLinks.active { display: none; }
#homeNavTop.showNav .navBar .navLinks.active,
#homeNavScroll.showNav .navBar .navLinks.active,
.navBar .navLinks.active
{ display: block; max-height: 375px; background-color: var(--primary); }
.navBar .navLinks .linkObj { text-align: right; color: #ffffff; text-decoration: none; padding: 15px 20px; line-height: normal; display: block; font-size: 16px; }
.navBar .navLinks .linkObj:hover { border-bottom: 3px solid var(--primary); }

.homeNav { z-index: 3; position: relative; }
.homeNav .navBar { top: -70px; }
.homeNav.showNav .navBar { /*height: 70px;*/ top: 0; transition: top 300ms cubic-bezier(0.17, 0.04, 0.03, 0.94); overflow: hidden; box-sizing: border-box; }
#homeNavTop.showNav .navBar { height: 70px; background-color: transparent; overflow: visible; }
#homeNavTop.showNav .navBar .logo { display: none; position: absolute; }
#homeNavTop.showNav .navBar .navLinks { width: 100%; justify-content: center; position: absolute; /*top: 50px;*/ top: 5vh; }
#homeNavTop.showNav .navBar .navLinks .linkObj { color: #ffffff; }
#homeNavTop.showNav .navBar .navLinks.active .linkObj { color: #000000; }
#homeNavTop .navBar.solidBg { background-color: var(--black); }
#homeNavScroll .navBar.solidBg { background-color: #ffffff; }

/* --- Home --- */
/*#homeImg { background-position: bottom; background-color: var(--black); color: #000; }*/
/*#homeImg { background-image: url("../img/parking-enforce-car-2000.jpg"); background-size: cover; background-position: bottom; background-color: transparent; position: absolute; color: #000; z-index: 1; !* height: auto; max-height: 800px; min-height: 650px; }*!*/
#homeHeading { position: relative; color: #000; margin-bottom: 0; z-index: 2; }
.homeHeadingWrapper { box-sizing: border-box; position: relative; color: #ffffff; display: flex; justify-content: center; flex-direction: column; align-items: flex-start; height: 70vh; }
.num-divider {text-align: center;position: relative;}
.num-divider:before {content:'';background-color: #ff3131; display: inline-block; width: 30vw; min-width: 200px; max-width: 400px; height: 1px; position: absolute; left: 0; right: 0; top: 50%; margin: 0 auto; }
.num-divider span {padding: 0 10px;background-color: #ffffff; position: relative;}
.img-placeholder { width: auto; text-align: center; }
.img-placeholder > img { width: 100%; box-shadow: 2px 4px 7px 0px rgba(0, 0, 0, 0.25); }
/*.videoWrapper{width: 100%; display: flex; justify-content: center; align-items: center; padding: 20px 0 0;}*/
.videoWrapper > video{width: clamp(400px, 100%, 800px);}
#home-content-wrapper { position: relative; z-index: 2; background: #ffffff; }

#our-process { padding-top: 50px; }
#our-process h2, #ticket-design h2, #ticket-design > p { text-align: center; }
.how-section {margin: 80px 0;}
.how-section > div {display: flex; flex-direction: column; align-items: center;}
.how-section > div > div { flex-basis: 50%; margin: 0 0 15px; box-sizing: border-box; }
.how-section > div > div > p { max-width: 600px; }

.design-opts { display: flex; flex-direction: column; }
.design-opts > div { margin: 15px 0; }
.design-opts .img-placeholder > img { width: 100%; max-width: 400px; height: auto; max-height: 600px; }

#ticket-reorder { margin: 80px auto; }
#ticket-reorder > div { display: flex; flex-direction: column-reverse; align-items: center; }
#ticket-reorder > div > div { flex-basis: 40%; margin: 15px 0; box-sizing: border-box; }
#ticket-reorder > div > div:nth-of-type(2) { flex-basis: 60%; }
#ticket-reorder > div > div > p { max-width: 600px; }

#features { background-color: #EEF2F4; width: 100%; padding-top: 30px; margin-top: 50px; box-sizing: border-box; }
#features section { position: relative; height: 650px; max-width: fit-content; z-index: 2; }
#features img#canister { width: 100%; max-width: 450px; position: absolute; bottom: 0; left: 0; right: 0; margin: 0 auto; z-index: 1; }
#home-feature-list { max-width: fit-content; margin: 0 auto; position: relative; }
.home-feature-item { display: flex; margin: 20px 0; align-items: center; }
.home-feature-item .feature-icon { font-size: 2em; min-width: 50px; text-align: center; }
#feature-no-printer > .feature-icon { outline: 1px solid black; background: linear-gradient(to top left, rgba(0,0,0,0) 0%, rgba(0,0,0,0) calc(50% - 1px), rgba(0,0,0,1) 50%, rgba(0,0,0,0) calc(50% + 1px), rgba(0,0,0,0) 100%); }
.home-feature-item > p { margin: 0 0 0 20px; }

/* --- Footer --- */
.footer-stripes { height: 25px; width: 100%; background: repeating-linear-gradient(  -45deg,  #ff3131,  #ff3131 20px,  #000000 20px,  #000000 40px); position: relative; z-index: 2; }
#footer { background-color: #000000; color: #ffffff; padding: 30px; display: flex; position: relative; z-index: 2; flex-wrap: wrap; gap: 20px; }
#footer h2 { margin: 0; }
#footer .footerCopyright { font-size: 0.75em; }
#footer a { color: #ffffff; text-decoration: none; }
#footer .footerLinks { display: flex; flex-wrap: wrap; }
#footer .footerLinks a { display: block; margin: 5px; width: fit-content; flex: 1 0 200px; }
#footer .footerLinks a:hover { text-decoration: underline; }


/* --- Media Queries Start --- */

@media (min-width: 768px) {
    html,body { font-size: 18px;}
    h1,.h1 { font-size: 50px; }
    h2,.h2 { font-size: 36px; }
    .how-section > div { flex-direction: row-reverse; }
    .how-section > div > div { margin: 30px; }

    .design-opts > div { margin: 30px auto; max-width: 600px; }
    #ticket-reorder > div { flex-direction: row; }
    #ticket-reorder > div > div { margin: 30px; }

    #home-feature-list { padding-left: 450px; }
    #features img#canister { max-width: 800px; }

    #footer { flex-wrap: nowrap; }
    #footer > div { flex: 1 0 33%; }
}

@media (min-width: 992px) {
    .navBar .navLinks.active { background-color: unset; }
    .navBar .navLinks .linkObj { text-align: center; padding: 10px 20px; }
    .navBar { padding-bottom: 10px; }
    .navBar .contentContainer { display: flex; box-sizing: border-box; justify-content: space-between; align-items: center; }
    .navBar .navBurger { display: none; }
    .navBar .navLinks, .navBar .navLinks.active { display: flex; justify-content: flex-end; align-items: center; overflow: hidden; height: 50px; box-sizing: border-box; width: 75%; margin: 0; max-height: unset; }
    .navBar .navLinks .linkObj { box-sizing: border-box; border-bottom: 3px solid #ffffff00; }

    .design-opts { flex-direction: row; justify-content: center; }
    .design-opts > div { margin: 30px; width: 50%; }
}

@media (min-width: 1200px) {

}

@media (min-width: 1600px) {
    .navBar { padding: 10px 100px; }
    .navBar .navLinks { width: 70%; }
}

@media (min-width: 2000px) {

}