/* MODIFIED for ADA */

/* apps/perform using CGI.pm */
#cbrforms td, 
#cbrforms th {
  padding: 5px;
}

#cbrforms .card-header {
background-color: #eeeeee !important;
}

#cbrforms form {
  margin: 0 0 18px; /* top right&left bottom*/
  font-size: 1rem;
  font-weight: normal;
  line-height: 1.5;
}

#cbrforms fieldset {
  padding: 0;
  margin: 0;
  border: 0;
}

#cbrforms .control-group {
  margin-bottom: 9px;
}

#cbrforms legend + .control-group {
  margin-top: 18px;
  -webkit-margin-top-collapse: separate;
}

/* match h4 */
#cbrforms legend {
  /*margin-top: 0;*/
  font-size: 1.1rem;
  font-weight: 500;
  padding-top: 5px;
  padding-bottom: 5px;
}

/* match h5 */
  /*font-size: 1.2rem; setting this font-size had negative impact to alignment*/
#cbrforms div.control-group .control-label {
  font-weight: 400; /* 600*/
  padding-top: 5px;
  padding-bottom: 5px;
}

#cbrforms .controls > .radio:first-child,
#cbrforms .controls > .checkbox:first-child {
  padding-top: 5px;
}

#cbrforms .btn-group {
  position: relative;
}
#cbrforms .btn-group:before,d
#cbrforms .btn-group:after {
  display: table;
  content: "";
}
#cbrforms .btn-group:after {
  clear: both;
}
#cbrforms .btn-group:first-child {
  /*margin-left: 0;*/
}
#cbrforms .btn-group + .btn-group {
  margin-left: 5px;
}
#cbrforms .btn-toolbar {
  margin-top: 9px;
  margin-bottom: 9px;
}
#cbrforms .btn-toolbar .btn-group {
  display: inline-block;
}
#cbrforms .btn-group .btn {
  position: relative;
  float: left;
  margin-left: -1px;
  border-radius: 0;
}
#cbrforms .btn-group .btn:first-child {
  margin-left: 0;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
}
#cbrforms .btn-group .btn:last-child,
#cbrforms .btn-group .dropdown-toggle {
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}

#cbrforms .btn-group .btn:hover,
#cbrforms .btn-group .btn:focus,
#cbrforms .btn-group .btn:active,
#cbrforms .btn-group .btn.active {
  z-index: 2;
}

#cbrforms .btn-small {
  padding: 5px 9px;
  font-size: 11px;
  line-height: 16px;
}
#cbrforms .btn-small [class^="bi bi-"] {
  margin-top: -1px;
}


#cbrforms .btn {
  display: inline-block;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  font-size: 13px;
  line-height: 18px;
  color: #333333;
  text-align: center;
  text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75);
  vertical-align: middle;
  background-color: #f5f5f5;
  background-image: linear-gradient(to bottom, #ffffff, #e6e6e6);
  background-repeat: repeat-x;
  border-color: #e6e6e6 #e6e6e6 #bfbfbf;
  border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);
  border: 1px solid #cccccc;
  border-bottom-color: #b3b3b3;
  border-radius: 4px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
  cursor: pointer;
}
#cbrforms .btn:hover,
#cbrforms .btn:active,
#cbrforms .btn.active,
#cbrforms .btn.disabled,
#cbrforms .btn[disabled] {
  background-color: #e6e6e6;
}
#cbrforms .btn.active {
  font-weight: bold;

}
#cbrforms .btn:first-child {
}
#cbrforms .btn:hover {
  color: #333333;
  text-decoration: none;
  background-color: #e6e6e6;
  background-position: 0 -15px;
  transition: background-position 0.1s linear;
}
#cbrforms .btn:focus {
  outline: thin dotted #333;
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}
#cbrforms .btn.active,
#cbrforms .btn:active {
  background-image: none;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.05);
  background-color: #e6e6e6;
  outline: 0;
}
#cbrforms .btn.disabled,
#cbrforms .btn[disabled] {
  cursor: default;
  background-image: none;
  background-color: #e6e6e6;
  opacity: 0.65;
  box-shadow: none;
}

#cbrforms .btn-primary,
#cbrforms .btn-primary:hover {
  text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
  color: #ffffff;
}
#cbrforms .btn-primary {
  background-color: #0074cc;
  background-image: linear-gradient(to bottom, #0088cc, #0055cc);
  background-repeat: repeat-x;
  border-color: #0055cc #0055cc #003580;
  border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);
}

#cbrforms .btn-primary:hover,
#cbrforms .btn-primary:active,
#cbrforms .btn-primary.active,
#cbrforms .btn-primary.disabled,
#cbrforms .btn-primary[disabled] {
  background-color: #0055cc;
}
#cbrforms .btn-primary:active,
#cbrforms .btn-primary.active {
}

#cbrforms .btn-primary.active {
  color: rgba(255, 255, 255, 0.75);
}


#cbrforms button.btn,
#cbrforms input[type="submit"].btn {
}
#cbrforms button.btn::-moz-focus-inner,
#cbrforms input[type="submit"].btn::-moz-focus-inner {
  padding: 0;
  border: 0;
}

#cbrforms button.btn.btn-small,
#cbrforms input[type="submit"].btn.btn-small {
}

#cbrforms button,
#cbrforms input,
#cbrforms select,
#cbrforms textarea {
  margin: 0;
  font-size: 100%;
  vertical-align: middle;
}
#cbrforms button,
#cbrforms input {
  line-height: 1.5;
}
#cbrforms button::-moz-focus-inner,
#cbrforms input::-moz-focus-inner {
  padding: 0;
  border: 0;
}
#cbrforms button,
#cbrforms input[type="button"],
#cbrforms input[type="reset"],
#cbrforms input[type="submit"] {
  cursor: pointer;
}

#cbrforms .radio,
#cbrforms .checkbox {
  padding-left: 18px;
}
#cbrforms .radio input[type="radio"],
#cbrforms .checkbox input[type="checkbox"] {
  float: left;
  margin-left: -18px;
}
#cbrforms .controls > .radio:first-child,
#cbrforms .controls > .checkbox:first-child {
  padding-top: 5px;
}
#cbrforms .radio.inline,
#cbrforms .checkbox.inline {
  display: inline-block;
  padding-top: 5px;
  margin-bottom: 0;
  vertical-align: middle;
}
#cbrforms .radio.inline + .radio.inline,
#cbrforms .checkbox.inline + .checkbox.inline {
  margin-left: 10px;
}

#cbrforms label,
#cbrforms input,
#cbrforms button,
#cbrforms select,
#cbrforms textarea {
line-height: 1.5; /* orig 1 */
/*
  font-size: 13px;
*/
/*
font-weight: normal;
*/
/*
  line-height: 18px;
*/
}

#cbrforms label {
  display: block;
  margin-bottom: 5px;
  color: #333333;
}

#cbrforms label input,
#cbrforms label textarea,
#cbrforms label select {
  display: block;
}
#cbrforms input[type="image"],
#cbrforms input[type="checkbox"],
#cbrforms input[type="radio"] {
  width: auto;
  height: auto;
  padding: 10px;
  margin: 3px 0;
  /*line-height: 1.5;*/ /*normal;*/
  cursor: pointer;
  border-radius: 0;
}
#cbrforms input[type="image"] {
  border: 0;
}
#cbrforms input[type="file"] {
  width: auto;
  padding: initial;
  line-height: initial;
  border: initial;
  background-color: #ffffff;
  background-color: initial;
  box-shadow: none;
}
#cbrforms input[type="button"],
#cbrforms input[type="reset"],
#cbrforms input[type="submit"] {
  width: auto;
  height: auto;
}
#cbrforms input[type="file"] {
  height: 28px;
  /*line-height: 28px;*/
}
#cbrforms input[type="file"] {
}
#cbrforms select {
  /*width: 220px;*/
  background-color: #ffffff;
}
#cbrforms select[multiple],
#cbrforms select[size] {
  height: auto;
}
#cbrforms input[type="image"] {
  box-shadow: none;
}
#cbrforms textarea {
  height: auto;
}
#cbrforms input[type="hidden"] {
  display: none;
}

#cbrforms input,
#cbrforms textarea {
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  transition: border linear 0.2s, box-shadow linear 0.2s;
}
#cbrforms input:focus,
#cbrforms textarea:focus {
  border-color: rgba(82, 168, 236, 0.8);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(82, 168, 236, 0.6);
  outline: 0;
}
#cbrforms input[type="file"]:focus,
#cbrforms input[type="radio"]:focus,
#cbrforms input[type="checkbox"]:focus,
#cbrforms select:focus {
  box-shadow: none;
  outline: thin dotted #333;
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}


#cbrforms input[disabled],
#cbrforms select[disabled],
#cbrforms textarea[disabled],
#cbrforms input[readonly],
#cbrforms select[readonly],
#cbrforms textarea[readonly] {
  background-color: #eeeeee;
  border-color: #ddd;
  cursor: not-allowed;
}

#cbrforms input:focus:required:invalid,
#cbrforms textarea:focus:required:invalid,
#cbrforms select:focus:required:invalid {
  color: #b94a48;
  border-color: #ee5f5b;
}
#cbrforms input:focus:required:invalid:focus,
#cbrforms textarea:focus:required:invalid:focus,
#cbrforms select:focus:required:invalid:focus {
  border-color: #e9322d;
  box-shadow: 0 0 6px #f8b9b7;
}
/* radius matches bs5 card radius 0.375*/
/* radius matches cbr-crumb-light */
#cbrforms .form-actions {
  padding: 1rem 1rem 1rem;
  margin-top: 1em;
  margin-bottom: 1em;
  background-color: #eeeeee;
  border: 1px solid #ddd;
  border-radius: 0.3rem;
}
#cbrforms .form-actions:before,
#cbrforms .form-actions:after {
  display: table;
  content: "";
}
#cbrforms .form-actions:after {
  clear: both;
}


#cbrforms .input-prepend,
#cbrforms .input-append {
  margin-bottom: 5px;
}
#cbrforms .input-prepend input,
#cbrforms .input-append input,
#cbrforms .input-prepend select,
#cbrforms .input-append select,
#cbrforms .input-prepend .uneditable-input,
#cbrforms .input-append .uneditable-input {
  border-radius: 0 3px 3px 0;
}
#cbrforms .input-prepend input:focus,
#cbrforms .input-append input:focus,
#cbrforms .input-prepend select:focus,
#cbrforms .input-append select:focus,
#cbrforms .input-prepend .uneditable-input:focus,
#cbrforms .input-append .uneditable-input:focus {
  position: relative;
  z-index: 2;
}
#cbrforms .input-prepend .uneditable-input,
#cbrforms .input-append .uneditable-input {
  border-left-color: #ccc;
}
#cbrforms .input-prepend .add-on,
#cbrforms .input-append .add-on {
  display: inline-block;
  width: auto;
  min-width: 16px;
  /*height: 18px;*/
  padding: 4px 5px;
  /*font-weight: normal;*/
  /*line-height: 18px;*/
  text-align: center;
  text-shadow: 0 1px 0 #ffffff;
  vertical-align: middle;
  background-color: #eeeeee;
  border: 1px solid #ccc;
}
#cbrforms .input-prepend .add-on,
#cbrforms .input-append .add-on,
#cbrforms .input-prepend .btn,
#cbrforms .input-append .btn {
  border-radius: 3px 0 0 3px;
}
#cbrforms .input-prepend .active,
#cbrforms .input-append .active {
  background-color: #a9dba9;
  border-color: #46a546;
}
#cbrforms .input-prepend .add-on,
#cbrforms .input-prepend .btn {
  margin-right: -1px;
}
#cbrforms .input-append input,
#cbrforms .input-append select .uneditable-input {
  border-radius: 3px 0 0 3px;
}
#cbrforms .input-append .uneditable-input {
  border-left-color: #eee;
  border-right-color: #ccc;
}
#cbrforms .input-append .add-on,
#cbrforms .input-append .btn {
  margin-left: -1px;
  border-radius: 0 3px 3px 0;
}
#cbrforms .input-prepend.input-append input,
#cbrforms .input-prepend.input-append select,
#cbrforms .input-prepend.input-append .uneditable-input {
  border-radius: 0;
}
#cbrforms .input-prepend.input-append .add-on:first-child,
#cbrforms .input-prepend.input-append .btn:first-child {
  margin-right: -1px;
  border-radius: 3px 0 0 3px;
}
#cbrforms .input-prepend.input-append .add-on:last-child,
#cbrforms .input-prepend.input-append .btn:last-child {
  margin-left: -1px;
  border-radius: 0 3px 3px 0;
}

#cbrforms .form-inline input,
#cbrforms .form-inline textarea,
#cbrforms .form-inline select,
#cbrforms .form-inline .help-inline,
#cbrforms .form-inline .uneditable-input,
#cbrforms .form-inline .input-prepend,
#cbrforms .form-inline .input-append,
#cbrforms .form-inline-ada input,
#cbrforms .form-inline-ada textarea,
#cbrforms .form-inline-ada select,
#cbrforms .form-inline-ada .help-inline,
#cbrforms .form-inline-ada .uneditable-input,
#cbrforms .form-inline-ada .input-prepend,
#cbrforms .form-inline-ada .input-append,
#cbrforms .form-horizontal input,
#cbrforms .form-horizontal textarea,
#cbrforms .form-horizontal select,
#cbrforms .form-horizontal .help-inline,
#cbrforms .form-horizontal .uneditable-input,
#cbrforms .form-horizontal .input-prepend,
#cbrforms .form-horizontal .input-append {
  display: inline-block;
  margin-bottom: 0;
}
#cbrforms .form-inline .hide,
#cbrforms .form-inline-ada .hide,
#cbrforms .form-horizontal .hide {
  display: none;
}
#cbrforms .form-inline label,
#cbrforms .form-inline-ada label {
  display: inline-block;
}
#cbrforms .form-inline .input-append,
#cbrforms .form-inline .input-prepend,
#cbrforms .form-inline-ada .input-append,
#cbrforms .form-inline-ada .input-prepend {
  margin-bottom: 0;
}
#cbrforms .form-inline .radio,
#cbrforms .form-inline .checkbox {
  padding-left: 0;
  margin-bottom: 0;
  vertical-align: middle;
}
#cbrforms .form-inline-ada .radio,
#cbrforms .form-inline-ada .checkbox {
  padding-left: 0;
  margin-bottom: 0;
  vertical-align: middle;
  padding-right: 1rem !important;
}
#cbrforms .form-inline .radio input[type="radio"],
#cbrforms .form-inline .checkbox input[type="checkbox"],
#cbrforms .form-inline-ada .radio input[type="radio"],
#cbrforms .form-inline-ada .checkbox input[type="checkbox"] {
  float: left;
  margin-left: 0;
  margin-right: 10px;
}

#cbrforms .form-horizontal .control-group {
  margin-bottom: 10px; /*18px*/
}
#cbrforms .form-horizontal .control-group:before,
#cbrforms .form-horizontal .control-group:after {
  display: table;
  content: "";
}
#cbrforms .form-horizontal .control-group:after {
  clear: both;
}
#cbrforms .form-horizontal .control-label {
  float: left;
/*
  width: 140px;
*/
  width: 160px;
  padding-top: 5px;
  text-align: right;
}
#cbrforms .form-horizontal .controls {
/*
  margin-left: 160px;
*/
  margin-left: 180px;
}
#cbrforms .form-horizontal .help-block {
  margin-top: 9px;
  margin-bottom: 0;
}
#cbrforms .form-horizontal .form-actions {
/*
  padding-left: 160px; 
*/
  padding-left: 180px; 
}
#cbrforms .nav {
  margin-left: 0;
  margin-bottom: 18px;
  list-style: none;
}
#cbrforms .nav > li > a {
  display: block;
}
#cbrforms .nav > li > a:hover {
  text-decoration: none;
  background-color: #eeeeee;
}

#cbrforms .nav-tabs:before,
#cbrforms .nav-pills:before,
#cbrforms .nav-tabs:after,
#cbrforms .nav-pills:after {
  display: table;
  content: "";
}
#cbrforms .nav-tabs:after,
#cbrforms .nav-pills:after {
  clear: both;
}
#cbrforms .nav-tabs > li,
#cbrforms .nav-pills > li {
  float: left;
}
#cbrforms .nav-tabs > li > a,
#cbrforms .nav-pills > li > a {
  padding-right: 12px;
  padding-left: 12px;
  margin-right: 2px;
  line-height: 14px;
}
#cbrforms .nav-tabs {
  border-bottom: 1px solid #ddd;
}
#cbrforms .nav-tabs > li {
  margin-bottom: -1px;
}
#cbrforms .nav-tabs > li > a {
  padding-top: 8px;
  padding-bottom: 8px;
  line-height: 18px;
  border: 1px solid transparent;
  border-radius: 4px 4px 0 0;
}
#cbrforms .nav-tabs > li > a:hover {
  border-color: #eeeeee #eeeeee #dddddd;
}
#cbrforms .nav-tabs > .active > a,
#cbrforms .nav-tabs > .active > a:hover {
  color: #555555;
  background-color: #ffffff;
  border: 1px solid #ddd;
  border-bottom-color: transparent;
  cursor: default;
}

/* for all div.element: if use float left, then need to add div clearfix around each to clear out float alignment*/
div.element-group-border {
border-style:solid; 
border-color:#DDDDDD; 
border-width:1.5px; 
border-radius: 8px;
padding:10px; 
margin:5px 15px;
}

div.element-group-noborder {
/*padding-top:5px; */
padding-bottom:15px; 
margin-left:15px;
}

div.element-subgroup-noborder {
	padding:5px; margin-left:25px;
}
div.element-subsubgroup-noborder {
	padding:5px; margin-left:35px;
}
div.element-subsubgroup-border {
border-style:solid; 
border-color:#DDDDDD; 
border-width:1.5px; 
border-radius: 8px;
padding:5px; 
margin-left:35px;
}

/* added 2024 for date input field in form */
span.validity::after {
  padding-left: 5px;
}

input:invalid + span.validity::after {
  content: "✖";
}

input:valid + span.validity::after {
  content: "✓";
  color: #3CB371; /* medium sea green */
}
