
/* Forms */

.millco_form {
	display: flex;
	flex-direction: column;
	gap: 20px;
	max-width: 84ch;

}

fieldset.no_border{
	border: none;
	padding: 0;
	margin: 0;
}

fieldset.horizontal{
	display: flex;
	flex-direction: row;
	gap: 8px;
	align-items: center;
}

.millco_form > div{
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.form_row.align_right{
	align-items: end;
}

.form_row_horizontal{
	flex-direction: row !important;
}

.enq_header{
	font-weight: var(--strong);
}

.millco_form label,
.millco_form .form_group_label,
.millco_form .instruction{
	font-size: 13.125px;
	color: var(--dark);
}

.required label:after{
	content: ' *';
	color: var(--theme);
}

.form_intro{
	display: flex;
	padding: 20px;
	flex-direction: column;
	gap: 8px;
	color: var(--grey-black, #222);
	font-size: 15px;
	font-style: normal;
	font-weight: 400;
	line-height: 120%;
	letter-spacing: 0.15px;
	background: var(--pale-blue, #E5F3FF);
}

.form_intro_title{
	font-weight: var(--strong);
}

.form_section_title {
	border-bottom: 1px solid var(--grey-light, #CCC);
	padding-bottom: 8px;
	text-wrap: auto;
	line-height: 1.3;
}

/* all input fields */

input[type="text"], input[type="email"], input[type="tel"], input[type="number"], input[type="date"], input[type="time"], input[type="url"], input[type="search"], input[type="password"], textarea, select {
	border: 1px solid var(--grey-light, #CCC);
	background: #FFF;
	border-radius: 1px;
	padding: 4px;
}

input[type="text"]:focus, input[type="email"]:focus, input[type="tel"]:focus, input[type="number"]:focus, input[type="date"]:focus, input[type="time"]:focus, input[type="url"]:focus, input[type="search"]:focus, input[type="password"]:focus, textarea:focus, select:focus {
	border: 1px solid var(--blue-dark, #2D6293);
	outline: none;
}

input[type="radio"], input[type="checkbox"] {
	accent-color: var(--green);
}

input.small{
	width: 100px;
}


.LoginRegisterPro .Inputfield:not(.InputfieldSubmit) {
	width: 100%;
	background-color: #fff !important;
	border: 1px solid #fff !important;
	padding:8px 0 !important;
	
}

.LoginRegisterPro .Inputfield input[type="text"], .LoginRegisterPro .Inputfield input[type="email"], .LoginRegisterPro .Inputfield input[type="tel"], .LoginRegisterPro .Inputfield input[type="number"], .LoginRegisterPro .Inputfield input[type="date"], .LoginRegisterPro .Inputfield input[type="time"], .LoginRegisterPro .Inputfield input[type="url"], .LoginRegisterPro .Inputfield input[type="search"], .LoginRegisterPro .Inputfield input[type="password"], .LoginRegisterPro .Inputfield textarea, .LoginRegisterPro .Inputfield select {
	padding:0.25rem 0.5rem;
}

.LoginRegisterLinks {
	margin: 2rem 1rem;
	padding: 0;
}

.LoginRegisterLinks li {
	display: block;
}

.InputfieldMaxWidth {
	width: 100%;
	max-width: 640px;
}

.LoginRegisterNotice {
	border-radius: 1rem;
	background-color: #eee;
}


/* Ensures the increment/decrement arrows always display */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  opacity: 1;
  color:var(--theme);
}

/* .millco_form label.label_for_dyn_options{
	font-size: 20px;
	padding:8px;
	background-color:var(--blue-pale);
	margin-bottom: 20px;
} */

.checkbox_group{
	display: flex;
	gap: var(--gap-small);
	width: 100%;
	flex-direction: column;
}

.checkbox_group > label {
	color: var(--blue-dark);
	display: flex;
	gap: 12px;
	align-items: center;
}

.checkbox_group_vertical{
	flex-direction: column;
}

@media (min-width: 480px) {
	.checkbox_group_horizontal{
		flex-direction: row;
		flex-wrap: wrap;
	}
}

.checkbox_group_vertical > label > input {
	margin-left: 0;
}

/**
Toggle switch adapted from
https://codepen.io/alvarotrigo/pen/abVPyaJ
*/

.toggle{
	display: inline-flex;
}

.toggle input[type=checkbox]{
  height: 0;
  width: 0;
  visibility: hidden;
}

.toggle label {
  cursor: pointer;
  text-indent: -9999px;
  width: 36px;
  height: 20px;
  background: white;
  display: block;
  border:2px solid var(--active);
  border-radius: 10px;
  position: relative;
}

.toggle label:after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  background: var(--active);
  border-radius: 50%;
  transition: 0.3s;
}

.toggle input:checked + label {
  background: var(--green);
  border-color:var(--green);
}

.toggle input:checked + label:after {
  left: calc(100% - 2px);
  transform: translateX(-100%);
  background:white;
}

.toggle label:active:after {
  width: 16px;
}

.form_row_optional{
	display: none;
	height: 0;
	flex-direction: column;
	gap: 8px;
	padding: 8px 0 0 20px;
	transition: height 0.3s ease-in-out;
}

.form_row_optional_visible{
	display: flex;
	height: auto;
	padding:1rem;
	background: var(--pale-blue, #E5F3FF);
}

.save_butt_container{
	display: flex;
	flex-direction: row;
	align-items: end;
}

.saved_timestamp{
	padding:0;
	font-size: 12px;
	color: var(--grey);
}

/* Form bits that were in old Boostrap but aren't in Bootstrap 5 */

.form-group{
	margin-bottom: var(--gap-small);
}

.form-control{
	width: 100%;
}

.w-fit{
	width: fit-content;
}



.input-group {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	width: 100%;
  }
  .input-group > .form-control,
  .input-group > .form-select,
  .input-group > .form-floating {
	position: relative;
	flex: 1 1 auto;
	width: 1%;
	min-width: 0;
  }
  .input-group > .form-control:focus,
  .input-group > .form-select:focus,
  .input-group > .form-floating:focus-within {
	z-index: 5;
  }
  .input-group .btn {
	position: relative;
	z-index: 2;
  }
  .input-group .btn:focus {
	z-index: 5;
  }
  
  .input-group-text {
	display: flex;
	align-items: center;
	padding: 0.375rem 0.75rem;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	color: var(--bs-body-color);
	text-align: center;
	white-space: nowrap;
	background-color: var(--bs-tertiary-bg);
	border: var(--bs-border-width) solid var(--bs-border-color);
	border-radius: var(--bs-border-radius);
  }
  
  .input-group-lg > .form-control,
  .input-group-lg > .form-select,
  .input-group-lg > .input-group-text,
  .input-group-lg > .btn {
	padding: 0.5rem 1rem;
	font-size: 1.25rem;
	border-radius: var(--bs-border-radius-lg);
  }
  
  .input-group-sm > .form-control,
  .input-group-sm > .form-select,
  .input-group-sm > .input-group-text,
  .input-group-sm > .btn {
	padding: 0.25rem 0.5rem;
	font-size: 0.875rem;
	border-radius: var(--bs-border-radius-sm);
  }
  
  .input-group-lg > .form-select,
  .input-group-sm > .form-select {
	padding-right: 3rem;
  }
  
  .input-group:not(.has-validation) > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),
  .input-group:not(.has-validation) > .dropdown-toggle:nth-last-child(n+3),
  .input-group:not(.has-validation) > .form-floating:not(:last-child) > .form-control,
  .input-group:not(.has-validation) > .form-floating:not(:last-child) > .form-select {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
  }
  .input-group.has-validation > :nth-last-child(n+3):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),
  .input-group.has-validation > .dropdown-toggle:nth-last-child(n+4),
  .input-group.has-validation > .form-floating:nth-last-child(n+3) > .form-control,
  .input-group.has-validation > .form-floating:nth-last-child(n+3) > .form-select {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
  }
  .input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
	margin-left: calc(-1 * var(--bs-border-width));
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
  }
  .input-group > .form-floating:not(:first-child) > .form-control,
  .input-group > .form-floating:not(:first-child) > .form-select {
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
  }
  
  .valid-feedback {
	display: none;
	width: 100%;
	margin-top: 0.25rem;
	font-size: 0.875em;
	color: var(--bs-form-valid-color);
  }
  
  .valid-tooltip {
	position: absolute;
	top: 100%;
	z-index: 5;
	display: none;
	max-width: 100%;
	padding: 0.25rem 0.5rem;
	margin-top: 0.1rem;
	font-size: 0.875rem;
	color: #fff;
	background-color: var(--bs-success);
	border-radius: var(--bs-border-radius);
  }
  
  .was-validated :valid ~ .valid-feedback,
  .was-validated :valid ~ .valid-tooltip,
  .is-valid ~ .valid-feedback,
  .is-valid ~ .valid-tooltip {
	display: block;
  }
  
  .was-validated .form-control:valid, .form-control.is-valid {
	border-color: var(--bs-form-valid-border-color);
	padding-right: calc(1.5em + 0.75rem);
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: right calc(0.375em + 0.1875rem) center;
	background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
  }
  .was-validated .form-control:valid:focus, .form-control.is-valid:focus {
	border-color: var(--bs-form-valid-border-color);
	box-shadow: 0 0 0 0.25rem rgba(var(--bs-success-rgb), 0.25);
  }
  
  .was-validated textarea.form-control:valid, textarea.form-control.is-valid {
	padding-right: calc(1.5em + 0.75rem);
	background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
  }
  
  .was-validated .form-select:valid, .form-select.is-valid {
	border-color: var(--bs-form-valid-border-color);
  }
  .was-validated .form-select:valid:not([multiple]):not([size]), .was-validated .form-select:valid:not([multiple])[size="1"], .form-select.is-valid:not([multiple]):not([size]), .form-select.is-valid:not([multiple])[size="1"] {
	--bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1'/%3e%3c/svg%3e");
	padding-right: 4.125rem;
	background-position: right 0.75rem center, center right 2.25rem;
	background-size: 16px 12px, calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
  }
  .was-validated .form-select:valid:focus, .form-select.is-valid:focus {
	border-color: var(--bs-form-valid-border-color);
	box-shadow: 0 0 0 0.25rem rgba(var(--bs-success-rgb), 0.25);
  }
  
  .was-validated .form-control-color:valid, .form-control-color.is-valid {
	width: calc(3rem + calc(1.5em + 0.75rem));
  }
  
  .was-validated .form-check-input:valid, .form-check-input.is-valid {
	border-color: var(--bs-form-valid-border-color);
  }
  .was-validated .form-check-input:valid:checked, .form-check-input.is-valid:checked {
	background-color: var(--bs-form-valid-color);
  }
  .was-validated .form-check-input:valid:focus, .form-check-input.is-valid:focus {
	box-shadow: 0 0 0 0.25rem rgba(var(--bs-success-rgb), 0.25);
  }
  .was-validated .form-check-input:valid ~ .form-check-label, .form-check-input.is-valid ~ .form-check-label {
	color: var(--bs-form-valid-color);
  }