/**
 * cpForm 
 * used for all settings forms in the backend. Primarly tables have been used
 * for forms but tables don't allow for responsive layouts, so we move forward.
 */
div.cpForm {
  width: 100%;
}

div.cpForm:before,
div.cpForm:after {
  content: "";
  display: table;
}

div.cpForm:after,
div.cpForm .formRow:after {
  clear: both;
}

div.cpForm .formRow,
div.cpForm .buttonsRow,
div.cpForm .formDescription,
div.cpForm .formHeading {
  position: relative;
  padding: 0.2em 0;
  width: 100%;
  display: table;
}

div.cpForm > .formHeading {
  font-size: 1.4em;
  font-weight: bold;
  margin-top: 0.5em;
  color: #5b7ca3;
}

div.cpForm > .buttonsRow {
  margin-top: 1em;
}

div.buttonsRow {
  padding: 0.5em 0;
  width: 100%;
  display: table;
}

div.settingValue {
  line-height: 1.2em;
  width: 80%;
}

div.cpForm div.settingName,
div.cpForm label.settingName {
  width: 50%;
  font-size: 1.15em;
  margin-top: 0.005em;
  margin-right: none;
}

label.settingName:after,
div.settingName label:after {
  content: ":";
}

div.cpForm div.settingName,
div.cpForm label.settingName,
div.cpForm div.settingValue {
  float: left;
}

div.settingValue label {
  padding-left: 4px;
  padding-right: 8px;
  cursor: pointer;
}

div.cpForm div.missingRequired {
  background-color: transparent;
  background-image: linear-gradient(#fffbfb, #ffe5e5);
  border-bottom: 1px solid #fe8282;
}

span.reqField {
  color: #ee5555;
  font-weight: bold;
  padding-left: 2px;
  font-size: 120%;
}

/**
 * cpForm 
 * input elements
 */
div.cpWrap input[type="file"],
div.cpWrap input[type="email"],
div.cpWrap input[type="text"],
div.cpWrap input[type="password"],
div.cpWrap textarea,
div.cpWrap select,
.idLabel {
  font-family: monospace, Courier, "Lucida Sans Typewriter", "Lucida Typewriter";
  font-size: 1em;
}

input {
  outline: 0 !important;
}

div.formRow input[type="file"],
div.formRow input[type="email"],
div.formRow input[type="text"],
div.formRow input[type="password"],
div.formRow textarea,
div.formRow select {
  margin: 0;
  padding: 0.48em 0 0.48em 0.4em;
  width: 100%;
  max-width: 100%;
  font-size: 1em;
  outline: 0;
}

div.formRow select {
  padding: 0;
  width: 99.2%;
  max-width: 99.2%;
  height: 30px;
}

div.formRow input.has-file-ext {
  width: 85%;
}

div.settingValue textarea {
  width: 99%;
  min-height: 80px;
}

div.settingValue select {
  padding: 0 0.2em 0 0.2em;
}

div.settingValue select option.selected-item {
  font-weight: bold;
}

div.settingValue select option.disabled-item {
  color: grey;
}

div.cpForm .buttonsRow {
  position: relative;
  text-align: left;
  width: 100%;
}

/*div.cpForm .buttonsRow * {
}*/

div.buttonsRow .pos-right {
  float: left;
}

/* Form Hints and Warnings */
div.formHint,
div.warningHint,
div.recommendHint {
  padding: 0.4em 0;
  font-size: 0.9em;
  color: #9e9e9e;
  font-style: italic;
}

div.warningHint {
  color: #cc0033;
}

div.recommendHint {
  color: #009933;
}

/**
 * Buttons 
 * we have several types of buttons: 
   <input type="button">
   <button>
   and anchor (link) based buttons
   the following css handles all the above types
   Note: we use a jQuery Plugin in order to enframe input type buttons into
         a div container we couldn't otherwise apply icons to all the buttons
 */
div.buttonsRow button,
div.buttonsRow input {
  padding: 4px 7px;
  font-size: 1em;
}

.button {
  display: inline-block;
  white-space: nowrap;
  margin: 5px 0 20px 0;
  margin-left: 3px;
  cursor: pointer;
}

.button,
.button:hover {
  text-decoration: none;
}

.button:active,
.button.sel,
.button.sel:hover {
  cursor: default;
}

.button:focus {
  outline: 0;
  background: #fafafa;
}

div.button input,
div.button input:hover,
div.button input:active,
div.button input:focus {
  cursor: pointer;
  display: inline;
}

/**
 * Buttons (grouped with a radius edge on start and end of buttons group)
 */
.button-group {
  border-radius: 5px;
}

.button-group .button {
  border-radius: 0;
  margin: -2px;
  padding: 0 1em 0 1em;
}

.button-group .button:first-child {
  border-radius: 9px 0 0 9px;
}

.button-group .button:last-child {
  border-radius: 0 9px 9px 0;
}

/**
 * list for checkboxes 
 * (used with page permissions and other places)
 */
ul.operatorList {
  list-style: none;
}

ul.operatorList li:first-child {
  font-weight: bold;
}

hr {
  margin: 30px 0;
  border: none;
  border-top: 2px solid rgba(115, 127, 140, 0.25);
  height: 0;
  color: transparent;
}

.input-error {
  color: red;
  border: 1px solid red;
}

/* 
 *  bootstrap like alert boxes
 */
/**
 * We use these with the new MessageBox PHP class
 * it is temporarily here until we figured out a better place for this CSS
 * it may trigger conflicts with bootstrap based themes, but tests need be done
 */
.alert,
.alertbox_success {
  padding: 10px;
  margin-bottom: 20px;
  border: 1px solid transparent;
  border-radius: 4px;
}

.alert h4 {
  margin-top: 0;
  color: inherit;
}

.alert .alert-link {
  font-weight: bold;
}

.alert > p,
.alert > ul {
  margin-bottom: 0;
}

.alert > p + p {
  margin-top: 5px;
}

.alert-dismissable,
.alert-dismissible {
  padding-right: 35px;
}

.alert-dismissable .close,
.alert-dismissible .close {
  position: relative;
  top: -2px;
  right: -21px;
  color: inherit;
}

button.close {
  background-color: transparent;
  cursor: pointer;
  border: 0;
  margin-top: 0px;
}

.alert-success,
.alertbox_success {
  color: #3c763d;
  background-color: #dff0d8;
  border-color: #d6e9c6;
}

.alert-success hr {
  border-top-color: #c9e2b3;
}

.alert-success .alert-link {
  color: #2b542c;
}

.alert-info {
  color: #31708f;
  background-color: #d9edf7;
  border-color: #bce8f1;
}

.alert-info hr {
  border-top-color: #a6e1ec;
}

.alert-info .alert-link {
  color: #245269;
}

.alert-warning {
  color: #8a6d3b;
  background-color: #fcf8e3;
  border-color: #faebcc;
}

.alert-warning hr {
  border-top-color: #f7e1b5;
}

.alert-warning .alert-link {
  color: #66512c;
}

.alert-danger {
  color: #a94442;
  background-color: #f2dede;
  border-color: #ebccd1;
}

.alert-danger hr {
  border-top-color: #e4b9c0;
}

.alert-danger .alert-link {
  color: #843534;
}

.alert,
.alertbox_success {
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25),
    0 1px 2px rgba(0, 0, 0, 0.05);
}

.alert-success,
.alertbox_success {
  background-image: linear-gradient(to bottom, #dff0d8 0%, #c8e5bc 100%);
  background-repeat: repeat-x;
  border-color: #b2dba1;
}

.alert-info {
  background-image: linear-gradient(to bottom, #d9edf7 0%, #b9def0 100%);
  background-repeat: repeat-x;
  border-color: #9acfea;
}

.alert-warning {
  background-image: linear-gradient(to bottom, #fcf8e3 0%, #f8efc0 100%);
  background-repeat: repeat-x;
  border-color: #f5e79e;
}

.alert-danger {
  background-image: linear-gradient(to bottom, #f2dede 0%, #e7c3c3 100%);
  background-repeat: repeat-x;
  border-color: #dca7a7;
}

.close {
  float: right;
  font-size: 21px;
  font-weight: 700;
  line-height: 1;
  color: #000;
  text-shadow: 0 1px 0 #fff;
  opacity: 0.2;
}

/* Overrides for ugly default template styles */
.buttonsRow input {
  width: 12em !important;
}

/* ################ */
@media (max-width: 750px) {
  div.cpForm {
    clear: both;
  }

  div.cpForm label.settingName,
  div.cpForm div.settingName {
    text-align: left;
    display: inline-block;
    max-width: 100%;
    margin-bottom: 5px;
  }

  div.cpForm label.settingValue {
    display: inline;
    width: 100%;
    margin-bottom: 5px;
  }

  div.formRow input[type="file"],
  div.formRow input[type="email"],
  div.formRow input[type="text"],
  div.formRow input[type="password"],
  div.formRow textarea,
  div.formRow select,
  div.formRow .form-control {
    width: 100%;
    min-width: 300px !important;
    display: inline-block;
  }

  span.file-ext {
    display: none;
  }

  div.cpForm label.settingName,
  div.cpForm div.settingName,
  div.cpForm div.settingValue {
    float: inherit;
    width: 100%;
  }

  div.cpForm label.settingName,
  div.cpForm div.settingName {
    padding-top: 5px;
  }

  div.cp-third,
  div.cp-two-thirds {
    width: 95% !important;
    float: left;
    padding: 12px 6px;
  }

  div.buttonsRow .pos-right {
    float: none;
  }
}

.pass-graybar {
  width: 100% !important;
  margin-bottom: 3px !important;
}

.pass-wrapper {
  margin-bottom: 5px !important;
}
