/*
 * Basic values for all elements
 *
 */

* {
  margin: 0;
  font-family: var(--font-family-normal);
  color: var(--base-color-dark);
  font-size: var(--font-sm);
  /* border: 1px dotted red; */
}

html,
body {
  height: 100%;
}

a.anchor {
  display: block;
  position: relative;
  visibility: hidden;
}

h1 {
  font-size: var(--font-lg);
}

h2 {
  font-size: var(--font-md);
}
h3 {
  font-size: var(--font-sm);
}

/* h3 {
  font-weight: normal;
} */

h1,
h2,
h3,
p {
  margin-top: var(--spacing-lg);
  margin-bottom: var(--spacing-xs);
}

form {
  /* background: var(--base-color-light); */
  padding: var(--spacing-xs);
}

/*
 * Header
 *
 */

#header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  border-bottom: 6px solid;
}

#header > div {
  position: absolute;
}

/* Logo */

#header #header-logo {
  top: 0;
  left: 0;
  margin: var(--spacing-xs) var(--spacing-md);

  background-repeat: no-repeat;
  background-origin: content-box;
  background-size: auto 99%;
}

#header #header-logo > a {
  text-decoration: none;
  font-weight: bold;
  font-size: var(--font-lg);
  margin-left: var(--spacing-lg);
}

/* Actions */

#header #header-actions {
  left: var(--spacing-md);
  bottom: 0px;
}

#header #header-actions > a.page {
  font-weight: bold;
  text-decoration: none;

  padding: var(--spacing-xs) var(--spacing-sm) var(--spacing-2xs);
  margin-right: var(--spacing-2xs);

  border-radius: var(--border-radius) var(--border-radius) 0 0;

  display: inline;
}

/* Info */

#header #header-info {
  top: 0;
  right: 0;
  margin: var(--spacing-sm) var(--spacing-md);
}

#header #header-info > a.page {
  display: inline;
  margin-right: var(--spacing-sm);
}

#header #header-info > a.page.profile {
  font-weight: bold;
}

#header #header-info a.page.logout {
  display: inline-block;
  height: var(--spacing-md);
  width: var(--spacing-md);
  background-image: url("../img/icons/logout.svg");
  vertical-align: middle;
  background-repeat: no-repeat;
}
#header #header-info a.page.logout > span {
  display: none;
}

/* Language selection */

#header #languages {
  bottom: 0;
  right: var(--spacing-md);
}

#header #languages > a {
  width: var(--spacing-sm);
  height: var(--spacing-sm);
  display: inline-block;
  margin-left: var(--spacing-sm);
  background-repeat: no-repeat;
}

#header #languages span {
  display: none;
}

#header #languages > #de.active {
  background-image: url("../img/de.png");
}
#header #languages > #de.inactive {
  background-image: url("../img/de-bw.png");
}

#header #languages > #en.active {
  background-image: url("../img/gb.png");
}
#header #languages > #en.inactive {
  background-image: url("../img/gb-bw.png");
}

/*
 * Main
 *
 */

#main > div:first-child {
  margin-top: var(--spacing-sm);
  padding: 0 var(--spacing-md);
}

#main .text-body > h1:first-child,
#main .text-body > h2:first-child,
#main .text-body > h3:first-child,
#main .text-body > h4:first-child {
  margin-top: 0;
}

/*
 * Footer
 *
 */

#footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: var(--spacing-xs) var(--spacing-sm) var(--spacing-2xs)
    var(--spacing-sm);
}

#footer > .footer-container {
  /* display: flex;
  justify-content: space-between; */
}

#footer a,
#footer div {
  font-size: var(--font-xs);
}

#contact-footer,
.customfooter {
  text-align: center;
}
#contact-footer,
#contact-footer > a {
  /* color: rgba(140, 140, 140, 1); */
}
.sysfooter {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#sysfooter-left,
#sysfooter-right,
#sysfooter-middle,
.link-videos {
  display: none;
}

@media (min-width: 768px) {
  #sysfooter-left,
  #sysfooter-right,
  #sysfooter-middle,
  .link-videos {
    display: block;
  }
}

.sysfooter-item {
  height: 100%;
  width: 240px;
}
.sysfooter .scale-bg {
  position: relative;
  background: rgba(200, 200, 200, 0.5);
  width: 100%;
  height: 100%;
  padding: var(--spacing-3xs) var(--spacing-sm);
  z-index: -1;
}

.footer-value {
  padding: 0 var(--spacing-sm);
  margin: var(--spacing-2xs) 0;
  text-align: center;
}

.sysfooter .scale-bg > .scale-bg-used {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: 0;
  padding: 0;
  height: 100%;
  z-index: -1;
}

/*
 * Other
 *
 */

.info {
  background: #d5edf8;
  border: var(--border-radius) solid #92cae4;
  border-radius: var(--border-radius);

  color: #205791;
  padding: var(--spacing-xs);
  margin: var(--spacing-sm);
}

.error,
.warning {
  background: #fbe3e4;
  border: var(--border-radius) solid #fbc2c4;
  color: #8a1f11;
  padding: var(--spacing-xs);
  margin: var(--spacing-sm);
  border-radius: var(--border-radius);
}

.success {
  background: #e6efc2;
  border: var(--border-radius) solid #c6d880;
  color: #264409;
  padding: var(--spacing-xs);
  margin: var(--spacing-sm);
  border-radius: var(--border-radius);
}

.remark {
  font-size: var(--font-sm);
  font-style: italic;
  padding-left: 120px;
}

.hidden {
  display: none;
}

.clickable {
  cursor: pointer;
}

.inline {
  display: inline;
}

.text-center {
  text-align: center;
}

/*
 * Actions
 *
 */

.action {
  display: inline-block;
}

.action.notext span {
  display: none;
}

.button {
  background-color: var(--base-color);
  border-radius: var(--border-radius);
  padding: var(--spacing-xs) var(--spacing-md);
  margin: var(--spacing-sm) 0;
  /* box-shadow: var(--box-shadow); */
}

/*
 * UI dialogs
 *
 */

.icon {
  margin: 0 var(--spacing-xs);
  height: 26px;
}

.ui-icon.inline-icon {
  display: inline-block;
  position: relative;
  top: var(--spacing-2xs);
  margin: var(--spacing-2xs);
}

.ui-dialog-content label {
  display: block;
}

.config_block {
  padding: var(--spacing-2xs);
}

.notifications-form {
  padding: var(--spacing-xs);
}

.notifications-form label {
  display: block;
}

/* user/file detail dialogs */

.ui-dialog .user-info *,
.ui-dialog .file-info * {
  vertical-align: top;
}
.ui-dialog .user-info tr,
.ui-dialog .file-info tr {
  margin-bottom: var(--spacing-2xs);
  display: block;
  text-align: left;
}
.ui-dialog .user-info th,
.ui-dialog .file-info th {
  text-align: right;
  padding-right: var(--spacing-xs);
  width: 160px;
  font-weight: bold;
  margin: var(--spacing-xs);
}
.ui-dialog .user-info td input,
.ui-dialog .user-info td button {
  margin: 0 var(--spacing-2xs);
  padding: var(--spacing-2xs);
}
.ui-dialog .user-info td form {
  padding: 0;
}

.ui-dialog .user-info .user-detail.notset {
  color: var(--base-color);
}

/* Login */

#login-form input {
  display: block;
  width: 250px;
  margin: var(--spacing-xs) auto;
  padding: var(--spacing-xs);
}

#login-button {
}

.content-count .num {
  margin-right: 0.5ex;
}
.content-count .spacer {
  margin-right: 1ex;
}

.users.inactive {
  margin-top: var(--spacing-lg);
}

.role_select {
  margin: 0 var(--spacing-xs);
  padding: var(--spacing-2xs);
}

.folder.readable > .header {
  background: var(--readable-color-light);
}

.folder.on_front > .header {
  background: var(--success-color-light);
}

.folder.on_front.readable > .header {
  background: var(--error-color-light);
}

.file-history > * {
  margin-right: 1ex;
}

.file-history > .what {
  display: inline-block;
  text-align: left;
  width: 50%;
}

.file-history > .who {
  font-style: italic;
  display: inline-block;
  width: 30%;
}

.plugin {
  padding: var(--spacing-xs);
  margin: var(--spacing-2xs);
}

.plugin > .name {
  font-weight: bold;
  font-size: var(--font-md);
}

.plugin > .description {
  font-style: italic;
  font-size: var(--font-sm);
}

.plugin > .pages {
  margin-top: 1em;
  padding: var(--spacing-2xs);
}

.plugin > table {
  margin-top: 1em;
}
.plugin > table td {
  padding: var(--spacing-2xs);
}
.plugin > table th {
  padding: var(--spacing-2xs);
  text-align: left;
  background: var(--base-color-dark);
  color: var(--base-color-light);
}

.folder > .header > .child .file .progress-indicator {
  background-color: var(--base-color);
  margin: var(--spacing-xs);
  bottom: 0;
  left: 0;
  position: absolute;
  top: 0;
  width: 0px;
}

#progress-container {
  display: flex;
  justify-content: space-between;
  margin: var(--spacing-sm) 0;
}

#progress-indicator {
  width: 60%;
}

#progress-text {
  margin-left: var(--spacing-sm);
  font-size: var(--font-xs);
}

#progress-bar {
  background-color: var(--highlight-color-alpha);
}

#replace-description {
  margin: var(--spacing-xs) 0;
}

/* Context Menu  */
#contextmenu {
  position: absolute;
  border-radius: var(--border-radius);
  background: white;
  padding: 8px;
  z-index: 101;
}

.cm-entry > .action {
  display: flex;
  align-items: center;
  min-width: 320px;
  height: var(--spacing-lg);
  padding: var(--spacing-2xs);
  border-radius: var(--border-radius);
}
.cm-entry > .action:hover {
  background-color: var(--highlight-color-alpha);
}
.cm-entry > .action > img {
  height: var(--spacing-md);
}

.cm-entry > .action > span {
}

input[type="checkbox"] {
  margin-right: var(--spacing-2xs);
}

/* Designer */

.text-upload {
  margin: var(--spacing-sm) 0;
  width: 100%;
}
.text-upload > label {
  display: block;
  margin-bottom: var(--spacing-xs);
}
.text-upload > textarea {
  padding: var(--spacing-sm);
  min-width: 90%;
  min-height: 300px;
  font-family: var(--font-family-code);
}

.image-upload {
  margin: var(--spacing-md) 0;
  width: 100%;
}

.image-upload > img {
  height: var(--font-lg);
}

.color-upload {
  /* padding: var(--spacing-sm); */
  margin: var(--spacing-sm) 0;
}

input[type="color" i] {
  padding: 0;
}
.color-upload > label {
  display: block;
  margin-bottom: var(--spacing-xs);
}
.font-upload {
  display: flex;
}

.font-upload > div {
  margin-right: var(--spacing-sm);
  width: 240px;
}
.font-upload > div > label {
  display: block;
  margin: var(--spacing-xs) 0;
}
.font-upload > div > select {
  padding: var(--spacing-2xs) var(--spacing-xs);
  width: 100%;
}

.font-upload > div > input {
  width: 100%;
}

.check-font-container > div.info,
.check-font-container > div.error {
  margin: 0;
  padding: var(--spacing-2xs) var(--spacing-xs);
  box-sizing: border-box;
  border: none;
}

.check-font-container > div.link {
  margin: var(--spacing-xs) 0;
}

@media (min-width: 640px) {
  .color-picker-container {
    display: flex;
  }
  .color-picker-container > div {
    width: 240px;
  }

  .text-upload > textarea {
    min-width: 50vw;
  }
  .image-upload {
    display: grid;
    grid-template-columns: 1fr 1fr 3fr;
    width: 50vw;
  }

  .image-upload > img {
    margin: 0;
  }
}

.btn-outline {
  border: 1px solid var(--base-color);
  border-radius: var(--border-radius);
  padding: var(--spacing-xs) var(--spacing-sm);
  margin: var(--spacing-sm) 0;
}

input,
select {
  padding: var(--spacing-2xs) var(--spacing-xs);
  line-height: 24px;
  box-sizing: border-box;
}

.btn-highlight {
  margin: var(--spacing-sm) 0;
  background-color: var(--highlight-color);
  color: white;
  border: none;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius);
}
.designer-title {
  font-weight: 600;
}

.input-container {
  padding: var(--spacing-sm);
  background-color: var(--base-color-medium);
  border-radius: var(--border-radius);
  margin: var(--spacing-md) 0;
}

.designer-card.card {
  min-height: 520px;
}

/* new user management  */

.privileges-column {
  width: 40%;
}
.active-column {
  width: 20%;
}

#paginator > .page-item.active .page-link {
  background-color: var(--highlight-color);
  border: var(--highlight-color);
}
.custom-checkbox .custom-control-input:checked ~ .custom-control-label::after {
  background-color: var(--highlight-color);
  border-radius: var(--border-radius);
}

.base-product-card.card,
.component-card.card {
  width: 22vw;
  min-width: 240px;
  height: 100%;
}

.base-product-card .price-tag {
  border: 1px solid var(--highlight-color);
  color: var(--highlight-color);
  border-radius: var(--border-radius);
  padding: var(--spacing-3xs) var(--spacing-xs);
  display: inline-block;
  margin-bottom: var(--spacing-sm);
}

.badge {
  background-color: white;
  color: var(--base-color-dark);
  font-size: 14px;
  display: inline-block;
}

.sr-only {
  display: none;
}

.components {
  margin-bottom: var(--spacing-2xl);
}

.left-indent {
  margin-left: var(--spacing-lg);
}

.modal-content {
  max-height: 80vh;
  overflow-y: scroll;
}

.bold {
  font-weight: 600;
}

input:read-only {
  color: grey;
}

.custom-radio > label {
  margin-left: var(--spacing-xs);
}

.navbar-toggler:hover {
  background-color: var(--highlight-color-alpha);
}

h5 {
  margin-bottom: var(--spacing-sm);
}

.grid .tick {
  stroke: rgb(34, 31, 31);
  opacity: 0.7;
}
.grid path {
  stroke-width: 0;
}

.link-videos {
  position: absolute;
  right: 16px;
}
