/*
This CSS resource incorporates links to font software which is the valuable copyrighted property of Monotype and/or its suppliers. You may not attempt to copy, install, redistribute, convert, modify or reverse engineer this font software. Please contact Monotype with any questions regarding Web fonts: http://www.fonts.com
*/
	@font-face{
        font-family:"Univia";
        src:url("/payments/fonts/2999620/d891ecf2-1fa5-41b8-8ae0-206b7b891767.eot?#iefix");
        src:url("/payments/fonts/2999620/d891ecf2-1fa5-41b8-8ae0-206b7b891767.eot?#iefix") format("eot"),url("/payments/fonts/2999620/d7ce7ab2-eeee-4ceb-9ab7-4fdbf032a77c.woff2") format("woff2"),url("/payments/fonts/2999620/5e5ba327-9f76-4ffb-8a8f-b8ace207d65d.woff") format("woff"),url("/payments/fonts/2999620/3b74999f-07ba-4851-9a5d-eac7d1bf7c7a.ttf") format("truetype");
    }
    @font-face{
        font-family:"UniviaULItalic";
        src:url("/payments/fonts/2999640/a21ef69f-998f-4680-a7a0-36b956d9fcab.eot?#iefix");
        src:url("/payments/fonts/2999640/a21ef69f-998f-4680-a7a0-36b956d9fcab.eot?#iefix") format("eot"),url("/payments/fonts/2999640/ca030473-c802-446b-9a41-1ccfd968276b.woff2") format("woff2"),url("/payments/fonts/2999640/ebbe7bff-c721-48ba-a0f6-d221f9bfae5b.woff") format("woff"),url("/payments/fonts/2999640/5a354f04-6151-4a4b-91f5-d8956b1260f0.ttf") format("truetype");
    }
    @font-face{
        font-family:"UniviaUL";
        src:url("/payments/fonts/2999656/b73bc3ae-d244-4532-b088-657817d819fd.eot?#iefix");
        src:url("/payments/fonts/2999656/b73bc3ae-d244-4532-b088-657817d819fd.eot?#iefix") format("eot"),url("/payments/fonts/2999656/7f4666dd-72ed-46b6-92c3-bc73307cb348.woff2") format("woff2"),url("/payments/fonts/2999656/aa537580-b355-411e-ae90-e52cd237b435.woff") format("woff"),url("/payments/fonts/2999656/5c693277-7fd3-4f92-831c-c0f5c9d18ae6.ttf") format("truetype");
    }


/* Global */
* 
{
  box-sizing : border-box;
}

:root.in-kiosk {
	--theme-color : white;
	--header-color : #3B092E;
	--initial-opacity: 0.3;
	--form-background: #FFFFFF00;
}
:root.in-kiosk label {
    color: white;
}
:root.in-kiosk .form-body {
    color: white;
}
:root.in-kiosk div.logo-header {
	display: none;
}
:root.in-kiosk .radioset input:checked + label {
    color: var(--header-color);
    background-color: var(--theme-color);
}

:root.in-kiosk .radioset label {
    background-color: transparent;
}

:root.in-kiosk .form-section:has(img.logo) {
    display: none;
}
input:is([type=checkbox],[type=radio]) {
	pointer-events: none;
}

.ieerror {text-align: center; margin-top: 20%;}

.bk-form-header{
    width: 100%;
    height: 20px;
	margin: 10px 0 25px 0;
	border-bottom: #090 solid 2px;
    border-bottom: var(--theme-color,#090) solid 2px;
    border-top-left-radius: 25px;
    border-bottom-left-radius: 25px;
    overflow: visible;
    display: flex;
    justify-content: flex-start;
    position: relative;
}
.bk-form-header div.title{
    margin-right: auto;
    height: 20px;
    min-width: 30%;
    padding: 6px 0 4px 20px;
    background-color: #090;
    background-color: var(--theme-color,#090);
    text-align: left;
    position: relative;
    box-sizing: border-box;
    border-top-left-radius: 25px;
    border-bottom-left-radius: 25px;
	white-space: nowrap;
	color: white;
    color: var(--header-color, white);
    font: 600 10pt/7pt arial;
}
.bk-form-header div.title::after{
    content: '';
    position: absolute;
    right: -40px;
    top: 0;
    width: 0;
    height: 0;
    border-right: 40px solid transparent;
    border-bottom: 20px solid #090;
    border-bottom: 20px solid var(--theme-color,#090);
    clear: both;
}
.bk-form-header .link{
	align-self: flex-end;
	font-style: italic;
	font-size: smaller;
	color: blue;
	cursor: pointer;
	text-align: right;
}

body {
	margin: 0;
	background-color: var(--bg-color);
		background: url(/payments/images/bg.jpg) no-repeat center center fixed;
        background: var(--bg);   
	font-family: 'Univia', 'Helvetica', sans-serif;
	display: flex;
	flex-wrap: wrap;
	/*justify-content: center;*/
	align-items: center;
	height: 99vh;
	min-height: 100vh;
	position: relative;
}
h1 {
	font-size:40px;
	font-family: 'Univia', sans-serif;
	color: #5e6977;
	color: var(--identity-color, #5e6977);
	margin-block-start: 0;
}
h2 {
	font-size : 30px;
	font-family: 'Univia', sans-serif;
	color: #5e6977;
	color: var(--identity-color, #5e6977);
	margin-top: -36px;
}
h3 {
	font-size:18px;
	color: #5e6977;
	color: var(--identity-color, #5e6977);
	margin-top: -30px;
	font-family: "UniviaUL";
}
h5 {
	font-size:14px;
	color: #5e6977;
	color: var(--identity-color, #5e6977);
	/*padding-left: 30px;*/
	/*margin-top: -30px;*/
	font-family: "UniviaULItalic";
	margin-block-start: 0;
	/*text-align: right;*/ /*if align right*/
	display: inline-flex;
	width: 100%;
	justify-content: center;
	align-items: flex-end;
}
h6 {
	color: #5e6977;
}
.logo-header {
	margin-top: 25px;
	min-height: 50px;
	padding-left: min(60px,10vw);
	padding-right: min(60px,10vw);
	}
.logo {
	max-height: 75px;
	/*padding: 10px;*/
	margin-bottom: -30px;  
	padding-top: 0;
	}
.logo-header .logo{
		max-height: 100px;
		max-width: 100%;
		min-height: 100px;
		float: right;
		padding: unset;
}
/* Credit Card */

.container{
	width: 1200px;
	width: var(--width, 1200px);
	min-height: 660px;
	margin: auto;
	max-width: 100%;
	position: relative;
}
.container form {
	width: 1200px;
	min-height: 660px;
	height: auto;
	/*column-count: 2;*/
	border: 1px solid #ddd;
	border: var(--border);
	border-radius: 6px;
	background-color: white;
	background-color: var(--form-background, white);
	box-shadow: 1px 2px 30px 10px rgba(0,0,0,0.10);
	box-shadow: var(--box-shadow);
	max-width: 100%;
	display: flex;
	flex-direction: column;
}
.form-header {
	
	height: 60px;
	padding: 20px 30px 0;
	border-bottom: 1px solid #E1E8EE;
}

.form-container {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 100%;
	/*height: 70vh;*/
	margin-bottom: auto;
	padding: 0 2em 0em; /*Was 0 2em 2em; changed on 8/12/20 to accomodate kiosks*/
}
.topside {
	width: 100%;
	margin-top: 2em;
}
.leftside, .rightside {
	width: 45%;
	margin: 20px auto;
	flex: 1 1 360px;
	display: flex;
	flex-flow: column nowrap;
	justify-content: space-between;
	/*border: 1px green dotted;*/
}
.form-section {
	width: 100%;
	padding: 10px 30px;
}
.form-body {
	display: flex; flex-flow: row wrap;
	justify-content: space-between;
	margin: auto -2pt
	/*height: 100%;*/
	/*padding: 30px 30px 20px;*/
}
.form-body > * {
	flex: 1 1 100%;
	position: relative;
	margin: auto 2pt
}
.form-choice {
	width: 100%;
	display: flex;
	justify-content: flex-end; /*make sure this works for everyone -- even daf7 || LOOKS GOOD (9/4)*/
	align-items: center;
	margin-bottom: 12px;
	flex-wrap: wrap; /* JUST ADDED (9/4) MAKE SURE IT IS GOOD ACROSS HE BOARD*/
}
.form-choice > * {
	margin-left: 10px; /* make sure this works for all -- LOOKS GOOD (9/4)*/

}
.form-choice > div {
    /*margin: auto;*/
    align-self: unset;
    margin-top: 0;
}
.form-choice > div.inside:nth-last-child(1) {
    margin-left: auto;
}
.insCalc {
	font-size: 65%;
}

.helplink {
	color: blue;
	font-size: 75%;
	margin-left: .75em;
	border: 1px lightgrey solid;
	border-radius: 50%;
	padding: 2pt 4pt;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2)
}

.form-message {
	padding: 10pt 0 5pt 0;
	font-size: 95%;
	text-align: center;
}

.form-yesno {
    /*padding: 10pt 0 5pt 0;*/
    font-size: 90%;
    text-align: center;
}
.footer {
	padding: 0;
	text-align: center;
}

h5 img.logo {
	margin-right: -7px; /* if aliging right*/
}

h6#page-footer {
	text-align: center;
	position: absolute;
	bottom: 0pt;
	text-shadow: 1px 1px 3px rgba(0,0,0,.2), -1px -1px 3px rgba(0,0,0,.2);
	padding: 2pt;
	margin: 2pt;
	display: none;
}
/* Title */
.title {
	margin: 0;
	color: #5e6977;
	font-size: 16px;
}
.proceed-btn {
	position: relative;
	background-color: #090;
	background-color: var(--theme-color,#090);
	width: 100%;
	color: white;
	color: var(--header-color, white);
    font: 700 10pt/7pt arial;
}
.proceed-btn.clover-must-login::after {
    content: 'Can\'t process payments. Please log into Clover';
    color: red;
    position: absolute;
    right: 3px;
    font-size: 9pt;
    font-weight: 900;
    bottom: 1px;
    pointer-events: auto;
	cursor: pointer;
}
.proceed-btn.clover-must-login {
    background-color: transparent;
    color: transparent;
    pointer-events: none;
}

.clear-btn {
	width: 100%;
    font: 700 10pt/7pt arial;
}
.link-btn {
	width : 100%;
	font: 700 10pt/7pt arial;
}
div#check {display: none;}

.top-banner {
    margin: 36px 60px 0 60px;
    text-align: center;
}
@media only screen and (max-width: 620px){
	.top-banner{
		margin: 36px 30px 0px 30px;
	}
}
.top-banner > img {
	max-width: 100%;
}
.bottom-banner{
    margin: 2em 60px 0 60px;
	text-align: center;
}
.bottom-banner:empty {
	display: none
}
.bottom-banner #merchlogo h5 {
	font-size: larger;
	align-items: center;
	margin-bottom: 0;
}
.bottom-banner #merchlogo h5 img.logo {
    max-height: 100px;
    margin-bottom: unset;
}
.iam {
    align-self: center;
    font-size: 8pt;
    color: lightgray;
}


/* Common */
.form-input-div {height: 36px; width: 100%}
.form-input {
	height: 36px;
	font-size: 14px;
	font-weight: 100;
	line-height: 14px;
	margin-bottom: 10px;
    border: 1px solid #ccc;
	border-radius : 6px;
}
.multiline .form-input {
	height: 1.6cm;
}
.form-input:placeholder-shown {
	/*color: transparent /-*#86939e;*-/ ;*/
	opacity: .7;
	opacity: var(--initial-opacity, .7);
}

.other-option .form-input:placeholder-shown {
	color: black;
}

input.form-input.text-input:focus {
    box-shadow: 1px 1px 2px black, 3px 2px 4px white;
}

.half-width {
	width: 45%;
	/*min-width: 2.5cm;*/
	flex: 1 1 4.5cm;
}

.input-group {
	display: flex; flex-flow: row nowrap;
	width: 100%
}
.input-group.has-caption::before {
    content: attr(data-caption);
    position: absolute;
    top: -20px;
    font-size: 80%;
    width: 100%;
    text-align: center;
}

.input-group.has-caption {
    margin-top: 18px;
}

.input-group .form-input {
 	border-radius: unset;
 	padding: 10px;
 }

/*.input-group *:not(.input-box) {border: 1px solid #ccc; }*/
.input-group > *:nth-child(1) {border-top-left-radius: 6px; border-bottom-left-radius: 6px;}
.input-group > *:nth-last-child(1) {border-top-right-radius: 6px; border-bottom-right-radius: 6px; }
.input-group > *:not(input):not(.input-box):not(.caption) {border-right: 1px solid #ccc;}
.input-group > * :is(input, div) {border-radius: inherit !important;}
.input-group > div .select :is(select, select + div) {border-radius: inherit !important;}

.amount-group > * {
	flex: 1 1 30%;
}
.currency-sign {
	flex: 0 0 0%;
	background-color: #090;
	background-color: var(--theme-color,#090);
	color: white;
	color: var(--header-color, white);
	font-weight: bolder;
}
.currency-sign.currency-international {
	position: relative;
	padding-right: 42px;
	cursor: pointer;
}
ul.currency-list {
	display: none;
    color: var(--theme-color);
    list-style: none;
    position: absolute;
	top: 22px;
    left: -2px;
    padding-left: 10px;
    background-color: white;
    z-index: 1000;
    width: 60px;
    cursor: pointer;
    box-shadow: 1px 1px 7px -4px;
    border-radius: 6px;
    padding: 2px;
    box-sizing: content-box;
}
.currency-sign:hover > ul.currency-list, ul.currency-list:hover {
    display: block;
}
ul.currency-list li {
    padding: 2pt 6pt;
}
ul.currency-list li:hover {
    background-color: var(--theme-color);
    color: var(--form-background);
}
.form-input.currency-sign.currency-international::after {
    content: "\25BC";
    position: absolute;
    right: 4px;
	top: 11px;
}
.amount-group div:nth-child(3) {
	flex: 2 1 50%;
	padding: 0 !important;
}
.amount-group div:nth-child(3) label {
	display: flex;
	align-items: center;
	font-style: oblique 10deg;
	font-size: smaller;
	height: 100%;
	justify-content: center;
	flex-wrap: wrap;
	padding: 0;
}
.form-input.final-group{
	padding: 0;
}
#final_header {
	width: 100%;
	min-width: max-content;
	font-weight: 600;
	font-size: 10pt;
	line-height: 12pt;
	height: 40%;
	text-align: center;
}
#final_amount {
	width: 100%;
	height: 60%;
	text-align: center;
	font-weight: bolder;
	font-family: Arial, Helvetica, sans-serif;
}
.cardcontainer[data-cardicon]::before {
    width: 100%;
    height: 36px;
    content: '';
    position: absolute;
    top: -36px;
    background-image: var(--icon);
    background-size: 327px;
    background-repeat: no-repeat;
    background-position: bottom right;
}
.cardcontainer[data-cardicon] {
	margin-top: 18px;
}


div.input-box, div.half-width {position: relative}
div.input-box::after, div.half-width::after {
   	content: attr(data-placeholder);
   	position: absolute;
   	bottom: 14px;
   	right: calc(14px + var(--button-width, 0px));
   	font-size: 8pt;
   	color: #aaaa;
   	font-style: italic;
   	pointer-events: none;
}
div.input-box:has(.be-anonymous)::after{
	right: 160px;
}
div.input-box:has(> [type=file])::after {
    left: 9px;
    right: auto;
}

div.input-box::before, div.half-width::before {
   	content: attr(data-caption);
    position: absolute;
    top: 10px;
    left: 8pt;
    font-size: 14px;
    color: darkgray;
    z-index: 100;
    pointer-events: none;
}

div.caption {
	position: absolute;
    top: 10px;
    left: 8pt;
    font-size: 14px;
    color: darkgray;
    z-index: 100;
    pointer-events: none;
    border: none;
}

.input-group .caption, .caption.date-caption {
    font-size: min(14px, 3.3vw);
}

.caption.date-caption {
    left: 52%;
}

input:not(.show-placeholder)::placeholder, textarea:not(.show-placeholder)::placeholder {color: transparent;}
input:not(.show-placeholder):-ms-input-placeholder, textarea:not(.show-placeholder):-ms-input-placeholder {color: transparent;}
input:not(.show-placeholder)::-webkit-input-placeholder, textarea:not(.show-placeholder)::-webkit-input-placeholder {color: transparent;}
input[id$=other]:not(.show-placeholder)::placeholder {color: initial;}

sup, sub {
  vertical-align: baseline;
  position: relative;
  top: -0.4em;
}
sub { 
  top: 0.4em; 
}

/* Card Number */
.text-input {
	width: 100%;
	padding: 10px;
}
.input-box {
	width: 100%;
}

fieldset.form-fieldset {
	font-size: 14px;
	font-weight: 100;
	line-height: 14px;
	margin-bottom: 10px;
    border: 1px solid #ccc;
	border-radius : 6px;
}

fieldset[data-header]::before {
    content: attr(data-header);
    position: absolute;
    width: calc(100% - 23.5px);
    text-align: center;
    top: 24pt;
    font-weight: 800;
    font-size: 110%;
    color: var(--theme-color);
    padding: 0 24px;
    box-sizing: border-box;
}

fieldset[data-header] {
    padding-top: 2cm;
}

fieldset.form-fieldset > div:not(.single-column):nth-of-type(1) {
	height: auto;
	width: 100%;
	padding: 20px;
	column-count: auto;
	column-width: 2in;
	column-gap: 22pt;
	/*
	display: flex;
	flex-direction: column;
	*/
}

fieldset.form-fieldset > div.widecolumn:nth-of-type(1) {
	column-width: 4in;
}

fieldset.form-fieldset div.checkgroup {
	-webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}

fieldset.form-fieldset label {
	display: flex;
	position: relative;
	font-size: 10pt;
	line-height: 14pt;
	padding-bottom: 8px;
	margin-bottom:	1px; /* To prevent breaking a column in middle of a checkbox */
	-webkit-column-break-inside: avoid;
}

fieldset.form-fieldset label input[type="checkbox"] {
    margin-right: 9pt;
}

fieldset.form-fieldset legend {
	padding: 0 .5cm;
	color: black;
	color: var(--identity-color,black);
}

fieldset.form-fieldgroup {
	font-size: 14px;
	font-weight: 100;
	line-height: 14px;
	margin-bottom: 10px;
    border: 1px solid #ccc;
	border-radius : 6px;
}
fieldset.form-fieldgroup legend {
	padding: 0 .5cm;
	color: black;
	color: var(--identity-color,black);
}
fieldset.form-fieldgroup > div:nth-of-type(1) {
	height: auto;
	width: 100%;
	padding: 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.reserve-second, .dinner-reservations-strict {
	display: none;
}

input.dinnerButton {
    border-radius: 6px;
    box-shadow: 2px 1px 8px 1px rgba(0,0,0,.4);
    flex: 1 0 36px;
	padding: 0 1.5cm;
	margin-bottom: 10px;
}
fieldset.form-fieldgroup .form-input[id$=other]:placeholder-shown  {
	opacity: .7 !important;
	color: #000;
}
fieldset.form-fieldgroup .form-input[id$=other]:-ms-input-placeholder{
	opacity: 1 !important;
	color: #000;
}
fieldset.form-fieldgroup .form-input[id$=other]::placeholder  {
	opacity: .7 !important;
	color: #000;
}
fieldset.form-fieldgroup .form-input[id$=other]::-webkit-input-placeholder{
	opacity: .7 !important;
	color: #000;
}
fieldset.form-fieldgroup .form-input[id$=other]::-ms-input-placeholder{
	opacity: 1 !important;
	color: #000;
}

.buyquan-item-footer {
    margin-bottom: 1.5em;
    margin-top: -.5em;
    font-size: 93%;
    font-style: oblique;
	text-indent: 16pt;
	filter: opacity(0.6);
}

.itemquangroup {
    display: flex;
	flex-wrap: wrap;
    margin: 11px 0;
    break-inside: avoid;
	margin: auto 2pt;
	align-items: center;
}
.quanfooter {
    font-size: 80%;
    margin-top: 0pt;
    text-indent: 2em;
    margin-bottom: 21pt;
	break-before: avoid;
}
.inventory-message {
    width: 100%;
    text-align: center;
    font-size: 75%;
}
.inventory-message::before {
    content: '\2730 \2730 ';
    margin-right: 0.5em;
}
.inventory-message::after {
    content: ' \2730 \2730';
    margin-left: 0.5em;
}

button.apply-button {
    position: absolute;
    right: 2px;
    height: calc(100% - 4px - 10px);
    top: 2px;
    border-radius: 6px;
    border: none;
    background-color: var(--theme-color);
    color: var(--header-color);
    padding: 0 28px;
}

/*
input::placeholder, textarea::placeholder {color: transparent;}
input:-ms-input-placeholder, textarea:-ms-input-placeholder {color: transparent;}
input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {color: transparent;}
input[id$=other]::placeholder {color: initial;}

*/





.checkboxheader {
	font-weight: bold;
	padding-top: 2mm;
	/*padding-bottom: 2mm;*/
	margin-bottom: 0;
	text-align: center;
	break-after: avoid;
}
div.cb-other {
	padding-top: 2mm;
    padding: 1.5em;
    border: 2px ridge;
    background-color: #0001;
    border-radius: 6pt;
    margin: 1em auto;
}
/*div.cb-other input[type=text] {
	width: 100%;
	padding: 1mm;
	border-radius: 6px;
}*/
div.cb-other input[type=text]::placeholder {
	color: initial;
}
span.checkother {
	font-weight: bold;
	display: block;
	padding-bottom: 2mm;
}

div.c-price {
	flex-grow: 1;
	text-align: right;
	padding-left: 2pt;
}

div.checkbox-footer {
    padding: 20px;
    text-align: left;
    font-weight: 600;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.checkbox-footer * {
    flex: 1 0 100%;
}

.checkgroup ul{
	margin-top: 4px;
}
.checkgroup h4{
	margin-bottom: 10px;
	display: inline-block;
	margin-top: 0;
	filter: drop-shadow(1px 2px 2px rgba(0,0,0,0.4));
}
.checkgroup li {
	padding: 3pt 0;
	line-height: 13pt;
}

.quantityinput{
	float: right;
	width: 3em;
}
.quantityinput input {
	width: 100%;
    height: 34px;
    border-radius: 6px;
    border: 0.1px solid #9999;
    font-size: 1rem;
}

.quantityinput input[type=number]::placeholder {
	color: #0008;
}

.pricegroup h4 {
	break-inside: avoid;
    break-after: avoid;
}

.pricegroup h4 + div {
    break-inside: avoid;
	/** there was also brealafter:avoid; but I don't know why. Removed on 2/5/25 while working on lby/auction/student*/
}

.pricegroup:first-child h4 {
    margin-top: 0;
}

.pricegroup > div {
	min-height: 18pt;
	display: flex;
	justify-content: space-between;
	padding: 2pt 0;
}

.pricegroup-item-text {
	width: calc(100% - 3em);
	line-height: 127%;
}

.pricegroupinput{
	float: right;
	width: 3em;
}
.pricegroupinput input {
	width: 100%;
}
.pricegroupinput input[type=number]::placeholder {
	color: #0008;
}

nav#pricegroupMessage {
    min-height: 4pt;
    width: 100%;
    text-align: center;
    margin-top: 8pt;
    color: crimson;
    font-weight: 800;
}
.form-input.link {color: blue; font-weight: 700; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6); background-color: white; opacity: .7; opacity: var(--initial-opacity);}

.dropdown.form-input {
	width: 100%;
	background: #fff;
 	padding-left: 20px;
 	margin-bottom: 0;
}
#repeat-section:not(.default-on), #instal-section:not(.default-on){
    display: none;
    /*height: 0px;
    transition: height 1s ease-in;
    overflow-y: hidden;*/
}

:is(#repeat-section,#instal-section) .select {
	margin-bottom: 0;
}

.other-option {
	display: none;
}

.options li[disabled][data-soldout] {
    opacity: .55;
}

.options li[disabled][data-soldout]::after {
    content: attr(data-inventorymessage);
    position: absolute;
    right: 16px;
    font-size: 80%;
    color: red;
    font-weight: 800;
}

.cardcontainer {position: relative;}
#card-swipe-icon {
	position: absolute;
	right: 2px;
	bottom: 16px;
	height: 24px;
}
.card-swipe-outline {fill: var(--theme-color,black);}
/* Date Field */


.month select,
.year select {
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	width: 45%;
	margin-bottom: 20px;
	padding-left: 20px;
	border: 2px solid #e1e8ee;
	border-radius: 6px;
	background: url('/payments/caret.png') no-repeat;
	background-position: 85% 50%;
}
.month select {
	float: left;
}
.year select {
	float: right;
}
#cvvdtls {
	position: absolute;
	bottom: 65px;
	right: 0;
	z-index: 900;
	padding: 30px;
	border-radius: 6px;
	box-shadow: 4px 6px 18px 6px rgba(0,0,0,0.5);
	background-color: white;
	opacity: 0;
	visibility: hidden;
	transition: opacity .3s ease-in;
}
#cvvdtls.show {visibility: visible; opacity: 1;}

.cvv-details {display: none;}
/* Buttons Section */
.captcha {
	margin: 36px auto;
	display: flex; justify-content: center;
}
#login-icon {
	display: none;
	position: absolute;
	height: 36px;
	top: -40px;
	right: -18px;
	/*bottom: 4px;
	right: 50%;*/
	cursor: pointer;
	transform: translateX(50%);
	filter: drop-shadow(0px 0px 2px white) drop-shadow(1px 0px 1px black);
}
#login-icon path {
	fill: var(--theme-color);
}

#merchlogin {
	display: none;
	display: var(--features-login);
	position: absolute;
	bottom: -14pt;
	right: 10px;
	font-style: italic; font-size: 11pt;
	color: blue; font-weight: 500; text-decoration: none; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6)
}
#sequelmerchlogin {
	display: none;
	display: var(--features-login-sequelpay);
	position: absolute;
	bottom: -14pt;
	right: 10px;
	font-style: italic; font-size: 11pt;
	color: blue; font-weight: 500; text-decoration: none; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6)
}
#merchpaygatewaylogin {
	display: none;
	display: var(--features-login-merchpay);
	position: absolute;
	bottom: -14pt;
	right: 10px;
	font-style: italic; font-size: 11pt;
	color: blue; font-weight: 500; text-decoration: none; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6)
}
#authorizelogin {
	display: none;
	display: var(--features-login-authorize);
	position: absolute;
	bottom: -14pt;
	right: 10px;
	font-style: italic; font-size: 11pt;
	color: blue; font-weight: 500; text-decoration: none; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6)
}
#reprint {
	display: none;
	position: absolute;
	top: -14pt;
	right: 10px;
	font-style: italic; font-size: 11pt;
	color: blue; font-weight: 500; text-decoration: none; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6)
}
.link-link {
	position: absolute;
	bottom: -14pt;
	right: 10px;
	font-style: italic; font-size: 11pt;
	color: blue; font-weight: 500; text-decoration: none; cursor: pointer; text-shadow: 1px 1px 3px rgba(100,100,255,.6)
}
.helptext {
	position: absolute;
	display: none;
	right: 0;
    font-size: 8pt;
    bottom: 35pt;
    color: var(--theme-color);
}


input.form-input[type=file]::file-selector-button {
    float: right;
    margin-top: -5px;
    border-radius: 9px;
    padding: 1px 24px;
    border: outset 2px;
    box-shadow: 1px 1px 4px -1px;
    font-family: 'UniviaULItalic';
    font-weight: 600;
}
input.form-input[type=file]::file-selector-button:active {
    border: inset 2px;
    box-shadow: -1px -1px 3px -1px;
    margin-top: -3px;
}
input.form-input[type=file]{
	direction: rtl;
	text-indent: 1em;
	font-size: 9pt;
}

#paymentform.only-apple [data-nonapple-payment]{
	display: none;
}
#paymentform button.only-apple-only {
	display: none;
}
#paymentform.only-apple button.only-apple-only {
	display: block;
	position: relative;
    background-color: #FFF;
    width: 100%;
    color: var(--theme-color, white);
    font: 700 10pt / 7pt arial;
    border: 1mm solid;
}


@media only screen and (max-width: 1278px) {
	#login-icon {
		position: relative;
		right: unset;
		transform: unset;
	}
}

@media only screen and (max-width: 770px){
	.logo-header {
		text-align: center;
	}
	.logo-header .logo {
		float: none !important; padding-right: 0; margin: 1em 0 0;
	}
}

@media only screen and (max-width: 620px) {
	h1 {
		font-size: 18pt;
		line-height: 40pt;
	}
	h2 {
		font-size: 12pt;
		line-height: 30pt;
	}
	h3 {
		font-size: 11pt;
		line-height: 28pt
	}
	.form-container {
		padding: 0;
	}
	.leftside, .rightside {
		margin: auto 0;
	}
	h6#page-footer {
		position: relative;
		margin: 2em 2pt 2pt;
	}
}

@media only screen and (max-width: 370px){
	.form-section {
		padding: 10px 5px;
	}
}


/*
	SELECT replacer
*/

.s-hidden {
    /*visibility:hidden;*/ /*** Anyhow neing placed behind the dropdown. Now the browser cans show required warning*/
	padding-right:10px;
	position: absolute;
	left: 0;
    /*height: 0;*/
}
.select {
    cursor:pointer;
    display:inline-block;
    position:relative;
    font:normal 14px/14px Roboto, Sans-Serif;
    color:black;
    width: 100%;
    /*border:1px solid #ccc;*/
    margin-bottom: 12px
}
.styledSelect {
    position:relative;
    top:0;
    right:0;
    bottom:0;
    /*left:0;*/
    background-color:white;
	padding-right: 36px;
	min-width: max-content;
	margin-bottom: 0;
    /*font-weight:bold;*/
}
.styledSelect[data-disabled=true] {
	color: darkgray;
	/*opacity: var(--initial-opacity, .7);*/
	font-size: 14px;
}
.styledSelect:after {
    content:"";
    width:0;
    height:0;
    border:5px solid transparent;
    border-color:black transparent transparent transparent;
    position:absolute;
    top:15px;
    right:10px;
}
.styledSelect:active, .styledSelect.active {
    background-color:#eee;
}
.options {
    display:none;
    position:absolute;
    top:100%;
    right:0;
    /*left:0;*/
    z-index:999;
    margin:0 0;
    padding:0 0;
    list-style:none;
    border:1px solid #ccc;
    background-color:white;
    -webkit-box-shadow:0 1px 2px rgba(0, 0, 0, 0.2);
    -moz-box-shadow:0 1px 2px rgba(0, 0, 0, 0.2);
	box-shadow:0 1px 2px rgba(0, 0, 0, 0.2);
	min-width: fit-content; /* Due to left:0 it won't listen; without left:0 it doesn't fit to parent width. solution: js*/
}
.options li {
    margin:0 0;
	padding:10px 10px;
	white-space: nowrap;
	min-width: fit-content;
}
.options li:hover:not([disabled]) {
    background-color:#39f;
    color:white;
}
.options li[disabled] {cursor: not-allowed; background-color: lightgray;}

li.section-header {
    text-align: center;
    font-weight: bold;
}

/* RADIO BUTTON*/
.radioset {
	display: flex; flex-direction: row; justify-content: flex-start; align-items: center;
	padding: 0 0 0 10px;
}
.radioset label{
	border-right: 1px #ccc solid; border-left: 1px #ccc solid;
	margin: 0;
	height: 100%;
	padding: 15px;
	display: flex;
	flex-direction: column;
	justify-content: center; align-items: center;
	color: #f0f0f0;
	background-color: darkgray;
}
.radioset label:nth-last-child(1) {
	border-radius: 0 6px 6px 0;
	border-right: 0;
}
.radioset span {
	flex: 1;
}
.radioset input {
	margin: 0; padding: 0;
}
.radioset input[type=radio]{
	position: absolute;
	margin: 0;
	padding: 0;
	width: 98%;
	height: 100%;
	opacity: 0;
	z-index: -1;
}
.radioset input:checked + label {
	color: white;
	font-weight: 700;
	background-color: #090;
	background-color: var(--theme-color, #090);
}
.radiobutton input[type="radio"] {
    position: absolute;
    opacity: 0;
}.radiobutton label {
	margin: 6px 0 !important;
}
.radiobutton:nth-child(1) label{
	margin-top: 0 !important;
}
.radio-button-subtitle {
    font-size: 8pt;
    line-height: normal;
}
.radiobutton label > div {
	padding: 4pt;
	width: 100%;
	color: var(--theme-color);
	border-radius: 6px;
	border: 1px dotted gray;
	text-align: center;
}
.radiobutton label input:checked + div {
	background-color: #090;
	background-color: var(--theme-color, #090);
	color: var(--header-color);
	border-radius: 6px;
}

.customer-search {
    display: flex;
    justify-content: center;
    margin: auto;
    max-width: max-content;
	align-items: center;
}
.customer-search > span {
    margin-right: .5em;
}
.customer-search input {
    height: 36px;
    border-radius: 6px;
    border: 1px solid #ddd;
    margin: 0 .5em;
    padding: 2pt 6pt;
    font-size: 11pt;
    font-family: 'Univia';
}
.customer-search input[type="button"] {
    border: 2px outset;
}
div#customerpopup {
	display: none;
    position: absolute;
    left: 50%;
    transform: translatex(-50%);
    top: 100%;
    background-color: white;
    z-index: 1000;
    padding: 5px;
    cursor: pointer;
    min-width: 100%;
    border-radius: 6px;
    box-shadow: 2px 2px 10px -2px grey;
	width: max-content;
	overflow-y: auto;
}
.customerentry:hover {
    background-color: var(--theme-color,gray);
    color: var(--header-color,white);
}
.customerentry {
    border: 1px solid lightgray;
    border-radius: 4px;
    padding: 2px 7px;
}
span.customerentryaddress {
    padding-left: .7em;
    font-size: 68%;
}
div#paymentMethodPopup {
	display: none;
    position: absolute;
    top: calc(100% - 10px);
    background-color: white;
    z-index: 1000;
    padding: 5px;
    cursor: pointer;
    min-width: 100%;
    border-radius: 6px;
    box-shadow: 2px 2px 10px -2px grey;
	width: max-content;
	overflow-y: auto;
	left: 50%;
    transform: translatex(-50%);
}
.paymententry:hover {
    background-color: var(--theme-color,gray);
    color: var(--header-color,white);
}
.paymententry {
    border: 1px solid lightgray;
    border-radius: 4px;
    padding: 2px 7px;
}




/* Modal controls */
.modalcurtain.show {
	background-color: hsla(190deg,100%,5%,.8); visibility: visible;
}
.modalcurtain {
	height: 100vh; width: 100vw;  position: fixed; top: 0; left: 0; z-index: 1000; visibility: hidden; 
	background-color: hsla(190deg,100%,5%,0); transition: background-color .4s;
}
.modalcurtain.show .modalframe {
	top: 0;
}
.modalframe {
	height: 100vh; width: 100vw; display: flex; justify-content: center; align-items: center; 
	position: absolute; top: -100vh; left: 0; transition: top .4s ease-in;
}
.modalcontent {
	background-color: white; border-radius: 6px; box-shadow: 4px 6px 40px 10px rgba(0,0,0,1); 
	min-height: 50%; min-width: 30%; padding: 30px 20px; display: flex; flex-flow: column nowrap; max-height: 90vh;
}

#carddetails { display: none; }
div#carddetails > div {display: flex; justify-content: space-between;}
div#carddetails div#cardresult {display: block; padding: 3mm;}
div#cardresult > div { display: flex; justify-content: space-between;}
div#carddetails > div > div:nth-child(2) {
    color: forestgreen;
    font-weight: 600;
    font-style: italic;
}
div#carddetails > div#cardresult > div {
    color: unset;
    font-weight: unset;
    font-style: unset;
}

.modalmessage {
    padding: 1cm;
    background-color: azure;
    font: 500 14pt arial;
    text-shadow: 1pt 1pt 5pt rgba(0,0,0,.4);
    box-shadow: 2px 4px 10px inset rgba(0,0,0,.8);
    border-radius: 6px;
	overflow: hidden;
}#paymentstatus {
	width: 100%; text-align: center; color: white; font: 700 24pt/48pt arial; padding: .4em; background-color: green;
}
.modalcontrol {
	display: flex; flex-direction: row; align-items: center; justify-content: space-evenly; margin: auto; width: 80%; padding: 6pt;
}
.popup-error {
    background-color: red;
    padding: .8cm;
    color: white;
    font-size: 110%;
    text-shadow: 2px 2px 6px rgba(255,255,255,.5), -2px -2px 6px rgba(255,255,255,.5);
    border-radius: 4px;
    margin-bottom: 1in;
}
button.okbtn {
    padding: .7em;
    border-radius: 50%;
    box-shadow: 3px 7px 16px -2px;
    height: 5em;
    width: 5em;
    font: 700 14pt arial;
}
button.cnbtn {
    padding: .7em;
    border-radius: 50%;
    box-shadow: 3px 7px 16px -2px;
    width: 5em;
    height: 5em;
    font: 700 14pt arial;
}

/* Spinner*/
#loadingspinner {
	width: 100vw; height: 100vh; background-color: rgba(255,255,255,0.7); display: none; flex-flow: row nowrap; justify-content: center; align-items: center;
	position: fixed; z-index: 2000;
}
.spinner {
  margin: auto;
  width: 70px;
  text-align: center;
  visibility: visible;
}

.spinner > div {
  width: 18px;
  height: 18px;
  background-color: #333;

  border-radius: 100%;
  display: inline-block;
  -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
  animation: sk-bouncedelay 1.4s infinite ease-in-out both;
}

.spinner .bounce1 {
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}

.spinner .bounce2 {
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}

label.packagelabel {
    box-shadow: 1px 1px 10px -4px rgba(0,0,0,.4);
    border-radius: 3px;
    padding: 1em;
}

input:checked + label.packagelabel {
	border: outset;
    border-radius: 6px;
    background-color: lightcyan
}
label {
	cursor: pointer;
	/*padding: 4pt;*/ /** I don't kneo why this was here, but removed it 2024-03-12 since it messed up columns*/
	display: block;
	margin-bottom: 12px;
}
.invisible {
	width: 0;
	visibility: hidden;
}

.dependent-visibility {
	visibility: hidden;
}

.dependent-existance.hide-initially {
	display: none;
}

@-webkit-keyframes sk-bouncedelay {
  0%, 80%, 100% { -webkit-transform: scale(0) }
  40% { -webkit-transform: scale(1.0) }
}

@keyframes sk-bouncedelay {
  0%, 80%, 100% { 
    -webkit-transform: scale(0);
    transform: scale(0);
  } 40% { 
    -webkit-transform: scale(1.0);
    transform: scale(1.0);
  }
}

@media only screen{
	.printedpage {
		display: none;
		display: var(--screen-receipt, none);
		z-index: 2000;
		width: 100%;
		height: 100%;
	}
}

@media only print{
	html, body {
		width: 8.5in !important; height: 11in !important;
	}
	img {
		max-width: 100%;
	}
	body {
		-webkit-font-smoothing: antialiased; -webkit-text-size-adjust: none; line-height: 1.6; background-image: none;
	}
	body {
		background-color: darkgrey; display: flex; justify-content: center; font-family: arial;
	}
	#wholepage {
		width: 8in;
		max-width: 100%;
		background-color: white;
		margin: .25in auto;
		border-radius: 3px;
		box-shadow: 2px 2px 14px 5px rgba(0,0,0,.3), -2px -2px 14px 5px rgba(0,0,0,.3)
	}
	#main{margin: 2cm; }
	#head{color: #000;  display: flex;  flex-direction: column;  align-items: center;  padding: 2em 4em; }
	#merch-logo img{  max-height: 220px; }
	#merch-name{  font-size: 26pt;  font-weight: 700; margin-bottom: 1em;}
	#merch-phone{  margin: 14pt; }
	#meta{background-color: #FFCCEE; padding: 1em 2em; display: flex; flex-wrap: wrap; justify-content: center;}
	#status{font-size: 18pt; font-weight: 700; width: 100%; text-align: center;}
	#refnum, #datetime {width: 40%; text-align: center;}
	#body, .footer {
		padding: 2em 4em;
		display: flex; justify-content: space-between; flex-wrap: wrap;
		border: 1px #ccc solid;
	}
	.footer pre {
		text-align: left;
		white-space: break-spaces;
    	font-size: 90%;
	}
	.segment {display: flex; justify-content: space-between; flex-wrap: nowrap; width: 100%;}
	.segment > div {width: 40%;}
	#cardinfo {margin: 4mm auto; font-weight: bold; padding: .5cm; border: lightgreen 1px solid; border-radius: 4px}
	#transactioninfo {display: flex; flex-wrap: wrap; justify-content: space-between;}
	.col1, .col2 {width: 40%}
	.centered {justify-content: center; font-weight: bold; font-size: larger;}

	.printedpage{
		z-index: 2000;
		width: 100%;
		height: 100%;
	}
	.container {display: none;}
	.modalcurtain {display: none;}
}

.overlay {
	display: none;
	display: var(--overlay,none);
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10000;
	overflow: hidden;
	background-color: white;
}

.overlay * {pointer-events: none;}

#overlayvideo {
	min-height: 100%;
	min-width: 100%;
	width: auto;
	height: auto;
	position: absolute;
  	top: 50%;
  	left: 50%;
  	transform: translate(-50%,-50%);
}
#overlayimage {
	min-height: 100%;
	min-width: 100%;
	position: absolute;
  	top: 50%;
  	left: 50%;
  	transform: translate(-50%,-50%);
}
#overlaymessage {
	width: 100%;
	height: 15%;
	position: absolute;
	bottom: 10%;
	padding: 1in;
	background-color: #0008;
	display: flex;
	justify-content: center;
	align-items: center;
}
#overlaymessage > div {
	color: #eee;
	width: 100%;
	text-align: center;
	font-size: 48pt;
}

span.paymententryextension {
    padding-left: 2em;
    font-size: 90%;
}

#darkBackground.show {
	background-color: hsla(190deg,100%,5%,.8); visibility: visible;
}
#darkBackground {
	height: 100vh; width: 100vw;  position: fixed; top: 0; left: 0; z-index: 1000; visibility: hidden; 
	background-color: hsla(190deg,100%,5%,0); transition: background-color .4s;
}

#threedsChallenge {
	visibility: hidden;
	opacity: 0;
	transition: visibility .5s ease-in;
	transition: opacity .5s ease-in;
	z-index: 1100;
	position: fixed;
	width: 400px;
	height: 400px;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.pageNavigation {
    width: 100%;
    display: flex;
    justify-content: center;
}
.pageNavigationsButtons input {
    padding: 4px 20px;
    border-radius: 6px;
    background-color: var(--theme-color);
    color: var(--header-color);
    font-size: 14pt;
    font-family: Univia;
    margin: 0 1cm;
}

div#authaugnotice {
    position: fixed;
    right: 0;
    bottom: 2%;
    width: 4in;
    display: flex;
}
.toast-text {
    font-size: 10pt;
}
.toast-dismiss {
    width: 75px;
    padding: 0;
	margin: 0;
	cursor: pointer;
}
.toast-dismiss:before {
    width: 40px;
    height: 4px;
    background-color: darkgray;
    position: absolute;
    top: 50%;
    content: " ";
    transform: rotateZ(-45deg);
    border-radius: 10px;
}
.toast-dismiss:after {
    width: 40px;
    height: 4px;
    background-color: darkgray;
    position: absolute;
    top: 50%;
    content: " ";
    transform: rotateZ(45deg);
    border-radius: 10px;
}
div#totalDisplay {
    padding: 0 0 8pt 1em;
    font-weight: 900;
}
span#totalDisplayAmount::before {
    content: '$ ';
    font-size: 146%;
    font-weight: 800;
    vertical-align: -7%;
}
span#totalDisplayAmount.ILS::before {
	content: '\20AA';
}

/** Goal display **/
.goal-banner {
    display: flex;
	flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    margin-top: 2em;
	max-width: 100%;
}
.goal-caption {
    white-space: nowrap;
    /*margin-right: 2em;*/
}
.goal-wrapper {
    width: 100% /*min(567px, 90vw)*/;
    height: 34px;
    margin-left: auto;
    background-color: #eee;
    border-radius: 16px;
    position: relative;
}
.goal-wrapper:after {
    content: attr(data-goal);
    position: absolute;
    right: 0px;
    top: -18px;
    font-size: 9pt;
}
.goal-meter {
    width: 100%;
    border: solid 1px var(--theme-color);
    height: 100%;
    border-radius: 16px;
    overflow: hidden;
}
.goal-meter-fill {
    height: 100%;
    /*position: relative;*/
}
.goal-meter-fill:after {
    content: attr(data-amount);
    font-size: 7pt;
    position: absolute;
    left: calc(100% * var(--percentage) / 100 + 4px);
    top: 10px;
}

/** Campaign scrolling marqee **/
.campaign-marqee::before {
    content: 'Recent Donors';
    position: absolute;
    background: white;
    width: 2.5in;
    text-align: center;
    top: -9pt;
    left: calc(50% - 1.25in);
    border-radius: 12pt;
    line-height: 16pt;
    box-shadow: 0px 3px 8px -2px black;
    font: 500 11pt/18pt arial;
    color: var(--header-color);
    background-color: var(--theme-color);
}
.campaign-marqee {
    border: 1.5pt var(--theme-color) solid;
    border-radius: 6pt;
    padding: 6pt;
    position: relative;
    padding-top: 12pt;
    margin-top: 16pt;
    max-height: calc(20pt + 28pt * var(--height));
}
.campaign-marqee:has(.donor-container:empty) {
	display: none;
}
.donor-container {
	position: relative;
    max-height: calc(28pt * var(--height));
    overflow-y: clip;
	--scroll-top: 0pt;
}
.donor {
    display: flex;
    flex-wrap: wrap;
    position: absolute;
    width: 100%;
    justify-content: space-between;
    height: 28pt;
    top: calc(0pt + 28pt * var(--pos) - var(--scroll-top));
	border-top: 1px dotted #0003;
}
.donor-amount::before {
    content: '$';
    font-weight: 800;
    margin-right: 1pt;
}
.donor-comment {
    flex: 2 0 100%;
    font-size: 60%;
    text-indent: 26px;
}
input.be-anonymous {
    position: absolute;
    right: 0;
    height: 36px;
    border-radius: 6px;
    border: none;
    background-color: var(--theme-color);
    color: transparent;
    /* background-image: linear-gradient(180deg, black, transparent 10%), linear-gradient(360deg, #fffa, transparent 10%), linear-gradient(90deg, black, transparent 2%), linear-gradient(270deg, #fffa , transparent 2%); */
    font-weight: 800;
    box-shadow: inset 2px 4px 8px -3px white, inset -2px -4px 6px -2px black;
    text-shadow: 1px 1px 0px var(--header-color), -1px -1px 0px black;
}
[popover]:not(.popped-open) {
    display: none;
}

.donors-wrapper {
    background: white;
    width: fit-content;
    height: fit-content;
	max-height: 90vh;
	max-width: 98vw;
	overflow: auto;
}

div div[popover].show-popover.campaign-full-list {
    position: fixed;
    z-index: 2000;
    height: 100vh;
    width: 100vw;
    top: 0;
    left: 0;
    box-sizing: border-box;
    display: flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    background: var(--theme-color);
}
.campaign-full-list:not(.show-popover) {
    position: fixed;
    margin: auto;
    overflow: auto;
    max-height: 90vh;
    max-width: 98vw;
}

.campaign-full-list::backdrop {
    background-color: #9609;
}

.full-list-donor {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    height: 45px;
    background: linear-gradient(180deg, #0003 2%, transparent 46%);
    padding: 1pt 6pt;
    box-sizing: border-box;
}

.full-list-donor-comment {
    flex: 2 0 100%;
    font-size: 71%;
    text-indent: 2em;
}
.full-list-donor-amount {
    padding-left: 0.5cm;
}
.full-list-donor-amount::before {
    content: '$';
    margin-right: 2px;
}

/** This is for short links that were created with data */
.itemized-list {
    margin-bottom: 8pt;
    border: 2pt ridge;
    border-radius: 6pt;
    padding: 12pt;
    display: flex;
    flex-direction: column;
}
.itemized-list-title {
    text-align: center;
    border-bottom: 3pt double;
    font-weight: 600;
    padding-bottom: 6pt;
    margin-top: -6pt;
}
.itemized-list-item {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    font-size: 10pt;
    padding: 3pt;
}
.itemized-list-item:nth-child(odd) {
    background-color: #0001;
}
.itemized-list-item-price::before {
    content: '$';
    padding-right: 1.5pt;
    font-size: 110%;
}