﻿html { height: 100%; font-family: 'Inter', sans-serif; font-size: 14px; line-height: 1.4; }
body { min-height: 100%; margin: 0; background-color: #f6f6f6; display: flex; flex-direction: column; }

header { display: flex; width: 100%; max-width: 680px; margin: 30px auto; align-items: center; justify-content: center; }
.header-container { display: flex; align-items: flex-end; }
.header-logo-container { flex: 1; text-align: left; }
.header-menu-container { text-align: right; }
.header-menu-user { padding-right: 15px; font-size: 12px; margin: 8px 0; margin-bottom: 30px; display: block; }
.header-menu { display: flex; list-style: none; padding: 0; }
.header-menu li { margin-right: 5px; }
.header-menu a { border-radius: 3px; padding: 10px 15px; color: #000; text-decoration: none; font-weight: bold; }
.header-menu a:hover { background-color: #eee; }
.header-menu a.selected { background-color: #575656; color: #fff; }

.header-logo { height: 80px; width: 100px; margin-right: 20px; }
.header-title-container { display: flex; flex-direction: column; }
.header-title-container h1 { margin: 0; }
.header-title-container h4 { margin: 0; }

main { width: 100%; max-width: 680px; margin: 0 auto; padding-bottom: 100px; }

fieldset { border: 0; padding: 0; }
legend { font-size: 20px; padding: 0; margin-top: 20px; display: block; }

label { display: inline-block; margin-bottom: 3px; }

.button { cursor: pointer; display: inline-block; line-height: 1.4em; appearance: none; -moz-appearance: none; -webkit-appearance: none; border: 0; font-size: 100%; padding: 10px 20px; font-weight: bold; background-color: #eee; color: #000 !important; text-decoration: none !important; border-radius: 5px; transition: background-color .1s; }
.button:hover { background-color: #ccc; }

.button.save { background-color: #65BEEC; color: #fff !important; }
.button.save:hover { background-color: #33A1D9; }

.button.clear { background-color: transparent; }
.button.clear:hover { background-color: #eee; }

/* Below removes number input increase/decrease buttons */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; -moz-appearance: none; appearance: none; margin: 0; }

.complete-message { border-radius: 3px; padding: 0px 10px; padding-left: 20px; border: 1px solid #94b6af; border-left: 5px solid #20bea1; background-image: url(/public/static/icons/message-check.svg); background-size: 24px; background-position: 14px center; background-repeat: no-repeat; padding-left: 55px; margin-bottom: 10px; }

.error-message { border-radius: 3px; padding: 0px 10px; padding-left: 20px; border: 1px solid #970000; border-left: 5px solid #ff0000; background-image: url(/public/static/icons/message-cross.svg); background-size: 24px; background-position: 14px center; background-repeat: no-repeat; padding-left: 55px; margin-bottom: 10px; }

textarea,
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
.textarea { padding: 8px 14px; font-size: 16px; font-family: 'Inter', sans-serif; box-sizing: border-box; background-color: #fff; border-radius: 5px; border: 1px solid #ccc; max-width: 100%; width: 100%; min-width: 100%; }
textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="password"]:focus { border: 1px solid #40B3ED; }
input:read-only { background-color: #f6f6f6; color: #666; }
.textarea { background-color: #f6f6f6; color: #666; display: block; }
select { font-size: 16px; font-family: 'Inter', sans-serif; width: 100%; box-sizing: border-box; border: 1px solid #cacaca; padding: 8px 12px; padding-right: 8px; border-radius: 5px; -webkit-appearance: none; -moz-appearance: none; appearance: none; background-image: url('/mox/static/svg/arrow-down.svg'); background-position: right 12px center; background-repeat: no-repeat; background-size: 11px; padding-right: 28px !important; }

.flex-columns { display: flex; }
.flex-columns > * { flex: 1 1 100%; }
.flex-columns > * + * { margin-left: 20px; }
.flex-columns { margin-top: 1em; margin-bottom: 1em; }
.flex-columns > p { margin-top: 0; margin-bottom: 0; }

.info-card { border-radius: 5px; border: 1px solid #ccc; flex: 1; margin-bottom: 20px; }
.info-card-header { border-bottom: 1px solid #ccc; padding: 10px 16px; display: flex; align-items: center; min-height: 28px; }
.info-card-content { padding: 16px; display: flex; }
.info-card-content-column { flex: 1; }
.info-card-grid { display: grid; grid-gap: 10px 40px; grid-template-columns: min-content; }
.info-card-grid-1 { grid-column: 1; margin: 0; font-size: 100%; color: #555; white-space: nowrap; }
.info-card-grid-2 { grid-column: 2; }
.info-box { border-radius: 3px; padding: 10px 20px; padding-left: 16px; border: 1px solid #4893ec; border-left-color: rgb(72, 147, 236); border-left-style: solid; border-left-width: 1px; border-left: 5px solid #4893ec; background-size: 24px; background-position: 14px center; background-repeat: no-repeat; margin-bottom: 10px; }
.info-box:before { content: "\f05a"; display: inline-block; font-family: "Font Awesome 5 Pro"; font-size: 20px; vertical-align: sub; margin-right: 10px; color: rgb(72, 147, 236); }

.pay-button { background-color: #65BEEC; color: #fff !important; font-size: 1.1rem; font-weight: 500; padding: 8px; border-radius: 5px; border: 0; cursor: pointer; min-width: 72px; }

.pay-button:hover { background-color: #3a96c6; }

.flex-radio { display: flex; }
.flex-radio > * + * { margin-left: 16px; }
.flex-radio > * { align-items: center; }
.flex-radio input[type="radio"] { vertical-align: middle; }
.flex-radio label { vertical-align: sub; }

.flatpicker-clearable { position: relative; display: block; }
.flatpicker-clearable button { cursor: pointer; font-size: 20px; line-height: 28px; font-family: sans-serif; top: 50%; transform: translateY(-50%); border-radius: 3px; position: absolute; right: 3px; background-color: transparent; width: 28px; height: 28px; appearance: none; -webkit-appearance: none; -moz-appearance: none; border: 0; }
.flatpicker-clearable button:hover { background-color: #eee; }
.flatpicker-clearable.inline { display: inline-block; }
input[type="date"].flatpickr-mobile,
input[type="text"].date-time.flatpickr-input,
input[type="datetime-local"].flatpickr-mobile,
input[type="datetime"].flatpickr-mobile { min-height: 32px; line-height: 1em !important; }
input[type="date"].flatpickr-mobile { min-width: 120px; }

/*************
    BOX
**************/
.box { border-radius: 10px; position: relative; background-color: #fff; padding: 20px; margin-bottom: 20px; }
.box::before { position: absolute; z-index: -1; content: ""; position: absolute; top: 0; bottom: 0; left: 0; right: 0; box-shadow: rgba(0, 0, 0, .05) 0 0 16px; border-radius: 10px; }
.box.join { border-bottom-left-radius: 0; border-bottom-right-radius: 0; margin-bottom: 0; border-bottom: 1px solid #e0e0e0; }
.box.join + .box { border-top-left-radius: 0; border-top-right-radius: 0; }

.box h1 { margin: 0; line-height: 1.215em; margin: 3px 0; }

.box .info { display: flex; margin: 1em -20px; padding: 0 20px; padding-top: 20px; border-top: 1px solid #eee; align-items: center; }
.box .info .far { font-size: 20px; margin-right: 15px; }

.field-validation-error { color: red; }
input.input-validation-error,
textarea.input-validation-error,
select.input-validation-error { border-color: #f9a7a7; }

.validation-summary-errors { background-color: #ffd2d2; padding: 10px; border-radius: 5px; border: 1px solid #ffa2a2; }
.validation-summary-errors ul { margin: 0; padding: 0; padding-left: 10px; }

.attachment-upload-dropzone { position: relative; cursor: pointer; background-color: #fafafa; display: block; width: 100%; border: 1px dashed #bbb; text-align: center; border-radius: 3px; padding: 10px 20px; box-sizing: border-box; }
.attachment-upload-dropzone:hover { border-color: #999; background-color: #eee; }
.attachment-upload-input { cursor: pointer; position: absolute; opacity: 0; width: 100%; height: 100%; left: 0; right: 0; top: 0; bottom: 0; display: block; }
.attachment-upload-form { position: relative; }
.attachment-upload-form.loading { pointer-events: none; background-image: url('/mox/static/svg/loader-button-black.svg'); background-repeat: no-repeat; background-size: 40px; background-position: 50%; }
.attachment-upload-form.loading > :not(.attachment-upload-form-loader) { opacity: 0.25; }
.attachment-upload-form-loader { display: none; position: absolute; left: 0; right: 0; top: calc(50% + 27px); text-align: center; font-weight: bold; }
.attachment-upload-form.loading .attachment-upload-form-loader { display: block; }
.attachment-upload-form .fa-exclamation-triangle { display: none; }

.attachment-file-list { padding: 0; margin: 16px 0; list-style: none; }
.attachment-file { margin-bottom: 5px; border: 1px solid #cacaca; border-radius: 3px; display: flex; overflow: hidden; }
.attachment-file-link { flex: 1; display: flex; align-items: center; padding: 6px 10px; text-decoration: none; }
.attachment-file-link:hover { background-color: #fafafa; }
.attachment-file-link.border { border: 1px solid #cacaca; margin-bottom: 5px; border-radius: 3px; display: inline-flex; margin-right: 10px; padding: 3px 8px; }
.attachment-file-icon { width: 16px; height: 24px; margin-right: 10px; background-image: url('/Public/Static/icons/file.svg'); background-size: 18px; background-repeat: no-repeat; background-position: center; }
.attachment-file-title { flex: 1; color: #000; word-wrap: break-word; }
.attachment-file-delete { cursor: pointer; -webkit-appearance: none; -moz-appearance: none; appearance: none; border: 0; background-color: transparent; width: 36px; background-image: url('/Public/Static/icons/delete.png'); background-size: 20px; background-repeat: no-repeat; background-position: center; }
.attachment-file-delete:hover { background-color: #ff8a8a; }

.green { color: green; }

.summary-title-container { display: flex; }
.summary-title { display: flex; flex-direction: column; margin: 0; flex: 1; font-size: 22px; }
.summary-title-subtitle { font-size: 12px; color: #666; }

.buttons { text-align: right; margin: -20px; margin-top: 20px; padding: 20px; border-top: 1px solid #eee; }
.buttons p { margin: 0; }

.link { color: #666; }
.link:hover { color: #FFD500 }
.link-button { border-radius: 2px; padding: 10px; border: 2px solid #FFD500; background-color: transparent; cursor: pointer; font-family: 'Inter', serif; font-size: 1.2rem; font-weight: 500; transition-duration: 0.3s; user-select: none; text-decoration: none; color: black; margin-top: 10px !important; }
.link-button:hover { background-color: #FFD500; transition-duration: 0.3s; }
.link-button:active { border: 2px solid #ebc500; background-color: #ebc500; transition-duration: 0.3s; }


@media only screen and (max-device-width : 680px) {
	.box { border-radius: 0; }

	.header-title-container h1 { font-size: 20px; }
}

@media only screen and (max-device-width : 568px) {
	.flex-columns { flex-direction: column; }
	.flex-columns > * + * { margin-left: 0; }
	.flex-columns > p + p { margin-top: 1em; }
}

.gift-info { display: flex; flex-direction: row; gap: 1.5em; height: 150px; overflow: hidden; justify-content: space-evenly; }
.gift-image { flex: 1 1 0px; display: flex; justify-content: center;}
.gift-text { flex: 1 1 0px; }
.gift-text > h4 { line-height: 4px }
