@font-face {
    font-family: 'loraregular';
    src:	local('loraregular') ,
            url('fonts/lora-variablefont_wght-webfont.woff2') format('woff2'),
            local('lora-variablefont_wght-webfont.woff') ,
            url('fonts/lora-variablefont_wght-webfont.woff') format('woff');

    font-style: normal;
    font-display: swap;
}

html {
	font-family: 'loraregular';
	line-height: 1.05;
}

body {
  	background-image: linear-gradient(to bottom left, #496AE3, #FFE59E);
	color: #616D7E;
	font-size: 105%;
	overflow-wrap: break-word;
	word-wrap: break-word;
	text-underline-offset: .2rem;
	padding-top: env(safe-area-inset-top);
	padding-bottom: env(safe-area-inset-bottom);
	padding-left: env(safe-area-inset-left);
	padding-right: env(safe-area-inset-right);
}

header,
.LeftFootBadge,
.AppBar {
	padding-top: env(safe-area-inset-top);
	padding-bottom: env(safe-area-inset-bottom);
}

a {
  	color: #616D7E;
}

a:hover {
	color: black;
}

::placeholder {
	color: #616D7E;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:autofill:focus,
input:-webkit-autofill:focus,
input:autofill:active,
input:-webkit-autofill:active,
input:autofill {
    transition-delay: 99999999s;
    transition-property: background-color, color;
    -webkit-text-fill-color: inherit !important;
    background-color: transparent !important;
}

.Recycler {
    contain: paint;
}

.LogoWrap,
.DrillPocket,
#DeepDrill,
.ExpandPlate,
.SocketLinkHole,
.ShaftHole,
.SubmitWrapper {
    contain: layout;
}

.Shoot,
.Shot,
.LogoWrap::after,
.DrillPocket::after,
.RollPocket::after,
#DeepDrill,
#DeepPocket,
#DrillPocket,
#RollPocket,
.FrameIn {
    will-change: transform, opacity;
}

.WillChangeTransform {
	will-change: transform;
}

.WillChangeOpacity {
	will-change: opacity;
}

.Black {
	color: black;
}

.Italic {
	font-style: italic;
}

.NoUnderlineOffset {
	text-underline-offset: .05rem;
}

.Centered {
    align-items: center;
	justify-content: center;
	text-align: center;
}

.TopBar {
	width: 100%;
	height: 28px;
	background-color: #FFC038;
	position: absolute;
	z-index: 1;
	box-shadow: 0px 0px 3px 2px #FFFFFF;
}

.Logo,
.TopCorners,
.LogoWrap::before,
.LogoWrap::after {
    border-top-right-radius: 25px;
    border-top-left-radius: 25px;
}

.Logo {
	height: 155px;
}

.LogoWrap {
    position: relative;
	overflow: hidden;
}

.LogoWrap::before {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    width: 100%;
	height: 133px;
}

.LogoWrap::after {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    background: linear-gradient(to bottom right, #FFE59E 0%, transparent 33%);
	opacity: 0;
    width: 100%;
	height: 133px;
    animation: wetTip 333ms 1233ms forwards;
}

.StandardWidth {
	width: 426px; /*426*/
}

.InnerWidth {
	width: 264px;
}

.StandardWrapper {
	display: block;
	clear: both;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 2;
}

.WetPocket {
	background-color: white;
	box-shadow: 2px 0px 4px 0px #FFE59E;
	position: relative;
	top: 7px;
	border: 1px solid #FFE59E;
}

.SegmentOut {
	padding-top: 37px;
	padding-bottom: 37px;
}

.FrameOut {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	background-color: white;
	border-radius: 5px;
}

.DrillPocket,
.RollPocket {
    -webkit-text-stroke: 1px;
	font-weight: 900;
	overflow-wrap: normal;
	word-wrap: normal;
}

.DrillPocket {
	font-size: 170%;
	height: 100px;
	letter-spacing: 3px;
	color: #FFC038;
	padding-left: 37px;
	padding-top: 7px;
    position: relative;
    animation: fadeIn 500ms ease-in-out;
}

.DrillPocket::after {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    background: linear-gradient(to top right, #697DC3 0%, transparent 23%), linear-gradient(to top left, #697DC3 0%, transparent 23%);
    opacity: 0;
    animation: wetUp 333ms 1233ms forwards;
}

.Row {
	clear: both;
	line-height: 1;
}

.Slot {
	width: 70px;
	padding-top: 5px;
	font-size: 75%;
	text-align: right;
	padding-right: 12px;
	float: left;
	color: #496AE3;
}

.Center {
	width: 230px;
	font-weight: 500;
	float: left;
}

.Ring {
	width: 35px;
	letter-spacing: 2px;
	font-weight: 500;
	color: #496AE3;
	float: left;
}

.Blue {
	color: #496AE3;
	letter-spacing: 2px;
}

.Crunch {
	position: relative;
	top: 7px;
	font-size: 60%;
}

.Heavy {
	font-weight: 900;
}

.Huge {
	position: relative;
	top: -7px;
	font-size: 137%;
}

.Hugest {
	position: relative;
	top: -11px;
	font-size: 147%;
	right: -3px;
}

.Tight {
	font-size: 90%;
	letter-spacing: 1.33px;
}

.Tightest {
	font-weight: normal;
}

.RollPocket {
	font-size: 112%;
	height: 60px;
	clear: both;
	padding-top: 22px;
	line-height: 1.4;
	text-align: center;
	letter-spacing: .7px;
	color: #496AE3;
    position: relative;
    animation: fadeIn 500ms ease-in-out;
}

.RollPocket::after {
    content: "";
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    background: linear-gradient(to bottom right, #697DC3 0%, transparent 23%), linear-gradient(to bottom left, #697DC3 0%, transparent 23%);
    opacity: 0;
    animation: wetDown 333ms 1233ms forwards;
}

@keyframes fadeIn {
    0% {opacity: 0;}
    100% {opacity: 1;}
}

@keyframes wetTip {
    0% {opacity: 0;}
    100% {opacity: 1;}
}

@keyframes wetUp {
    0% {opacity: 0;}
    100% {opacity: 1;}
}

@keyframes wetDown {
    0% {opacity: 0;}
    100% {opacity: 1;}
}

.Shoot {
    animation-name: fadeIn;
    animation-fill-mode: forwards;
    opacity: 0;
    animation-duration: 200ms;
    animation-delay: 0ms;
}

.Shot {
    animation-name: fadeIn;
	animation-fill-mode: forwards;
    opacity: 0.37;
    animation-duration: 333ms;
    animation-delay: 1233ms;
}

.FrameTop {
	margin-top: 80px;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	box-shadow: 0 2px 4px #496AE3, 0 8px 16px #496AE3;
	background-color: #496AE3;
	border-radius: 5px;
}

.Halo {
	box-shadow: 0 2px 4px #FFE59E, 0 8px 16px #FFE59E;
}

.BlueHalo {
	box-shadow: 0 2px 4px #A3ADFA, 0 8px 16px #A3ADFA;	
}

.Gold {
	background-color: #FFC038;
}

.TopHalf {
	padding: 10px;
	height: 88px;
	border-top-right-radius: 5px;
	border-top-left-radius: 5px;
	background-color: white;
	font-size: 28.56px;
	letter-spacing: 2px;
	font-weight: 900;
	color: black;
	display: flex;
    align-items: center;
  	background-image: linear-gradient(to top right, #FFFFFF 90%, #496AE3 100%);
}

.TopHalfOptional {
	color: #616D7E;
	height: 54px;
}

.TopGold {
  	background-image: linear-gradient(to top right, #FFFFFF 90%, #FFE59E 100%);
}

.SlideFast {
	height: 100%;
	width: 20%;
	float: left;
	display: flex;
    align-items: center;
}

.SlideHard {
	width: 65%;
	text-align: center;
}

.Icon {
	max-height: 67%;
	opacity: .8;
}

.IconLight {
	opacity: .53;
}

.Interconnector {
	min-height: 27px;
	background-color: #F5F5F5;
	text-align: right;
}

.Expand {
	padding-left: 7px;
	padding-right: 7px;
	float: right;
}

.ExpandLead {
	position: relative;
	top: 4px;
}

.ExpandButton {
    width: 100%;
	float: right;
	padding-top: 2px;
}

.ExpandButton:hover {
	cursor: pointer;
}

.CircleSlide,
.CircleSlide3,
.CircleSlideArch {
    transition: transform 800ms ease;
}

.ExpandPlate {
	background-color: white;
	width: 100%;
	display: none;
	padding-top: 10px;
	padding-bottom: 10px;
}

.FilterTitle {
	transition: color 800ms ease;
}

.ListPacket {
	margin-bottom: 14px;
	padding-left: 10px;
}

.ListTitle {
	color: #496AE3;
	width: 100%;
	font-weight: 700;
	text-align: left;
	letter-spacing: 1px;
	padding-bottom: 3px;
}

.ItemPacket {
	padding-left: 12px;
}

.ListItem {
	color: #496AE3;
	letter-spacing: 1px;
}

.LineSub {
	font-weight: 300;
	padding-left: 15px;
}

.ListHug {
	color: #616D7E;
	margin-right: 2px;
	letter-spacing: normal;
	font-weight: normal;
}

.Links {
    display: grid;
    place-items: center;
	padding-top: 55px;
	padding-bottom: 55px;
}

.Tip {
	padding-top: 55px;
	padding-bottom: 27px;
}

.Cursor {
  	cursor: pointer;
}

.Field {
	-webkit-appearance: none;
	-moz-appearance: none;
	color: black;
	padding-top: 2px;
	padding-left: 7px;
	padding-right: 7px;
	margin-left: auto;
	margin-right: auto;
	font-size: 16px;
	height: 34px;
	border-radius: 7px;
	border: 1px solid #F5F5F5;
  	background-color: #FFFCF5;
	box-sizing: border-box;
}

.InputField {
	line-height: 3;
}

.RateField {
	background-color: #F5F5F5;
	border-bottom-left-radius: 0px;
	border-bottom-right-radius: 0px;
	border-bottom: 1px #FFC038 solid;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	padding-top: 2px;
	display: flex;
	align-items: center;
	cursor: pointer;
	line-height: 3;
}

.RateField:hover {
	font-weight: bold;
}

.InvalidField {
	border: 1.35px solid red;
}

.FilterField {
  	background-color: #FFFFFF;
	border: 1px solid #FFC038;
	padding-top: 3px;
}

.FilterField:hover {
	cursor: pointer;
}

.ErrorMsg {
    position: relative;
    z-index: 3;
	top: -6px;
	padding-top: 2px;
	border-bottom-right-radius: 7px;
	border-bottom-left-radius: 7px;
    min-height: 28px;
	background-color: red;
	color: white;
	font-size: 84%;
	opacity: 0;
    display: flex;
	pointer-events: none;
}

.ErrorMsgExpand {
	min-height: 28px;
	align-items: center;
}

.ExpandErrorText {
	font-size: 75%;	
}

.Field:focus {
	outline: 0;
}

.TextField:hover {
	cursor: text;
}

.SocketLinks {
	min-height: 200px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	color: #4E5765;
	padding-bottom: 39px;
}

.SoftHaul {
	font-size: 22px;
	font-weight: 700;
	text-align: left;
	letter-spacing: .6px;
	padding-bottom: 12px;
}

.SoftOpacity {
	opacity: .91;
}

.SoftTitle {
	text-align: center;
}

.SocketLinkHole {
	border-radius: 7px;
}

.HoleTop {
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 7px;
	text-align: left;
}

.LoveNextTop {
	top: 5px;
}

.HateNextTop {
	top: 7px;
}

.IndifferentNextTop {
	top: 6px;
}

.CheckNextIcon {
	position: relative;
	left: -7px;
	padding-right: 2px;
}

.Box24 {
	height: 24px;
	width: 24px;
	opacity: .47;
}

.Box20 {
	margin-left: 3px;
	margin-bottom: -4px;
	height: 20px;
	width: 20px;
}

.Helphover:hover {
	cursor: pointer;
}

.HelpBox {
	position: absolute;
	margin-left: 55px;
	width: 233px;
	margin-top: -65px;
	min-height: 45px;
  	background-color: #F5F5F5;
	border: 1px solid #FFC038;
	z-index: 3;
	border-radius: 7px;
	padding: 10px;
	font-size: 11px;
	text-align: left;
}

.Box48 {
	height: 48px;
	width: 48px;
	opacity: .47;
}

.BoxMarginLeft {
	margin-left: 42px;
}

.Rectangle48 {
	height: 48px;
	padding-right: 14px;
	padding-left: 14px;
	margin-left: auto;
	margin-right: auto;
}

.ShaftHole {
	background-color: white;
	padding-bottom: 10px;
	border-radius: 7px;
}

.ShaftHoleTop {
	margin-top: 48px;
}

.LinkLink {
	text-decoration: none;
}

.Selected {
	opacity: 1;
}


.FilterWrapper {
	margin-left: auto;
	margin-right: auto;
	padding-bottom: 15px;
}

.FilterWidth {
	width: 183px;
}

.OffWhiteGold {
	background-color: #FFFFFA;
}

.FilterTitle {
	font-size: 24px;
}

.InputTitle {
	padding-top: 12px;
	padding-bottom: 12px;
	font-size: 115%;
	font-weight: 600;
	clear: both;
}

.InactiveOpacity {
	opacity: .4;
}

.GrayOut {
  pointer-events: none;
  user-select: none;
}

.SubmitWrapper {
	text-align: center;
	margin-right: auto;
	margin-left: auto;
	padding-top: 40px;
	margin-top: 10px;	/* Will absorb margin added to Filter in event binder in AllPage.js so add 10 to space to add there */
}

.SubmitButton {
	-webkit-appearance: none;
	-moz-appearance: none;
	text-align: center;
	color: #FFC038;
	letter-spacing: 1px;
	background-color: #F5F5F5;
	border-radius: 7px;
	border: 3px solid #FFC038;
	box-shadow: 0 2px 4px #FFE59E, 0 8px 16px #FFE59E;
	padding-top: 25px;
	padding-bottom: 25px;
	width: 100%;
	font-size: 25px;
	font-weight: bold;
    transition: background-color 800ms ease,
                color 800ms ease,
				border 800ms ease;
}

.SubmitButton:focus {
	outline: 0;
}

.FlipButton {
	background-color: #496AE3;
	border: 3px solid #496AE3;
	box-shadow: 0 2px 4px #FFC038, 0 8px 16px #FFC038;
	color: white;
}

.FlipButton:hover {
	border: 3px solid #FFC038;
	cursor: pointer;
}

.FlipButton:active {
	border: 3px solid #FFC038;
}

.CkBoxContainer {
	margin-left: 3px;
	padding-left: 35px;
	display: block;
	position: relative;
	margin-bottom: 17px;
	pointer-events: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.CkBoxConfirm {
	display: block;
	text-align: left;
}

.Checkmark {
	margin-top: -5px;
	position: absolute;
	top: 0;
	left: 0;
	height: 22px;
	width: 22px;
	border: 2px solid #FFE59E;
}

.InvalidCheckmark {
	border: 2px solid red;	
}

/* When the checkbox is checked, add background */
.CkBoxContainer input:checked ~ .Checkmark {
	background-color: #496AE3;
	border: 2px solid #496AE3;
}

/* Create the checkmark/indicator (hidden when not checked) */
.Checkmark:after {
	content: "";
	position: relative;
	display: none;
}

/* Show the checkmark when checked */
.CkBoxContainer input:checked ~ .Checkmark:after {
	display: block;
}

/* Style the checkmark/indicator */
.CkBoxContainer .Checkmark:after {
	left: 7px;
	top: 4px;
	width: 5px;
	height: 10px;
	border: solid white;
	border-width: 0 3px 3px 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* Hide the browser's default checkbox */
.CkBoxContainer input {
	position: absolute;
	top: 18px;
	right: 361px;
	float: left;
	opacity: 0;
	cursor: pointer;
	height: 1px;
	width: 1px;
}

.Recycler {
	display: none;
	position: fixed;
	z-index: 4;
	left: 0;
	top: 0px;
	padding-bottom: 20px;
	width: 100%;
	height: 100%;
	min-height: 100dvh;
	background-color: rgba(73, 106, 227);
	background-color: rgba(73, 106, 227, .85);
}

.Spx {
    position: fixed;
    margin-top: -64px;
    margin-left: -64px;
    z-index: 4;
	left: 50%;
	top: 20%;
	animation: dance .2s infinite;
}

@keyframes dance {
  100% {
    transform: rotate(45deg);
  }
}

.SpxTxt {
	text-align: center;
	color: white;
	font-size: 120%;
	width: 400px;
	height: 700px;
	margin-left: -200px;
    z-index: 999;
    position: fixed;
	left: 50%;
	top: 36%;
	font-weight: bold;
}

.SpxWaitMsgs {
	display: none;
}

.LastWaitMsg {
  animation: blinker 1.5s linear infinite;
}

@keyframes blinker {
  50% {
    opacity: 0;
  }
}

.Foot {
    text-align: center;
	color: white;
	margin-top: 25px;
	font-size: 88%;
	background: transparent;
	line-height: 1.2;
}

.Foot a {
  	color: white;
}

.Foot a:hover {
  	color: #616D7E;
}

.LeftFootBadge {
	display: none;
	position: fixed;
  	border-radius: 3px;
	left: 0;
	margin-left: -2px;
	font-size: 95%;
	bottom: 6px;
	text-align: center;
	font-weight: bold;
	width: 118px;
	background-color: #FFE59E;
	filter: brightness(.95);
	opacity: .92;
	z-index: 2;
	will-change: bottom;
    backface-visibility: hidden;
	transform: translate3d(0, 0, 0);
}

.LeftFootBadgeBar {
	bottom: 48px;
}

.Alt {
	background-color: #FFE59E;
}

.ArchMiddle {
	text-align: left;
	padding-left: 10px;
	padding-right: 10px;
	background-color: white;
}

.BridePuff {
	padding-top: 22px;
	padding-bottom: 22px;
}

.Bold {
	font-weight: bold;
}

.SocialWrapper {
	width: 129px;
	height: 40px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 3px;
	opacity: .73;
}

.Sb {
	height: 40px;
	width: 40px;
}

.t {
	margin-left: 43px;
}

.Sb:hover {
    opacity: 1;
    cursor: pointer;
}

.SbBox {
	width: 33%;
	float: left;
	padding-bottom: 14px;
}

.CopyIcon {
	position: relative;
	height: 18px;
	padding-left: 13px;
	padding-right: 2px;
	float: left;
	top: -1px;
}

.CopyButtonText {
	float: right;
	padding-right: 13px;
	font-size: 93%;
}

.CopyButton {
	position: relative;
	width: 129px;
	height: 25px;
	margin-right: auto;
	margin-left: auto;
	border-radius: 7px;
	padding-top: 5px;
	margin-bottom: 15px;
	background-color: #496AE3;
	opacity: .73;
	color: white;
}

.CopyButtonHover:hover {
	cursor: pointer;
	opacity: 1;
}

.CopyButtonUnselect {
	width: 140px;
	background: #E8E8EE;
	color: black;
}

.CopyButtonUnselect:hover {
	cursor: default;
}

.grecaptcha-badge {
	visibility: hidden;
}

.AppBar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #496AE3;
    color: white;
	font-size: 20px;
    padding: 14px 20px;
    border: 3px solid #496AE3;
    box-shadow: 0 -4px 12px rgba(0,0,0,0.15);
    z-index: 2;
    box-sizing: border-box;
    height: 45px;
    backface-visibility: hidden;
	transform: translate3d(0, 0, 0);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    cursor: pointer;
    line-height: 1;
}

.AppBarIcon {
    width: 24px;
    height: 24px;
}

.AppBarFall {
    backface-visibility: hidden;
	transform: translate3d(0, 120%, 0);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.LeftFootBadgeFall {
    backface-visibility: hidden;
	transform: translate3d(0, 194%, 0);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.LeftFootBadgeBarFreeFall {
    bottom: 6px;
    transition: bottom 0s;
}

.AppBarRise {
    backface-visibility: hidden;
	transform: translate3d(0, 0, 0);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.LeftFootBadgeBarRise {
	bottom: 48px;
	transition: bottom 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.LeftFootBadgeRise {
    backface-visibility: hidden;
	transform: translate3d(0, 0, 0);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);	
}

.Hidden {
	display: none;
}

.HiddenByOpacity {
	opacity: 0;
}