
/* ========================== FORM CLASSES ====================
customized 2-3-2024
_V-7.0.1 :: ZETA PKG
 
zeta_form
oneline small medium large
TODO tiny giant  

rounded rounded-errors
corners corner-errors
subtle subtle-errors

wide_errors

no-border 
error-border
no-error-border 
brand-color-border

light dark 

//////////////////////// html form opts
input/select/radio must have: class="form-control"
forms must have .zeta_form

// formatting
.generate_password + #pass1 #pass2 + #pass_helper .password
.strict_email

.format_number_one
.format_number_two
.format_number_three

.format_cell_phone - (000)-000-0000
.format_land_phone - (000)-000-0000 x00000

.format_money_mil
.format_money_hk
.format_money_k - $0,000.00

.spinner_money

.limit_text + .charcount
.limit_newlines + .linesused

style for UI spinners:
show_dollarsign | show_percentsign

*/

.ccpy {
    text-align: center;
    display: inline-block;
    font-size: 11px;
    color: #4b4b4b;
    margin: 4px 0 0 0;
    padding: 1px 12px;
    background: #fff7b4;
    font-weight: normal !important;
    cursor: pointer;
    font-family: monospace;
    -webkit-user-select: all !important;
    -moz-user-select: all !important;
    -ms-user-select: all !important;
    user-select: all !important;
}




.help-text { }
.detail-text {
    font-size: 8px !important;
    margin: 0 0 0 0;
    padding: 0px 5px 0 5px;
    float: right;
    line-height: 15px;
	display: block;
	text-align: right;
	background: rgb(0 0 0 / 3%);
	color: #8e8e8e
}
.detail-text span.green, 
.notice.green{ color: #0ca500;}
.detail-text span.grey, 
.notice.grey{ color: #808080;}
.detail-text span.blue, 
.notice.blue{ color: #0093d6;}
.detail-text span.light-blue, 
.notice.light-blue{ color: #56c8fd;}
.detail-text span.red, 
.notice.red{ color: #6B0001;}
.detail-text span.bright-red, 
.notice.bright-red{ color: #a20002;}
.detail-text span.black, 
.notice.black{ color: #000 !important;}


.form.dark .detail-text {
	background: rgb(255 255 255 / 3%);
	color: #d5d5d5;
}
.form.dark .detail-text span.green, 
.form.dark .notice.green{ color: #0ca500;}
.form.dark .detail-text span.grey, 
.form.dark .notice.grey{ color: #808080;}
.form.dark .detail-text span.blue, 
.form.dark .notice.blue{ color: #0093d6;}
.form.dark .detail-text span.light-blue, 
.form.dark .notice.light-blue{ color: #56c8fd;}
.form.dark .detail-text span.red, 
.form.dark .notice.red{ color: #6B0001;}
.form.dark .detail-text span.bright-red, 
.form.dark .notice.bright-red{ color: #a20002;}



.form.light .detail-text {
	background: rgb(200 200 200 / 15%);
	color: #000;
}
.form.light .detail-text span.green, 
.form.light .notice.green{ color: #5acc00;}
.form.light .detail-text span.grey, 
.form.light .notice.grey{ color: #b4b4b4;}
.form.light .detail-text span.blue, 
.form.light .notice.blue{ color: #3bb1e8;}
.form.light .detail-text span.light-blue, 
.form.light .notice.light-blue{ color: #87efff;}
.form.light .detail-text span.red, 
.form.light .notice.red{ color: #e45152;}
.form.light .detail-text span.bright-red, 
.form.light .notice.bright-red{ color: #ff3636;}


.form.details-behind .detail-text {
    margin: -15px 0 0 0; }


.form.large.details-behind .detail-text {
    margin: -15px 2px 0 0; }


.form.medium.details-behind .detail-text { }

.form.details-behind .form-group.spinner-wrap .detail-text, 
.form.details-behind .form-group.textarea-wrap .detail-text{
    margin: -15px 25px 0 0; }



.form.details-behind.small .detail-text,
.form.details-behind.sm .detail-text{
    margin: -7px 0 0 0; 
line-height: 4px;}
	
	
	
.form-group.error .detail-text .required {
	 color: #6B0001;
}

/* all fields with error validation need a wrap to contain the error correctly */
.fieldwrap { margin: 0 0 0 0; padding: 0 0 0 0; position: relative; display: block; }

.fieldwrap.selectwrap {
	display: block;
}


.form .form-control-icon {
    font-size: 15px;
    position: absolute;
    left: 7px; 
    top: 14px;
    z-index: 3;
	opacity: 0.5;
	width: 25px;
	pointer-events: none;
}
.form .form-control-icon.right {
    right: 3px;
    top: 11px;
    width: 25px;
    left: unset;
}
.form .form-control-icon.allow_click {
	pointer-events:auto;
}
.form .form-control-icon.allow_click:hover {
	cursor: pointer;
}


.form .select2-wrapper.has_icon .form-control-icon { 
    top: unset;
    bottom: 11px;
    left: 7px;
} 




.form.small .form-control-icon {
  left: 4px;
  top: 7px;
}
.form.small .form-control-icon.right {
}




.form.small .has_icon input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.sm .has_icon input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.small .has_icon.selectwrap select, 
.form.sm .has_icon.select2-wrapper .select2-search__field, 
.form.small .has_icon.select2-wrapper .select2-search__field {
	padding-left:32px;
}
.form.small .has_icon_right input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.sm .has_icon_right input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.small .has_icon_right.selectwrap select, 
.form.sm .has_icon_right.select2-wrapper .select2-search__field , 
.form.small .has_icon_right.select2-wrapper .select2-search__field  {
	padding-left:32px;
}

.form.medium .form-control-icon {
}
.form.medium .form-control-icon.right {
}

.form.medium .has_icon input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.md .has_icon input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.medium .has_icon.selectwrap select, 
.form.medium .has_icon.select2-wrapper .select2-search__field {
	padding-left:32px;
}

.form.medium .has_icon_right input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.md .has_icon_right input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.medium .has_icon_right.selectwrap select, 
.form.medium .has_icon_right.select2-wrapper .select2-search__field {
	padding-right:32px;
}


.form.large .form-control-icon {
    font-size: 20px;
}
.form.large .form-control-icon.right {
}

.form.large .has_icon input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.lg .has_icon input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.large .has_icon.selectwrap select, 
.form.large .has_icon.select2-wrapper .select2-search__field {
	padding-left:35px;
}
.form.large .has_icon_right input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.lg .has_icon_right input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.large .has_icon_right.selectwrap select, 
.form.large .has_icon_right.select2-wrapper .select2-search__field {
	padding-left:35px;
}




.ui-spinner.show_dollarsign:before{ 
    content: '$';
    position: absolute;
    left: 10px;
    top: 11px;
    font-size: 14px;
    z-index: 999;
    display: block;
    color: #999;
}

.form.medium .ui-spinner.show_dollarsign input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.md .ui-spinner.show_dollarsign input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]) {
	padding-left:20px;
}


.ui-spinner.show_percentsign:before{ 
    content: '%';
    position: absolute;
    left: 10px;
    top: 11px;
    font-size: 14px;
    z-index: 999;
    display: block;
    color: #999;
}

.form.medium .ui-spinner.show_percentsign input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.md .ui-spinner.show_percentsign input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]) {
	padding-left:25px;
}







/* ----------------------- DETAIL TEMPLATES -------------------- */
/* box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset; */
label.error{ display: none}



.form.no-border textarea,
.form.no-border select,
.form.no-border input,
.form.no-error-border .form-group.error textarea,
.form.no-error-border .form-group.error select,
.form.no-error-border .form-group.error input,
.form.no-error-border .cb_wrap{
	/*  border: none; 	border-style: none;	border-width: 0px;*/
	border-color: transparent !important; 
}

.form.rounded textarea,
.form.rounded select,
.form.rounded .ms-options-wrap,
.form.rounded input:not(.btn),
.form.rounded .cb_wrap {
	border-radius: 3px;
}
.form.rounded-errors label.error{
 	border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
}


.form.corners textarea,
.form.corners select,
.form.corners .ms-options-wrap,
.form.corners input {
	border-radius: 0px;
}
.form.corner-errors label.error{
 	border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
}



.form .styled.form-control optgroup[label], 
.form .styled.form-control [disabled]{
   opacity: 0.5;
   font-style: inherit;
   font-weight: 300;
   text-shadow: none
}
.form select[multiple] option[disabled], 
.form select[multiple] option[disabled]:checked {
	background: none;
	background-color:transparent;
	text-align: center;
	font-family: Arial, Font Awesome\ 6 Pro; 
	padding: 4px 0 4px 0;
	margin: 0 0 4px 0;
	border-bottom:1px dashed #ccc;
	font-size: 0.7rem;
}
.form .ms-options-wrap button span{
	font-family: Arial, Font Awesome\ 6 Pro; 
}


/* ----------------------- SIZE TEMPLATES -------------------- */
.form input[type=date] {
	padding-right: 0;
}
@media (max-width: 767px) {
.form input[type=date] {
	max-width: 100%;
}
}



.form.minimal.large .btn.large,
.form.minimal.large .btn.lg,
.form.minimal.lg .btn.large,
.form.minimal.lg .btn.lg {
	    padding: 17px 17px 17px 17px;
}
 
.form.minimal.medium .btn.medium,
.form.minimal.medium .btn.md,
.form.minimal.md .btn.medium,
.form.minimal.md .btn.md {
	    padding: 15px 15px 15px 15px;
} 
 
.form.minimal.small .btn.small,
.form.minimal.small .btn.sm,
.form.minimal.sm .btn.small,
.form.minimal.sm .btn.sm {
	   padding: 9px 9px 9px 9px;
}


.form .ms-options-wrap > .ms-options > ul input[type="checkbox"] {
    margin: 0 5px 0 0;
    position: absolute;
    left: 4px;
    top: 4px;
}



.form.small select,
.form.small .ms-options-wrap,
.form.small textarea,
.form.small input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.sm select,
.form.sm .ms-options-wrap,
.form.sm textarea,
.form.sm input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]){
	height: 30px;
	margin: 0px 0px 0px 0px;
	padding: 0 8px 0 8px;
	font-size: 12px;
	line-height: 13px;
	border-width: 1px;
}
.form.small .cb_wrap, 
.form.sm .cb_wrap{border-width: 2px;  margin: 0 0 0 0; height: 30px;}
.form.sm label.cb, 
.form.small label.cb { padding: 3px 4px;
} 



.form.small select[multiple] {
 height: 100px;
}


.form.small input[type=radio].circular, 
.form.small input[type=checkbox].circular, 
.form.sm input[type=radio].circular, 
.form.sm input[type=checkbox].circular{
    width: 15px;
    height: 15px;
    border-radius: 15px !important;
}



.form.small textarea,
.form.sm textarea{ padding-top: 4px;} 

.form.small.oneline .btn.submit_form,
.form.sm.oneline .btn.submit_form{
	height: 31px;
	width: 100%;
}

.form.oneline .tos_block { margin-top: 10px !important; }


.form.medium select,
.form.medium .ms-options-wrap,
.form.medium input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.md select,
.form.md .ms-options-wrap,
.form.md input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]){
	height: 42px; /* factor in the border*/
	margin: 0px 0px 0px 0px;
	padding: 0 10px 0 10px;
	font-size: 13px;
	line-height: 18px;
	border-width: 2px;
}

.form.medium select[multiple] {
 height: 150px;
}

.form.medium input[type=radio].circular, 
.form.medium input[type=checkbox].circular, 
.form.md input[type=radio].circular, 
.form.md input[type=checkbox].circular{
    width: 18px;
    height: 18px;
    border-radius: 18px !important;
}

.form.medium textarea,
.form.md textarea{
	height: 125px; /* factor in the border*/
	margin: 0px 0px 0px 0px;
	padding: 10px 0px 10px 10px;
	font-size: 13px;
	line-height: 18px;
	border-width: 2px;
} 
.form.medium select.multiple,
.form.md select.multiple{
	height: 125px; /* factor in the border*/
	margin: 0px 0px 0px 0px;
	padding: 0px 0px 0 0px;
	font-size: 13px;
	line-height: 18px;
	border-width: 2px;
}

.form.medium .cb_wrap, 
.form.md .cb_wrap{border-width: 2px;  margin: 0 0 0 0; height: 42px;}
.form.md label.cb, 
.form.medium label.cb { padding: 9px 5px;
}


@media (max-width: 768px) {
	
/* could make this slimmer on devices
	.form.medium select.multiple,
	.form.md select.multiple{
		height: 42px; 
	}*/
	
}


.form.medium textarea,
.form.md textarea{ padding-top: 7px;} 



.form.medium.oneline .btn.submit_form, 
.form.md.oneline .btn.submit_form {
	height: 43px;
	width: 100%;
}


.form.large select,
.form.large .ms-options-wrap,
.form.large input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.lg select,
.form.lg .ms-options-wrap,
.form.lg input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]){
	height: 50px;
	margin: 0px 0px 0px 0px;
	padding: 0 15px 0 16px;
	font-size: 15px;
	line-height: 20px;
	border-width: 3px;
}

.form.large select[multiple] {
 height: 150px;
}

.form.large input[type=radio].circular, 
.form.large input[type=checkbox].circular, 
.form.lg input[type=radio].circular, 
.form.lg input[type=checkbox].circular{
       width: 21px;
    height: 21px;
    border-radius: 26px !important;
}




.form.large textarea,
.form.lg textarea, 
.form.large select.multiple,
.form.lg select.multiple{
	height: 220px;
	margin: 0px 0px 0px 0px;
	padding: 0 15px 0 16px;
	font-size: 15px;
	line-height: 20px;
	border-width: 3px;
}
/*.form.lg .cb_wrap, 
.form.large .cb_wrap{ border-width: 2px; margin: 0 0 0 0; height: 50px;}*/
.form.lg label.cb, 
.form.large label.cb { padding: 10px 7px;
}
.form.large label.cb span {    position: relative;
    top: -4px; 
}

.form.large textarea, 
.form.lg textarea{ padding-top: 10px;} 


.form.large.oneline .btn.submit_form,
.form.lg.oneline .btn.submit_form{
	height: 52px;
	width: 100%;
}


.form select[multiple].large {
 height: 200px;
}

.form select[multiple].larger {
 height: 300px;
}

.form.oneline { padding: 0 0 0 0; }

.form.oneline .msgbox.minni {
	position: relative;
    bottom: 15px;
}

.form.oneline input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]){
	margin: 0 0 0 0;
}



.form.dark .cb_wrap a{
	color: #65d3ff;
}

.form.light .cb_wrap  a {
	color: #407cff;
} 


.form.dark .form-segment {
    background: #0000001a;
    padding: 10px 10px 0px 10px;
}

.form.dark .cb_wrap {
    background: rgba(0, 0, 0, 1);
	color: #fff; 
}
.form.dark.subtle .cb_wrap {
     background-color: rgba(0, 0, 0, 0.45);
}
   
.form.light .form-segment {
    background: #a2a2a21a;
    padding: 10px 10px 10px 10px;
}

.form.light .cb_wrap {
    background: #a2a2a21a;
}

.form-segment:after { display: block; clear: both; content: " ";
}


.form.light .form select[multiple] option:checked {
      background-color: rgb(0 0 0 / 15%) !important;
    color: rgb(143 143 143) !important;
}

 .form.dark .form select[multiple] option:checked {
      background-color: rgb(0 0 0 / 33%) !important;
    color: rgb(143 143 143) !important;
} 


/* ----------------------- dark -------------------- */
.boxedin.dark .arrow-element-down {
    border-top-color:rgba(0,0,0,0.24) !important;
}

@media (max-width: 767px) {
	.mobile-boxedin.dark .arrow-element-down {
		border-top-color:rgba(0,0,0,0.24) !important;
	}
}

.form.dark input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.dark select option, 
.form.dark select, 
.form.dark textarea, 
.form.dark .ms-options-wrap{
	color: #fff;
	border-color:#3A3A3A;
}



.form.dark .cb_wrap { border-style: solid; border-color:#3A3A3A;}

.form.dark .counter_under_textbox{
	background: #383838;
    color: #ccc;
}
.form.dark .counter_inside_textbox{
	background: #383838;
    color: #ccc;
}


.form.dark textarea,
.form.dark select,
.form.dark .ms-options-wrap,
.form.dark .ms-options-wrap,
.form.dark input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.dark .cb_wrap,
.form.dark .select2.select2-container{
 background-color: rgba(0, 0, 0, 1);
}

.form.dark .select2.select2-container {
  border-color: #000;
}




.form.dark.subtle textarea,
.form.dark.subtle select,
.form.dark.subtle .ms-options-wrap,
.form.dark.subtle input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]) {
 background-color: rgba(0, 0, 0, 0.45);
}

.form.dark .ms-options-wrap > .ms-options {
 background-color: #3b3b3b;
}

.form.dark .ms-options-wrap.ms-has-selections > button {
    color: #fff;
}

.form.dark .ms-options-wrap > .ms-options > ul li.selected label{
    background-color: #99c8ff; color: #000;
}
.form.dark .ms-options-wrap > .ms-options > ul label:hover {
    background-color: #d1e6ff; color: #000;
	cursor: pointer;
}




.form.dark textarea:hover,
.form.dark select:hover,
.form.dark .ms-options-wrap:hover,
.form.dark input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]):hover,
.form.dark .cb_wrap:hover {
  color: #DADADA; background: rgba(0, 0, 0, 1);
	border-color:#858585;
}



.form.dark.subtle textarea:hover,
.form.dark.subtle select:hover,
.form.dark.subtle .ms-options-wrap:hover,
.form.dark.subtle input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]):hover,
.form.dark.subtle .cb_wrap:hover {
  color: #DADADA; background: rgba(0, 0, 0, 1);
	border-color:#858585;
}

.form.dark select:invalid, 
.form.dark input::placeholder, 
.form.dark textarea::placeholder { 
	color: #7d7d7d;  }


.form.dark label.error{
 	background: #6B0001;
    color: #fff;
}






/* ----------------------- light -------------------- */
.boxedin.light .arrow-element-down {
    border-top-color:rgba(255,255,255,0.64) !important;
}

@media (max-width: 767px) {
	.mobile-boxedin.light .arrow-element-down {
		border-top-color:rgba(255,255,255,0.64) !important;
	}
}



.form.light input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
.form.light select option, 
.form.light select, 
.form.light textarea, 
.form.light .cb_wrap {
	color: #212121;
	border-color:#C6C6C6;
	border-style: solid;
}


.form.light .counter_under_textbox{
	background: #a2a2a21a;
    color: #424242;
}

.form.light .counter_inside_textbox{
	background: #f6f6f6;
    color: #919191;
}



.form.light textarea,
.form.light select,
.form.light .ms-options-wrap,
.form.light .ms-options-wrap,
.form.light input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.light .cb_wrap,
.form.light .select2.select2-container{
 background-color: rgba(255, 255, 255, 1);
}
.form.light .select2.select2-container {
  border-color: #ccc;
}



.form.light.subtle textarea,
.form.light.subtle select,
.form.light.subtle .ms-options-wrap,
.form.light.subtle .ms-options-wrap,
.form.light.subtle input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
.form.light.subtle .cb_wrap {
 background-color: rgba(255, 255, 255, 0.55);
}

.form.light textarea:hover,
.form.light select:hover, 
.form.light .ms-options-wrap:hover, 
.form.light .ms-options-wrap:hover,
.form.light input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]):hover,
.form.light .cb_wrap:hover {
  color: #000; background: rgba(255, 255, 255, 1);
	border-color:#8e8e8e;
}
.form.light.subtle textarea:hover,
.form.light.subtle select:hover,
.form.light.subtle .ms-options-wrap:hover,
.form.light.subtle .ms-options-wrap:hover,
.form.light.subtle input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]):hover,
.form.light.subtle .cb_wrap:hover {
  color: #000; background: rgba(255, 255, 255, 1);
	border-color:#8e8e8e;
}

.form.light .ms-options-wrap > .ms-options {
 background-color: #fff;
}
.form.light .ms-options-wrap.ms-has-selections > button {
    color: #000; 
}
.form.light .ms-options-wrap > .ms-options > ul li.selected label {
    background-color: #0075ff; color: #fff;
} 
.form.light .ms-options-wrap > .ms-options > ul label:hover {
    background-color: #0075ff63;
	cursor: pointer;
}



.form.light select:invalid, 
.form.light ms-options-wrap  > button, 
.form.light input::placeholder, 
.form.light textarea::placeholder { 
	color:#a9a9a9; font-size: 12px; /*opacity: 0.5;*/  }

.form.error-border .form-group.error input, 
.form.error-border .form-group.error .cb_wrap, 
.form.error-border .form-group.error textarea{
	border-color: #6B0001;
}
.form.light label.error{
    /* background: #ccc;
    color: #6B0001;*/
	background: #6B0001;
    color: #fff;
}
.form.light .form-group.error .form-control-icon{
	color: #6B0001;
}


.form.error-border .form-group.success input{
	border-color: #00771d;
}
.form.light label.success {
    background: #00771d;
    color: #fff;
    display: block;
    margin: 0 0 0 0;
    padding: 3px 7px;
}
.form.light .form-group.success .form-control-icon{
	color: #00771d;
}





.form.subtle-errors label.error,
.form.light.subtle-errors label.error,
.form.dark.subtle-errors label.error{
 	background: transparent;
    color: #8c0000;
    bottom: 0;
}

.form.light .form-group hr,
.form.dark .form-group hr{
	background: #8c8c8c75;
}

.form.light .form-group.bordered,
.form.dark .form-group.bordered{
	border: 1px solid #8c8c8c75;
}

.form .form-group.bordered.dashed{
	border-bottom-style: dashed;
}
.form .form-group.bordered.dotted{
	border-bottom-style: dotted;
}

.form.light .form-group.padded, 
.form.dark .form-group.padded{
	padding: 10px 10px 10px 10px; 
}
.form.light .form-group.filled{
	background:  #d5d5d51a; 
} 
.form.dark .form-group.filled{
	background: #3737371a; 
}

.form fieldset.form-group.columns {
	  padding: 0 0 0 5px;
  margin: 0 0 5px 0;
  position: relative; 
}


/* ----------------------- ERROR GROUPS -------------------- */
.form.sm fieldset.form-group.error, 
.form.small fieldset.form-group.error{
	margin:0 0 17px 0;
}
.form.sm fieldset.form-group,
.form.small fieldset.form-group{
	margin:0 0 17px 0;
} 

.form.md fieldset.form-group.error,
.form.medium fieldset.form-group.error{
	margin:0 0 20px 0;
}
.form.md fieldset.form-group, 
.form.medium fieldset.form-group{
	margin:0 0 20px 0;
} 

.form.lg fieldset.form-group.error, 
.form.large fieldset.form-group.error{
	margin:0 0 25px 0;
}
.form.lg fieldset.form-group, 
.form.large fieldset.form-group{
	margin:0 0 25px 0;
} 


/* ----------------------- SPECIAL STUFF -------------------- */
.form.oneline button.submit_form {
 	border-bottom-left-radius: 0px;
    border-top-left-radius: 0px;
	position: relative; left: -5px; top: -1px;
}

.form.oneline.large .btn, 
.form.oneline.lg .btn{
	/*top: -1px;*/
}

.form.oneline.medium .btn, 
.form.oneline.md .btn{
	    padding: 13px 20px 11px 20px;
}

.form.oneline.small .btn, 
.form.oneline.sm .btn {
 padding: 15px 15px 15px 15px;
}

.form.small.oneline .btn.submit_form {
    height: 30px;
	width: 100%;
	min-width: 130px;
}
@media (max-width: 767px) {
	.form.oneline .btn.submit_form {
		height: 30px;
		width: 100%;
	}
	.form.oneline .form-group { 
		text-align: center;
		} 
	
	.form.oneline label.error { 
		position: static;
		} 

	
	.form.oneline button.submit_form {
		border-bottom-left-radius: 4px;
		border-top-left-radius: 4px;
		border-bottom-right-radius: 4px;
		border-top-right-radius: 4px;
		position:static; 
	}
	.form.oneline, 
	.form.oneline fieldset.form-group{ text-align: center; }
	
	.form.oneline input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]),
	.form.oneline button.submit_form, 
	.form.oneline .btn.submit_form, 
	.form.oneline label.error{
		text-align: center;
		margin: 0 auto 8px auto !important;
		width: 100%;
		max-width: 300px;
	}
	
	.form.oneline .form-group.error input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]){
		margin: 0 auto 0 auto !important;
	}
	
	.form.oneline label.error{
		margin: 0 auto 4px auto !important;
	}
	
	 
	.form.oneline.dark input::placeholder { color: #A2A2A2; }
	.form.oneline.light input::placeholder { color: #A2A2A2; }
}







.boxedin.light {background: rgba(255, 255, 255, 0.26);}
.boxedin.light .top_mast, 
.boxedin.light .bottom_mast {background: rgba(255,255,255,0.64);}

.boxedin.dark {background: rgba(0, 0, 0, 0.26);}
.boxedin.dark .top_mast,
.boxedin.dark .bottom_mast { background: rgba(0,0,0,0.24);}


@media (max-width: 767px) {

	
	.mobile-boxedin.light {background: rgba(255, 255, 255, 0.26);}
	.mobile-boxedin.light .top_mast, 
	.mobile-boxedin.light .bottom_mast {background: rgba(255,255,255,0.64);}

	.mobile-boxedin.dark {background: rgba(0, 0, 0, 0.26);}
	.mobile-boxedin.dark .top_mast,
	.mobile-boxedin.dark .bottom_mast { background: rgba(0,0,0,0.24);}

	
}




.form.small label.error, 
.form.sm label.error, 
.form.medium label.error, 
.form.md label.error, 
.form.large label.error, 
.form.lg label.error{
	width: auto; 
}

.form.wide_errors label.error{
	width: max-content;
}

.columns.form-group.multiple input.form-control, 
.columns.form-group.multiple select.form-control{ 
width: 97%;
}




form.sm fieldset, 
form.small fieldset{
	margin-bottom: 5px;
}

form.lg fieldset, 
form.large fieldset{
	margin-bottom: 12px;
}

@media (max-width: 767px) {
form.big fieldset{
	margin-bottom: 8px;
}
}


/* ----------------- select menus -------------------- */
.form .ms-options-wrap > button:focus, 
.form .ms-options-wrap > button {
	border: none;
    position: absolute;
    /* top: 50%; */
    /* transform: translate(0, -50%); */
    margin: 0 0 0 0;
    padding: 0 0 0 10px;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
	width: 100%;
	background: none;
}
.form .ms-options-wrap > button:after { display: none; }
.form .ms-options-wrap > .ms-options {
	margin-top: 39px;
	overflow-y: auto !important;
	overflow-x: hidden !important;
	border: none; padding: 5px 12px; 
}

.form.small .ms-options-wrap > .ms-options {
	margin-top: 29px;
}

.form.large .ms-options-wrap > .ms-options {
	margin-top: 48px;
}

.form .ms-options-wrap > .ms-options ul {
    width: 99% !important;
    max-width: 99% !important;
}

.form .ms-search input {
	margin: 10px !important;
    height: 30px !important;
    padding-left: 5px !important;
    width: 97% !important;
	font-family: Arial, Font Awesome\ 6 Pro;
	border: 1px solid #ccc !important;
}

.form.dark .ms-search input {
	border: 1px solid #424242 !important;
} 

.form .ms-search {
	  position: relative;
      width: 97% !important;
}
.form .ms-options-wrap > .ms-options > ul label {
    padding: 6px 4px 4px 27px;
    margin: 1px 2px;
    border: none;    
	width: 98%;
}


.selectwrap:after { 
    position: absolute;
    right: 10px;
    top: 8px;
    font-family: Font Awesome\ 6 Pro;
    pointer-events: none;
	font-weight: 300;
}
.form.small .selectwrap:after,
.form.sm .selectwrap:after{
    content: "\f107";
	font-size: inherit;
    top: 5px;
}

.form.medium .selectwrap:after,
.form.md .selectwrap:after{
    content: "\f107";
	font-size: inherit;
    top: 12px;
}

.form.large .selectwrap:after,
.form.lg .selectwrap:after{
    content: "\f107";
	font-size: inherit;
    top: 16px;
    right: 17px;
}


/* ----------------- custom combox boxes and checks -------------------- */
label.cb { padding: 2px 5px;
}
label.cb:hover { cursor: pointer !important; 
	background: rgb(217 217 217 / 50%); 
}


/* remove the default icon from the h5 date/time picker
opacity: 0; display: none; visibility: hidden;  */

.form.light input[type="date"],
.form.light input[type="datetime-local"],
.form.light input[type="time"] {
  cursor: pointer !important; 
	color-scheme: light;
}

.form.dark input[type="date"],
.form.dark input[type="datetime-local"],
.form.dark input[type="time"]{
  cursor: pointer !important; 
	color-scheme: dark; 
}


.form input[type="date"]::-webkit-calendar-picker-indicator,
.form input[type="datetime-local"]::-webkit-calendar-picker-indicator ,
.form input[type="time"]::-webkit-calendar-picker-indicator {
	border-radius: 100%; padding: 5px; margin: -5px; position: relative; top: -2px; left: 0;
}

.form.medium input[type="date"]::-webkit-calendar-picker-indicator,
.form.medium input[type="datetime-local"]::-webkit-calendar-picker-indicator ,
.form.medium input[type="time"]::-webkit-calendar-picker-indicator {
	border-radius: 100%; padding: 4px; margin: -4px; position: relative; top: -3px; left: -4px;
}

.form.small input[type="date"]::-webkit-calendar-picker-indicator,
.form.small input[type="datetime-local"]::-webkit-calendar-picker-indicator ,
.form.small input[type="time"]::-webkit-calendar-picker-indicator {
	border-radius: 100%; padding: 1px; margin: -3px; position: relative; top: -3px; left: -4px;
}

.form.light input[type="date"]::-webkit-calendar-picker-indicator,
.form.light input[type="datetime-local"]::-webkit-calendar-picker-indicator ,
.form.light input[type="time"]::-webkit-calendar-picker-indicator {
  cursor: pointer !important; 
	color-scheme: light;
	background-color: #ccc; 
}

.form.dark input[type="date"]::-webkit-calendar-picker-indicator,
.form.dark input[type="datetime-local"]::-webkit-calendar-picker-indicator ,
.form.dark input[type="time"]::-webkit-calendar-picker-indicator {
  cursor: pointer !important; 
	color-scheme: dark; 
	background-color: #494949; 
}


input[type=radio], 
input[type=checkbox]{
  -webkit-transition: border 0.15s ease;
  -moz-transition: border 0.15s ease;
  -o-transition: border 0.15s ease;
  transition: border 0.15s ease;
  -webkit-border-radius: 100%;
  -webkit-background-clip: padding-box;
  -moz-border-radius: 100%;
  -moz-background-clip: padding;
  border-radius: 100%;
  background-clip: padding-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
    margin: 0 5px 0 3px;
    vertical-align: text-bottom;
    width: 17px;
    height: 17px;
    border: 2px solid #dbdbdb;
    background-color: #ffffff;
    cursor: pointer;
}
input[type=radio]:checked, 
input[type=checkbox]:checked {
  background-color: #a3ff99;
}
input[type=radio]:hover,
input[type=radio]:focus,
input[type=checkbox]:hover,
input[type=checkbox]:focus{
  border-color: #dcdcdc;
}
input[type=radio]:before, 
input[type=checkbox]:before{

	opacity: 0;

}
input[type=radio]:checked:before, 
input[type=checkbox]:checked:before{
   font-family: Font Awesome\ 6 Pro;
    content: "\f00c";
    font-weight: 700;
    font-size: inherit;
       top: -0.5px;
    left: -0.5px; 
	opacity: 1;
	position: absolute;

}

form.medium input[type=radio].circular:checked:before, 
form.medium input[type=checkbox].circular:checked:before, 
form.md input[type=radio].circular:checked:before, 
form.md input[type=checkbox].circular:checked:before{
    left: 0px;
    text-align: center !important;
    font-size: 15px;
    top: -0.5px;
}

form.medium input[type=radio].circular.circle-check:checked:before, 
form.medium input[type=checkbox].circular.circle-check:checked:before, 
form.md input[type=radio].circular.circle-check:checked:before, 
form.md input[type=checkbox].circular.circle-check:checked:before{
        left: 1px;
    text-align: center;
    font-size: 13px;
    /* opacity: 0.75; */
    top: 1px;
}


form.large input[type=radio].circular:checked:before, 
form.large input[type=checkbox].circular:checked:before, 
form.lg input[type=radio].circular:checked:before, 
form.lg input[type=checkbox].circular:checked:before{
        left: -3px;
    text-align: center;
    top: -4px;
    font-size: 23px;
	color: #6b6b6b;
}


input[type=radio]:checked:before, 
input[type=checkbox]:checked:before{
	font-family: Font Awesome\ 6 Pro; 
    content: "\f00c";
	font-weight: 700;
	font-size: inherit;
}

input[type=radio].circle-check:checked:before, 
input[type=checkbox].circle-check:checked:before{
	font-family: Font Awesome\ 6 Pro; 
    content: "\f058";
	font-weight: 700;
	font-size: inherit;
}

input[type=radio].circle-dot:checked:before, 
input[type=checkbox].circle-dot:checked:before{
	font-family: Font Awesome\ 6 Pro; 
    content: "\f192";
	font-weight: 700;
	font-size: inherit;
}

input[type=radio].circle-small:checked:before, 
input[type=checkbox].circle-small:checked:before{
	font-family: Font Awesome\ 6 Pro;
    content: "\e122";
    font-weight: 700;
    vertical-align: middle;
	
	left: 3px !important;
    text-align: center !important;
    font-size: 13px !important;
    top: 0.5px !important;
	
	
}
.form.large input[type=radio].circle-small:checked:before, 
.form.large input[type=checkbox].circle-small:checked:before{
    left: 4.25px !important;
    font-size: 14px !important;
}
.form.small input[type=radio].circle-small:checked:before, 
.form.small input[type=checkbox].circle-small:checked:before{
    left: 2.5px !important;
    font-size: 11px !important;
}


input[type=radio] + p,
input[type=radio] + label, 
input[type=checkbox] + p,
input[type=checkbox] + label {
  display: inline;
}

input[type=file]:focus,
input[type=radio]:focus,
input[type=checkbox]:focus {
  outline: none;
}




	.show_capcha .grecaptcha-badge { visibility:visible; }
	.hide_capcha .grecaptcha-badge { visibility: hidden; }
	 
	.show_capcha .grecaptcha-text { visibility:hidden; display:none;}
	.hide_capcha .grecaptcha-text { visibility: visible; }

.grecaptcha-text, .grecaptcha-text a, .grecaptcha-text a:hover {font-size: 10px; font-weight: 100;  opacity: 0.75; }

.form.light .grecaptcha-text, 
.form.light .grecaptcha-text a, 
.form.light .grecaptcha-text a:hover {color: #000 !important;}

.form.dark .grecaptcha-text, 
.form.dark .grecaptcha-text a, 
.form.dark .grecaptcha-text a:hover {color: #fff !important;}

.grecaptcha-text a:hover { text-decoration: underline; }

.grecaptcha-text a[target=_blank]:not(.no_blank):after {content: "" !important; display: none; visibility: hidden; }








@media (max-width: 540px) {
form.form label { font-size: 11px !important; }
form.form label.actual-label { margin: 0 0 5px 0; }
	.cb_wrap label.cb { 
	font-size: 13px;
    padding: 7px 7px;
	}
	.cb_wrap label.cb.wide { width: 100%; max-width: 100%;
	}
	.cb_wrap label.cb span.rlabel { 
	padding: 4px 0 0 5px;
    float: left;
    display: block;
	}
	
	/*.form input[type=radio],
	.form input[type=checkbox] {
		float: left;
	}*/
	
	
	.form textarea,
	.form select, 
	.form .ms-options-wrap, 
	.form input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]), 
	.form textarea, 
	.form select, 
	.form input:not([type="submit"]):not([type="radio"]):not([type="checkbox"]) {
		margin-left: auto !important;
		margin-right: auto !important;
		display: block; 
	}
	
	
	
	
	/* this has an odd size, so lets match the button*/
	.g-recaptcha {  }
	.grecaptcha-badge { margin: 0 auto !important;
    }
	
	
	
	.form .submit_form {
	    width: 100%;
    /* text-align: center; */
    display: block;
    margin: 0 auto;
    float: none;
    max-width: 100%;
	}
	
	
	.form .form_interior { margin: 0 0 0 0;}

	
}




/* ----------------------- GOOGLE MAPS STUFF -------------------- */
.micro-address{ opacity: 0.75; }
.micro-address input {    
	height: 24px  !important;
    color: #2a2a2a !important;
    margin: 3px -2px 0px 0px !important;
    font-size: 11px  !important;
    line-height: 12px !important;
    border-width: 0px !important;
    border-color: #00000021 !important; 
    border-radius: 0 !important;
    border-style: none !important;
    display: block;
	background-color: #f2f2f291 !important;
	padding: 2px 5px 2px 5px !important;
	cursor:default !important;
}
.form.light .micro-address input {    
    color: #2a2a2a !important;
    border-color: #00000021 !important; 
	background-color: #d3d3d391 !important;
}

.form.dark .micro-address input {    
    color: #dddddd !important;
    border-color: #d3d3d321 !important; 
	background-color: #35353530 !important;
}
.micro-address .columns { padding: 0 3px 0 0 !important; }
.micro-address .large-12 input {   
}

