@charset "UTF-8";
/* montserrat-600 - latin */
@font-face { font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */ font-family: 'BeetlecrabHeaderFont'; font-style: normal; font-weight: 600; src: url("/public/fonts/montserrat-v25-latin-600.eot"); /* IE9 Compat Modes */ src: url("/public/fonts/montserrat-v25-latin-600.eot?#iefix") format("embedded-opentype"), url("/public/fonts/montserrat-v25-latin-600.woff2") format("woff2"), url("/public/fonts/montserrat-v25-latin-600.woff") format("woff"), url("/public/fonts/montserrat-v25-latin-600.ttf") format("truetype"), url("/public/fonts/montserrat-v25-latin-600.svg#Montserrat") format("svg"); /* Legacy iOS */ }

.beetlecrab-header { font-family: "BeetlecrabHeaderFont", "Helvetica Neue", Arial, sans-serif; font-size: 16px; line-height: 1.5; width: 100vw; height: 64px; display: flex; flex-direction: row; justify-content: space-between; align-items: center; padding: 0 1.5em; background: #000; color: #fff; border-bottom: 1px solid #252525; }

.beetlecrab-header a.logo { color: #fff; }

.beetlecrab-header a.logo img { height: 1.25rem; }

.beetlecrab-header ul.menu { box-sizing: border-box; margin: 0; display: flex; justify-content: flex-end; gap: 1em; }

.beetlecrab-header ul.menu li { display: block; margin: 0; list-style: none; font-weight: bold; }

.beetlecrab-header ul.menu li a { color: #767676; text-decoration: none; }

.beetlecrab-header ul.menu li a:hover { color: #b7b7b7; }

.beetlecrab-header ul.menu li.active a { color: #fff; }

@media (max-width: 576px) { .beetlecrab-header { justify-content: center; } .beetlecrab-header ul.menu { display: none; } }

/* montserrat-regular - latin */
@font-face { font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */ font-family: 'Montserrat'; font-style: normal; font-weight: 400; src: url("/public/fonts/montserrat-v25-latin-regular.eot"); /* IE9 Compat Modes */ src: url("/public/fonts/montserrat-v25-latin-regular.eot?#iefix") format("embedded-opentype"), url("/public/fonts/montserrat-v25-latin-regular.woff2") format("woff2"), url("/public/fonts/montserrat-v25-latin-regular.woff") format("woff"), url("/public/fonts/montserrat-v25-latin-regular.ttf") format("truetype"), url("/public/fonts/montserrat-v25-latin-regular.svg#Montserrat") format("svg"); /* Legacy iOS */ }

/* montserrat-600 - latin */
@font-face { font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */ font-family: 'Montserrat'; font-style: normal; font-weight: 600; src: url("/public/fonts/montserrat-v25-latin-600.eot"); /* IE9 Compat Modes */ src: url("/public/fonts/montserrat-v25-latin-600.eot?#iefix") format("embedded-opentype"), url("/public/fonts/montserrat-v25-latin-600.woff2") format("woff2"), url("/public/fonts/montserrat-v25-latin-600.woff") format("woff"), url("/public/fonts/montserrat-v25-latin-600.ttf") format("truetype"), url("/public/fonts/montserrat-v25-latin-600.svg#Montserrat") format("svg"); /* Legacy iOS */ }

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

html, body { margin: 0; padding: 0; height: 100%; }

html { font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif; font-size: 16px; line-height: 1.5; }

@media (min-width: 1500px) { html { font-size: 18px; } }

body { color: #b7b7b7; background-color: #000; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

a { color: #08adc3; text-decoration: underline; }

a:hover, a:focus { text-decoration: underline; }

a strong { color: inherit; }

img { display: block; }

input[type="button"], input[type="submit"], button { -webkit-appearance: none !important; -moz-appearance: none !important; }

h1, h2, h3, h4, h5, h6 { margin-bottom: .5rem; font-weight: 600; line-height: 1.25; text-rendering: optimizeLegibility; color: #e8e8e8; }

body { background: #000; }

/* .page { padding: 0 2.5rem; margin-bottom: 2rem; @media (min-width: $landscape-tablet-breakpoint) { width: 50%; } h2 { margin-top: 2em; margin-bottom: 1em; text-align: center; } } */
.nobreak { white-space: nowrap; }

.bgvideo { background: none !important; overflow: hidden; }

.bgvideo video.background { object-fit: cover; width: 100%; /* For some reason this works better than 100vw in Chrome */ height: calc(100vh - 64px); position: absolute; top: 64px; left: 0; z-index: -1; }

.header { width: 50%; margin: 0 auto; margin-bottom: 2em; }

.header h1.logo { font-size: 4rem; font-weight: bold; text-align: center; text-transform: uppercase; margin: 0 auto; line-height: 0.75; }

.header h1.logo a { color: inherit; }

.header h1.logo a img { width: 100%; filter: drop-shadow(0px 0px 2px #000); }

.header h1.logo a:hover { text-decoration: none; }

.header .marquee { width: 100%; font-weight: normal; margin-top: 1em; }

@media (max-width: 576px) { .header { width: 85%; } .header h1 { font-size: 3rem; } }

main { max-width: 1920px; margin: 0 auto; }

main .section { background: #000; color: #fff; text-shadow: -1px -1px 2px #000, 1px -1px 2px #000, -1px 1px 2px #000, 1px 1px 2px #000; background-repeat: no-repeat; background-size: auto 100%; display: flex; align-items: center; /** Custom sections: **/ }

main .section .content { width: 50%; }

main .section .content p, main .section .content ul, main .section .content h3 { width: 75%; margin: 0 auto; }

main .section .content h3 { font-size: 1em; margin-bottom: 1em; font-weight: bolder; }

main .section .content p { margin-bottom: 1em; }

main .section .content ul { padding-left: 1em; }

main .section.section_split .left, main .section.section_split .right { width: 50%; flex: 1; display: flex; align-items: center; justify-content: center; }

@media (max-width: 1000px) { main .section.section_split { display: block; background-size: auto 50%; } main .section.section_split .left, main .section.section_split .right { min-height: 75vh; width: 100% !important; padding: 0 1em; } }

main .section.section_center .content { width: 100%; }

@media (max-width: 1000px) { main .section.section_center { margin-bottom: 4em !important; /* WTF why is this needed? */ } }

main .section.section_left { justify-content: left; background-position: right center; background-size: auto 100%; padding: 8em 0; }

@media (min-width: 576px) { main .section.section_left { aspect-ratio: 2 / 1; padding: 0; } }

main .section.section_right { justify-content: right; background-position: left center; background-size: auto 100%; padding: 8em 0; }

@media (min-width: 576px) { main .section.section_right { aspect-ratio: 2 / 1; padding: 0; } }

@media (max-width: 1500px) { main .section .content { padding: 0 1em; } main .section .content p, main .section .content ul, main .section .content h3 { width: 100%; } main .section.section_left .content { padding-left: 3em; } main .section.section_right .content { padding-right: 2em; } }

@media (max-width: 1000px) { main .section .content { width: 100%; padding: 0 4em !important; } main .section .content p, main .section .content ul, main .section .content h3 { width: auto; } }

@media (max-width: 576px) { main .section .content { width: 100%; padding: 0 1em !important; } }

main .section.section_header { height: calc(100vh - 64px); font-weight: bolder; justify-content: center; align-content: center; }

@supports (-webkit-touch-callout: none) { main .section.section_header { /* iOS only */ height: calc(-webkit-fill-available - 64px); } }

main .section.section_header .intro { text-align: center; }

main .section.section_header .preorder_info { text-align: center; margin-top: 2em; }

main .section.section_header .preorder_info p { margin-top: 1em; }

main .section.section_header .preorder_info .green { color: #47f959; }

main .section.section_purchase { font-weight: bolder; justify-content: center; align-content: center; }

@media (min-width: 1000px) { main .section.section_purchase { background-size: auto 85%; height: 100vh; } @supports (-webkit-touch-callout: none) { main .section.section_purchase { /* iOS only */ height: -webkit-fill-available; } } }

main .section.section_purchase .left, main .section.section_purchase .right { height: 100%; flex: none; flex-direction: column; width: 40%; }

main .section.section_purchase .left { margin: 0; }

main .section.section_purchase .left p { font-size: 1.2em; width: 75%; margin: 0 auto; margin-bottom: 1em; text-align: center; }

main .section.section_purchase .left p.intro { margin: 3em auto; }

main .section.section_purchase .right video { max-height: 70vh; }

main .section.section_purchase .preorder_info { text-align: center; /*display: flex; flex-direction: column; align-content: space-around; justify-content: center; gap: 2em;*/ }

main .section.section_purchase .preorder_info h4 { font-size: 2.5rem; margin-bottom: 2.5rem; margin-top: 0; }

main .section.section_purchase .preorder_info .price { margin-bottom: 2rem; }

main .section.section_purchase .preorder_info .cta { margin: 2rem auto; }

main .section.section_purchase p.preorder_details { font-size: 1rem; color: #e8e8e8; }

main .section.section_purchase p.preorder_deadline { font-size: 1rem; color: #07ff00; }

main .section.section_purchase .price .amount_info { color: #ccc; font-size: 1.9rem; font-weight: bolder; line-height: 1.0; font-style: italic; }

main .section.section_purchase .price .amount_info i { font-size: 75%; }

main .section.section_purchase .price .amount_info s { display: block; margin-bottom: 0.25em; font-size: 55%; }

main .section.section_purchase .price .amount_info s:first-child { font-size: 60%; }

main .section.section_purchase .price .amount_info { color: #fff; }

main .section.section_purchase .price .amount_info .description { display: block; font-size: 1rem; color: #ccc; margin: 0; margin-top: 1rem; margin-bottom: 0.5rem; }

main .section.section_purchase .price .amount_info .amount { display: block; margin: 0; }

main .section.section_purchase .price .amount_info { margin-top: 0.5em; margin-bottom: 0.5em; font-style: normal; }

main .section.section_purchase .price .amount_info i { font-style: normal; }

main .section.section_purchase .price_info { color: #b7b7b7; font-size: smaller !important; font-weight: normal; }

main .section.section_purchase .price_info a { color: #767676; text-decoration: underline dotted; }

@media (max-width: 576px) { main .section.section_purchase .left { min-height: 100vh; } @supports (-webkit-touch-callout: none) { main .section.section_purchase .left { /* iOS only */ height: -webkit-fill-available; } } main .section.section_purchase .left p { width: 100%; padding: 0 1em; } main .section.section_purchase .left p.intro { margin: 1em auto !important; } }

@media (max-width: 1000px) { main .section.section_purchase { display: flex; flex-direction: column-reverse; } main .section.section_purchase .right { height: auto; padding: 0; margin: 0; } main .section.section_purchase .right video { max-width: 75%; } }

@media (max-width: 1500px) { main .section.section_purchase .left, main .section.section_purchase .right { width: 50%; } }

main .section.section_drawing { background-image: url(/public/images/splash_drawing.jpg), url(/public/images/splash_small.jpg); background-position: right top, left 75% bottom; background-size: 50% auto, auto 8em; min-height: 200%; align-items: end; padding-bottom: 10em; }

main .section.section_drawing .drawing { margin-top: 40%; overflow-x: auto; height: 720pt; width: 100%; }

main .section.section_drawing .drawing div.image { height: 100%; aspect-ratio: 6000 / 3750; background: url(/public/images/tempera_drawing.png) no-repeat; background-size: auto 100%; background-position: center; margin: 0 auto; }

main .section.section_drawing .drawing div.image.swipe { background-image: url(/public/images/swipe.png), url(/public/images/tempera_drawing.png); background-size: 12.5% auto, auto 100%; background-position: center bottom 25%, center; }

@media (max-width: 1500px) { main .section.section_drawing .drawing { height: 650pt; } }

@media (max-width: 1000px) { main .section.section_drawing { min-height: 100%; background-size: 75% auto, auto 8em; } main .section.section_drawing .drawing { margin-top: 60%; height: 580pt; } }

main .section.section_specs { background-image: url(/public/images/splash1.jpg); }

@media (max-width: 1000px) { main .section.section_specs { background-image: url(/public/images/splash1-left.jpg); } }

main .section.section_roadmap { background-image: url(/public/images/splash2.jpg); }

main .section.section_roadmap ul li::marker { color: #767676; }

main .section.section_roadmap ul li.hidden { list-style: none; }

main .section.section_roadmap ul li.finished::marker { color: #47f959; }

main .section.section_roadmap ul li.current::marker { color: #fff; filter: none; -webkit-animation: fade-in 1s infinite alternate; animation: fade-in 1s infinite alternate; }

@-webkit-keyframes fade-in { 0% { color: #767676; }
  100% { color: #fff; } }

@keyframes fade-in { 0% { color: #767676; }
  100% { color: #fff; } }

@media (max-width: 1000px) { main .section.section_roadmap { background-image: url(/public/images/splash2-right.jpg); } }

main .section.section_demos { min-height: 33vh; padding: 3em 0; font-size: 1.2em; }

main .section.section_demos .content { text-align: center; display: flex; flex-flow: row wrap; }

main .section.section_demos .content .item { width: 50%; padding: 2em; padding-top: 2em; }

main .section.section_demos .content .item h4 { margin-top: 2em; }

@media (max-width: 1000px) { main .section.section_demos .content .item { padding: 0; width: 100%; } }

main .section.section_demos .content .manual_links { padding-top: 2em; width: 100%; }

main .section.section_demos .content .manual_links p { margin-top: 2em; margin-bottom: 2em; }

@media (min-width: 2000px) { main .section.section_demos .content .manual_links { font-size: 1.4em; } }

main .section.section_testimonials { background: none; display: block; margin: 0 auto; }

main .section.section_testimonials .content { width: 75%; display: flex; flex-flow: row wrap; align-items: top; justify-content: center; margin: 0 auto; gap: 4em 0; margin-top: 6em; }

main .section.section_testimonials .testimonial { width: 33%; text-align: center; }

main .section.section_testimonials .testimonial img { display: inline-block; height: 5em; }

main .section.section_testimonials .testimonial .stars { user-select: none; padding: 0; height: 2.75em; }

main .section.section_testimonials .testimonial .stars i { font-size: 1.25em; margin-left: 0.25em; color: #22e0ff; -webkit-filter: drop-shadow(0 0 10px #948fb9); filter: drop-shadow(0 0 10px #948fb9); }

main .section.section_testimonials .testimonial .stars i:first-child { margin-left: 0; }

main .section.section_testimonials .testimonial blockquote { font-style: italic; margin-top: 2.75em; }

main .section.section_testimonials .testimonial blockquote.below-stars { margin-top: 0 !important; }

main .section.section_testimonials .testimonial blockquote:before { content: '“'; }

main .section.section_testimonials .testimonial blockquote:after { content: '”'; }

@media (max-width: 1000px) { main .section.section_testimonials .splash { width: 100%; } main .section.section_testimonials .content { width: 100%; gap: 1em 0; } main .section.section_testimonials .testimonial { width: 50%; } }

@media (max-width: 576px) { main .section.section_testimonials .content { gap: 0; } main .section.section_testimonials .testimonial { width: 100%; border-bottom: 4px solid #252525; padding: 0.25em 0; } main .section.section_testimonials .testimonial:last-child { border: none; } main .section.section_testimonials .testimonial blockquote { margin-top: 0; } }

main .section.section_gallery { margin: 10em 0 5em 0; }

main .section.section_gallery .content { width: 75%; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 1em; }

main .section.section_gallery .content a { display: block; width: 33%; aspect-ratio: 1920 / 280; }

main .section.section_gallery .content img { width: 100%; }

@media (max-width: 1000px) { main .section.section_gallery { min-height: auto; margin: 6em 0 !important; } main .section.section_gallery .content { width: 100%; gap: 0.5em; } }

main .section.section_signup { margin: 10em 0 !important; }

main .section.section_signup .content { text-align: center; width: 40%; margin: 0 auto; }

main .section.section_signup .content form { display: flex; gap: 0.75em; }

main .section.section_signup .content form input { margin: 0; }

main .section.section_signup .content form input[type="email"] { width: 67%; }

main .section.section_signup .content form input[type="submit"] { width: 33%; }

@media (max-width: 1500px) { main .section.section_signup .content { width: 60%; } }

@media (max-width: 1000px) { main .section.section_signup { margin: 4em 0 !important; } main .section.section_signup .content { width: 75%; } }

@media (max-width: 576px) { main .section.section_signup { margin: 0 !important; } main .section.section_signup .content { width: 100%; } main .section.section_signup form { flex-direction: column; } main .section.section_signup form input { width: 100% !important; } }

main .section.section_about { background-image: url(/public/images/splash_footer.jpg); }

main .section.section_about .cta_wrap { margin-top: 2em; margin-bottom: 4em; }

@media (max-width: 1000px) { main .section.section_about { background-size: 100% auto; padding-bottom: 80%; background-position: left bottom; } main .section.section_about .cta_wrap { text-align: center; } }

/* From https://ryanmulligan.dev/blog/css-marquee */
.marquee { --gap: 1px; position: relative; max-width: 90vw; display: flex; overflow: hidden; user-select: none; gap: var(--gap); }

.marquee_content { flex-shrink: 0; display: flex; justify-content: space-around; min-width: 100%; gap: var(--gap); animation: scroll 10s linear infinite; }

.marquee_content { padding: 0; margin: 0; list-style: none; }

@keyframes scroll { from { transform: translateX(0); }
  to { transform: translateX(calc(-100% - var(--gap))); } }

footer { /* Transparent background effect */ position: relative; width: 100%; height: 8em; margin-top: -8em; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; background: rgba(0, 0, 0, 0.75); }

footer { /* Copy from Vector */ color: #ddd; background: rgba(0, 0, 0, 0.75); padding-top: 6rem; text-align: center; font-size: 95%; }

footer a { text-decoration: none; }

footer p, footer a { font-weight: bold; }

footer p:first-child { color: #fff; margin-bottom: 3rem; }

footer p:not(:first-child) { font-size: 85%; color: #767676; }

footer p:not(:first-child) a { color: #aaa; }

form input, form button, form select, form textarea { color: #e8e8e8; font-size: 1em; height: 2.5em; border-radius: 2px; font-weight: normal; padding: 0 0.75em; margin: 0; }

form input[type="text"], form input[type="email"], form select, form textarea { background: #252525; border: 2px solid #767676; }

form input[type="text"]::placeholder, form input[type="email"]::placeholder, form select::placeholder, form textarea::placeholder { color: #767676; opacity: 1; }

form textarea { height: auto; padding: 0.75em; }

form input[type="checkbox"] { height: 1em; }

form input[type="submit"], form button { background: #252525; color: #e8e8e8; border: 1px solid #e8e8e8; cursor: pointer; }

form input[type="submit"]:hover, form button:hover { background: #e8e8e8; border-color: #252525; color: #252525; }

a.cta { text-shadow: none; background-color: rgba(0, 0, 0, 0.75); color: #07ff00; border: 2px solid #fff; display: inline-block; width: auto; font-weight: bold; padding: 1em 2em; text-decoration: none; }

a.cta i { font-size: 125%; margin-left: 0.4rem; }

a.cta:hover { background: #fff; color: #000; }

a.manual { color: #fff; text-decoration: none; font-weight: bold; margin: 2em 0; }

a.manual:hover { color: #08adc3; }

a.rewind { margin-top: 2em; font-size: smaller; display: block; color: #b7b7b7; visibility: hidden; font-weight: normal; }

a.rewind:hover { color: #e8e8e8; text-decoration: none; }

a.rewind:focus { text-decoration: none; }

/* Hack to maintain aspect ratio from https://stackoverflow.com/a/54924505 */
.youtube_container { max-width: 1920px; aspect-ratio: 16 / 9; box-sizing: border-box; border-radius: 7px; border: 7px solid #000; background: #000; margin: 0 auto; position: relative; /* So that iframe can be absolute */ }

.youtube_container iframe, .youtube_container video { position: absolute; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; }

.social { margin-top: 8em; text-align: center; }

.social a { text-decoration: none; color: #fff; font-size: 2.75em; margin-right: 10px; }

.social a:hover { color: #08adc3; }

.social a.discord { display: block; margin-bottom: 1em; margin-top: 0; }

.social a.discord img { height: 1.2em; width: auto; margin: 0 auto; }

.social a.discord:hover img { filter: invert(60%) sepia(98%) saturate(1065%) hue-rotate(156deg) brightness(91%) contrast(88%); }

.shopping_cart { position: fixed; top: calc(64px + 0.5em); right: 0; font-size: 75%; }

.shopping_cart a { text-decoration: none; }

.shopping_cart i { color: #000; }

.shopping_cart i.fa-inverse { color: #07ff00; }

.shopping_cart .count { color: #fff; position: relative; bottom: -1em; right: 1.25em; font-weight: bolder; }

/*# sourceMappingURL=homepage.css.map */