@charset "UTF-8";
@import "https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,400;0,700;1,400;1,700&display=swap";
@import "https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,700;1,400;1,700&display=swap";
@import "https://fonts.googleapis.com/css2?family=Dancing+Script&display=swap";


[type="checkbox"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    display: inline-block;
    vertical-align: middle;
    background-origin: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    flex-shrink: 0;
    height: 1rem;
    width: 1rem;
    color: #2563eb;
    background-color: #fff;
    border: 1px solid #6b7280;
    border-radius: 3px;
}

[type="checkbox"]:focus{
    outline: 2px solid transparent;
    outline-offset: 2px;
}

[type="checkbox"]:checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
    border-color: transparent;
	background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
	background-color: rgb(87, 39, 175);
    border-color: rgb(87, 39, 175);
}
* {
	box-sizing: border-box;
}
h1,.h1 {
    font-family: Lato,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";
    font-size: 24px;
    line-height: 32px;
    font-weight: 700;
	padding: 0;
	margin: 0;
}
h2,.h2 {
    font-family: Lato,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";
    font-size: 18px;
    line-height: 26px;
    font-weight: 700;
	padding: 0;
	margin: 0;
}
h3,.h3 {
    font-family: Lato,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";
    font-size: 16px;
    line-height: 24px;
    font-weight: 700;
	padding: 0;
	margin: 0;
}
h4,.h4 {
    font-family: Lato,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";
    font-size: 14px;
    line-height: 24px;
    font-weight: 700;
	padding: 0;
	margin: 0;
}
body,p,.p {
    font-family: Lato,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";
    font-size: 14px;
    line-height: 24px;
	padding: 0;
	margin: 0;
}
.mt-1 {
    margin-top: 4px;
}
.mt-2 {
    margin-top: 8px;
}
.mt-3 {
    margin-top: 12px;
}
.mt-4 {
    margin-top: 16px;
}
.mt-5 {
    margin-top: 20px;
}
.mb-1 {
    margin-bottom: 4px;
}
.mb-2 {
    margin-bottom: 8px;
}
.mb-3 {
    margin-bottom: 12px;
}
.mb-4 {
    margin-bottom: 16px;
}
.mb-5 {
    margin-bottom: 20px;
}
.pt-1 {
    padding-top: 4px;
}
.pt-2 {
    padding-top: 8px;
}
.pt-3 {
    padding-top: 12px;
}
.pt-4 {
    padding-top: 16px;
}
.pt-5 {
    padding-top: 20px;
}
.pb-1 {
    padding-bottom: 4px;
}
.pb-2 {
    padding-bottom: 8px;
}
.pb-3 {
    padding-bottom: 12px;
}
.pb-4 {
    padding-bottom: 16px;
}
.pb-5 {
    padding-bottom: 20px;
}
.gap-1 {
	gap: 4px;
}
.gap-2 {
	gap: 8px;
}
.gap-3 {
	gap: 12px;
}
.gap-4 {
	gap: 16px;
}
.gap-5 {
	gap: 20px;
}
.hidden {
	display: none !important;
}
a[href="*"] {
	color: #0070af;
}
.border-line-top {
	border-top: 1px solid #e5e7eb;
}

html {
	background-image: url(../images/logo.png);
    background-color: #3479c3;
    background-position-x: 0%;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
}
main {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	padding-top: 80px;
	padding-bottom: 80px;
}
main .column {
	display: flex;
	background: #fff;
	max-width: 800px;
	width: 100%;
	box-shadow: 0 2px 10px #0000001f;
	border-radius: 8px;
	padding: 16px;
}
.flex {
	display: flex;
	position: relative;
}
.flex-column {
	flex-direction: column;
}
.flex-row {
	flex-direction: row;
}
.items-center {
	align-items: center;
}
.justify-center {
	justify-content: center;
}
.justify-between {
	justify-content: space-between;
}
.justify-end {
	justify-content: end;
}
.text-center {
	text-align: center;
}
.text-right {
	text-align: right;
}
.w-100 {
	width: 100%;
}
.logo-box {
	max-height: 70px;
	max-width: 130px;
}
.header-text{
	color: #333333;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 2;
}
.preheader-text{
	color: #333333;
	/* font-size: 1.25rem; */
    line-height: 1.75rem;
	font-weight: 700;
}
.default-text{
	color: #000000;
}
.grey-text {
	color: #687281;
}
.red-text {
	padding: 0 1px;
	color: #d83b3b;
}
.tiny-text {
	font-size: 10px;
    line-height: 16px;
}
.image-block {
	width: 100%;
	height: 200px;
	background-image: url(/assets/images/preview.jpg);
	background-position: center;
	background-size: cover;
	border-radius: 8px;
	margin-bottom: 24px;
}
input[name="donationFreq"] {
	display: block;
	position: absolute;
	width: 0;
	height: 0;
}
input[name="donationFreq"] + label {
	width: 100%;
	padding: 8px 16px;
	border: 2px solid #f4f4f4;
	background-color: #e0e3e9;
	border-radius: 8px;
	color: #333333;
	line-height: 1.75rem;
}
input[name="donationFreq"]:checked + label {
	background-color: rgb(87, 39, 175);
	border-color: rgb(87, 39, 175);
	color: #ffffff;
}
input[name="donationFreq"] + label svg {
	margin-right: 8px;
	height: 16px;
	width: 16px;
}
input[name="donationFreq"] + label span {
	font-size:	16px;
	font-weight: 700;
}

.input-block-line {
	border: 1px solid #eaecf1;
	border-radius: 8px;
	position: relative;
}
.input-block-line span{
	display: flex;
	flex: 0;
	padding: 0px 8px;
}
.input-block-line input,
.input-block-line select{
	display: flex;
	flex: 1;
	border: none;
	box-shadow: none;
	width: 100%;
	padding: 8px;
	outline: none;
	border-radius: 8px;
	overflow: hidden;
	background: transparent;
}
.input-block-line + div {
	font-size: 14px;
    line-height: 24px;
	margin-left: 10px;
}
.input-block-line input::-webkit-outer-spin-button,
.input-block-line input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.input-block-line input[type=number] {
  -moz-appearance: textfield;
}
.input-block-line.invalid {
	color: #d83b3b;
	background-color: #fceded;
	margin-bottom: 20px;
}
.input-block-line .invalid-msg {
	position: absolute;
	bottom: -25px;
	left: 0;
	right: 0;
	overflow: hidden;
	display: none;
	color: #d83b3b;
}
.input-block-line .invalid-msg svg {
	font-size: 0.875em;
    line-height: 0.0714285718em;
	height: 1em;
}
.input-block-line.invalid .invalid-msg  {
	display: block;
}
.button-radio button{
	padding: 6px 16px;
	font-weight: 600;
	color: #333333;
	line-height: 24px;
	background: #ffffff;
	border: 1px solid #e5e7eb;
}
.button-radio button:nth-child(1){
	border-top-left-radius: 8px;
	border-bottom-left-radius: 8px;
}
.button-radio button:nth-child(2){
	border-top-right-radius: 8px;
	border-bottom-right-radius: 8px;
}
.button-radio button.active{
	color: #ffffff;
	background: #687281;
}
input:not([type="checkbox"]),
select {
	/* height: 48px; */
}
.input-icon svg{
	color: #687281;
	font-size: 1.25em;
	height: 1em;
}
.confirm-btn,
.modal .modal-block button {
	background: rgb(87, 39, 175);
    color: rgb(255, 255, 255);
    outline-color: rgb(37, 0, 125);
	font-weight: 700;
	font-size: 1rem;
	line-height: 1.75rem;
	padding: 16px;
	border: none;
	border-radius: 8px;
}
.modal {
    display: flex;
    position: fixed;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    background-color: #00000020;
	padding: 16px;
}
.modal .modal-block {
	display: flex;
	max-width: 100%;
	width: 600px;
	margin: auto;
	align-self: center;
	align-items: center;
	flex-direction: column;
	background-color: #fff;
	padding: 8px;
	border-radius: 8px;
	border: 1px solid #e5e7eb;
	text-align: center;
}
.modal .modal-block svg {
	color: #ff4444;
	max-width: 300px;
}
.modal .modal-block p {
	font-size: 1rem;
	line-height: 1.25rem
}
.modal .modal-block #timer {
	font-weight: 800;
	font-size: 1.25rem;
}