@font-face {
  font-family: "glacial indifference";
  src: url("/shared/fonts/gi/regular.woff2") format("woff2"), url("/shared/fonts/gi/regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "glacial indifference";
  src: url("/shared/fonts/gi/bold.woff2") format("woff2"), url("/shared/fonts/gi/bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "glacial indifference";
  src: url("/shared/fonts/gi/italic.woff2") format("woff2"), url("/shared/fonts/gi/italic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "kirppuicons";
  src: url("/shared/fonts/kirppuicons.eot?v=3");
  src: url("/shared/fonts/kirppuicons.eot?v=3#iefix") format("embedded-opentype"), url("/shared/fonts/kirppuicons.woff?v=3") format("woff"), url("/shared/fonts/kirppuicons.ttf?v=3") format("truetype"), url("/shared/fonts/kirppuicons.svg?v=3#kirppuicons") format("svg");
  font-weight: normal;
  font-style: normal;
}
[class^=icon-] {
  line-height: 0;
  font-size: 2rem;
}
[class^=icon-].large {
  font-size: 2.4rem;
}
[class^=icon-].green {
  color: #31AA47;
}
[class^=icon-]:before {
  display: inline-block;
  font-family: "kirppuicons";
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-add_item:before {
  content: "A";
}

.icon-add:before {
  content: "B";
}

.icon-archive:before {
  content: "C";
}

.icon-arrow_down:before {
  content: "D";
}

.icon-arrow_left:before {
  content: "E";
}

.icon-arrow_right:before {
  content: "F";
}

.icon-arrow_up:before {
  content: "G";
}

.icon-bag:before {
  content: "H";
}

.icon-bell:before {
  content: "I";
}

.icon-bill:before {
  content: "J";
}

.icon-block:before {
  content: "K";
}

.icon-building:before {
  content: "L";
}

.icon-calendar:before {
  content: "M";
}

.icon-chevron_down:before {
  content: "N";
}

.icon-chevron_left:before {
  content: "O";
}

.icon-chevron_right:before {
  content: "P";
}

.icon-chevron_up:before {
  content: "Q";
}

.icon-close:before {
  content: "R";
}

.icon-coins:before {
  content: "S";
}

.icon-copy_paste:before {
  content: "T";
}

.icon-danger:before {
  content: "U";
}

.icon-edit:before {
  content: "V";
}

.icon-expand:before {
  content: "W";
}

.icon-export:before {
  content: "X";
}

.icon-eye:before {
  content: "Y";
}

.icon-filter_remove:before {
  content: "Z";
}

.icon-filter_search:before {
  content: "a";
}

.icon-filter:before {
  content: "b";
}

.icon-flag:before {
  content: "c";
}

.icon-link:before {
  content: "d";
}

.icon-loading:before {
  content: "e";
}

.icon-location:before {
  content: "f";
}

.icon-log_out:before {
  content: "g";
}

.icon-login:before {
  content: "h";
}

.icon-menu:before {
  content: "i";
}

.icon-message:before {
  content: "j";
}

.icon-minus:before {
  content: "k";
}

.icon-money:before {
  content: "l";
}

.icon-note:before {
  content: "m";
}

.icon-placeholder:before {
  content: "n";
}

.icon-receipt:before {
  content: "o";
}

.icon-refresh:before {
  content: "p";
}

.icon-scan_barcode:before {
  content: "q";
}

.icon-scanner:before {
  content: "r";
}

.icon-search:before {
  content: "s";
}

.icon-settings_2:before {
  content: "t";
}

.icon-settings:before {
  content: "u";
}

.icon-shop_cart:before {
  content: "v";
}

.icon-shop:before {
  content: "w";
}

.icon-sort:before {
  content: "x";
}

.icon-tag:before {
  content: "y";
}

.icon-tasks:before {
  content: "z";
}

.icon-trash_bin:before {
  content: "0";
}

.icon-undo:before {
  content: "1";
}

.icon-ellipsis-vertical:before {
  content: "3";
}

.icon-quantity:before {
  content: "2";
}

.icon-checkbox:before {
  content: "4";
}

.icon-checked-checkbox:before {
  content: "5";
}

.icon-unprinted:before {
  content: "6";
}

.icon-printed:before {
  content: "7";
}

.icon-barcode:before {
  content: "8";
}

.icon-placeholder-image:before {
  content: "9";
}

.icon-offline:before {
  content: "!";
}

.icon-online:before {
  content: '"';
}

.icon-ai:before {
  content: "#";
}

.icon-heart:before {
  content: "$";
}

.icon-heart-filled:before {
  content: "%";
}

.icon-grid:before {
  content: "&";
}

.icon-listview:before {
  content: "'";
}

.icon-elektronik:before {
  content: "(";
}

.icon-underholdning:before {
  content: ")";
}

.icon-dame:before {
  content: "*";
}

.icon-hobby:before {
  content: "+";
}

.icon-bolig:before {
  content: ",";
}

.icon-smykke:before {
  content: "-";
}

.icon-born:before {
  content: ".";
}

.icon-herre:before {
  content: "/";
}

.icon-kaledyr:before {
  content: "[";
}

.icon-sport:before {
  content: "\\";
}

.icon-andet:before {
  content: "]";
}

*, *:before, *:after {
  box-sizing: border-box;
}

html, body, div, span, object, iframe, figure, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, code, em, img, small, strike, strong, sub, sup, tt, b, u, i, ol, ul, li, fieldset, form, label, table, caption, tbody, tfoot, thead, tr, th, td, main, canvas, embed, footer, header, nav, section, video, address, dl, dd, dt {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font-weight: normal;
  font: inherit;
  vertical-align: baseline;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  text-size-adjust: none;
  outline: none;
}

footer, header, nav, section, main {
  display: block;
}

body {
  line-height: 1;
  background-color: #fff;
}

ol, ul {
  list-style: none;
}

li {
  line-height: 1;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input {
  border-radius: 0;
  margin: 0;
}

picture {
  display: block;
  line-height: 0;
}

img, video {
  max-width: 100%;
  height: auto;
}

a {
  color: #4e9adb;
}

strong {
  font-weight: 600;
}

em {
  font-style: italic;
}

:root {
  --line-color: #e7e3e4;
}

html {
  font-size: 62.5%;
}

body {
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
}

body, input, textarea, select, button {
  font-family: "glacial indifference", sans-serif;
}

main, .container {
  position: relative;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.bold {
  font-weight: 700;
}

.text-xs {
  font-size: 1.2rem;
  line-height: 1.6rem;
}

.text-s {
  font-size: 1.4rem;
  line-height: 2rem;
}

.text-m {
  font-size: 1.6rem;
  line-height: 2.2rem;
}

.text-l {
  font-size: 1.8rem;
  line-height: 2.4rem;
}

.header-xs {
  font-size: 2rem;
  line-height: 2.8rem;
}

.header-s {
  font-size: 2.4rem;
  line-height: 3.2rem;
}

.header-m {
  font-size: 2.8rem;
  line-height: 3.6rem;
}

.header-l {
  font-size: 3.6rem;
  line-height: 4rem;
}

.display-xs {
  font-size: 4.4rem;
  line-height: 4.8rem;
}

.display-s {
  font-size: 6rem;
  line-height: 6.8rem;
}

.display-m {
  font-size: 7.6rem;
  line-height: 8.4rem;
}

.display-l {
  font-size: 9.2rem;
  line-height: 10rem;
}

:root {
  --header-height: 72px;
}

header {
  background-color: #F2F2F2;
  padding: 0 16px;
  height: var(--header-height);
  position: sticky;
  top: 0;
  z-index: 1;
}
header .container {
  max-width: 1164px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}
header #header-content {
  display: flex;
  align-items: center;
  column-gap: 20px;
}
header #header-content ul {
  display: flex;
  align-items: center;
  column-gap: 20px;
}
header #header-content ul li a {
  color: inherit;
  text-decoration: none;
  font-size: 1.6rem;
  line-height: 2.2rem;
  transition: all 0.2s ease-in-out;
}
header #header-content ul li a.current {
  color: #31aa47;
  font-weight: 700;
}
header #header-content ul li a:hover {
  color: #31aa47;
}
header #header-content ul:after {
  content: "";
  border-right: 1px solid #000;
  height: 36px;
}
@media screen and (max-width: 960px) {
  header #header-content ul {
    display: none;
  }
  header #header-content .header-profile span {
    display: none;
  }
}
header .header-profile {
  display: flex;
  align-items: center;
  column-gap: 10px;
}
header .header-profile svg, header .header-profile img {
  width: 40px;
  height: 40px;
  border-radius: 100%;
}
header .header-profile svg {
  background-color: #fff;
  border: 1px solid #31aa47;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
header .header-profile span {
  display: inline-flex;
  flex-direction: column;
  font-size: 1.4rem;
  line-height: 2rem;
  line-height: 1;
}
header .header-profile span strong {
  font-size: 1.6rem;
  line-height: 2.2rem;
}
header #menu-content {
  position: fixed;
  top: 0;
  background-color: #fff;
  z-index: 2;
  left: 0;
  width: 100%;
  height: 100vh;
  padding: 16px;
  display: none;
  flex-direction: column;
}
@media screen and (min-width: 961px) {
  header #menu-content {
    left: unset;
    max-width: 400px;
    right: max(0px, (100vw - 1164px) / 2);
    box-shadow: 5px 0 10px -5px rgba(0, 0, 0, 0.3), -5px 0 10px -5px rgba(0, 0, 0, 0.3);
    top: var(--header-height);
    height: auto;
  }
}
header #menu-content .header-profile {
  border-bottom: 1px solid #f2f2f2;
  margin: 0 -16px;
  padding: 0 16px 8px;
}
header #menu-content .header-profile svg, header #menu-content .header-profile img {
  width: 60px;
  height: 60px;
}
header #menu-content .header-profile span {
  font-size: 1.6rem;
  line-height: 2.2rem;
}
header #menu-content .header-profile .icon-close {
  font-size: 2.4rem;
}
header #menu-content ul {
  margin-top: 16px;
}
header #menu-content ul li {
  height: 40px;
  display: flex;
  align-items: center;
}
header #menu-content ul li a {
  color: inherit;
  text-decoration: none;
  font-size: 1.6rem;
  line-height: 2.2rem;
  transition: all 0.2s ease-in-out;
  display: flex;
  align-items: center;
  width: 100%;
  column-gap: 8px;
}
header #menu-content ul li a .icon-chevron_right {
  margin-left: auto;
}
header #menu-content ul li a.current {
  color: #31aa47;
  font-weight: 700;
}
header #menu-content ul li a:hover {
  color: #31aa47;
}
header #menu-content ul li.line {
  height: 1px;
  background-color: #bfbfbf;
  margin-top: 8px;
  margin-bottom: 8px;
}
header #menu-content .logout {
  margin-top: 20px;
}
@media screen and (min-width: 961px) {
  header #menu-content .logout {
    margin-bottom: 20px;
  }
}
header #menu-content .icon-close {
  margin-left: auto;
  cursor: pointer;
}

.component-title {
  font-size: 1.6rem;
  line-height: 2.2rem;
}
.component-title.medium {
  font-size: 1.8rem;
  line-height: 2.4rem;
}
.component-title.large {
  font-size: 2rem;
  line-height: 2.8rem;
}
.component-title.underline {
  border-bottom: 1px solid #bfbfbf;
  padding-bottom: 8px;
  margin-bottom: 8px;
}
.component-title.iconleft, .component-title.iconright {
  display: flex;
  align-items: center;
  width: 100%;
}
.component-title.textright {
  /*justify-content: space-between;
  text-align: right;*/
}
.component-title.iconright {
  justify-content: space-between;
}
.component-title span[class^=icon-] {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
}
.component-title .icons {
  display: flex;
  column-gap: 16px;
}
@media screen and (max-width: 960px) {
  .component-title .icons {
    column-gap: 8px;
  }
}
.component-title .helper {
  color: #404040;
  display: block;
  font-weight: normal;
}

.component-button {
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid;
  height: 4.8rem;
  width: 335px;
  max-width: 100%;
  outline: none;
  font-size: 1.6rem;
  line-height: 2.2rem;
  font-weight: 700;
  text-decoration: none;
}
.component-button a {
  text-decoration: none;
}
.component-button:focus-visible {
  outline: 3px solid;
  outline-offset: 2px;
}
.component-button.hidden {
  display: none;
}
.component-button.unbold {
  font-weight: normal;
}
.component-button.text {
  border: none;
  background: none;
  width: auto;
  font-weight: normal;
}
.component-button.black {
  color: unset;
}
.component-button.red {
  color: #DD3531 !important;
}
.component-button.red:focus {
  outline-color: #DD3531 !important;
}
.component-button.icon {
  background: transparent;
  border: none;
  width: auto;
  height: auto;
  padding: 0;
  color: #31aa47;
}
.component-button.icon.black {
  color: unset;
}
.component-button.icon span[class^=icon-] {
  justify-content: center;
}
.component-button.icon2 {
  width: auto;
  height: 42px;
}
.component-button.rounded {
  background: #fff;
  border-color: #31aa47;
  color: #31aa47;
  height: 4rem;
  border-radius: 4rem;
  font-weight: normal;
  width: auto;
  padding: 0 16px;
}
.component-button.primary {
  background-color: #31aa47;
  border-color: #31aa47;
  color: #fff;
}
.component-button.primary[disabled] {
  background-color: #e0e0e0;
  border-color: #e0e0e0;
  color: #cecece;
  cursor: default;
}
.component-button.primary:focus-visible {
  outline-color: #31aa47;
}
.component-button.secondary {
  background-color: #fff;
  border-color: #31aa47;
  color: #31aa47;
}
.component-button.secondary[disabled] {
  background-color: #fff;
  border-color: #e0e0e0;
  color: #e0e0e0;
  cursor: default;
}
.component-button.secondary:focus-visible {
  outline-color: #31aa47;
}
.component-button.tertiary {
  background-color: #fff;
  border-color: transparent;
  color: #31aa47;
}
.component-button.tertiary:focus-visible {
  outline-color: #31aa47;
}
.component-button.danger {
  background-color: #DD3531;
  color: #fff;
  border-color: #DD3531;
}
.component-button.medium {
  height: 4rem;
  font-size: 1.4rem;
  line-height: 2rem;
}
.component-button.small {
  height: 3.4rem;
  font-size: 1.2rem;
  line-height: 1.6rem;
}
.component-button.fluid {
  width: auto;
  padding-left: 1.2rem;
  padding-right: 1.2rem;
}
.component-button.wide {
  width: 100%;
}
.component-button a {
  text-decoration: none;
  color: inherit;
  display: inherit;
  align-items: inherit;
}
@media screen and (max-width: 960px) {
  .component-button.mobilehidetext .text {
    display: none;
  }
}

.component-icon-text {
  display: flex;
  align-items: center;
  column-gap: 4px;
}
.component-icon-text span[class^=icon-] {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.component-checkbox {
  display: flex;
  align-items: center;
  column-gap: 10px;
  position: relative;
}
.component-checkbox:focus-within .tooltip {
  opacity: 1;
  transform: translateY(0);
}
.component-checkbox.hidden {
  display: none;
}
.component-checkbox input[type=checkbox] {
  appearance: none;
  width: 24px;
  height: 24px;
  margin: 8px;
  border-radius: 8px;
  border: 1px solid #31aa47;
  position: relative;
  cursor: pointer;
}
.component-checkbox input[type=checkbox]:checked {
  /*background-color: #a2ffae;*/
}
.component-checkbox input[type=checkbox]:checked:after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg%20width='13'%20height='10'%20viewBox='0%200%2013%2010'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M11.75%200.500008L3.875%209.50001L0.5%206.12501'%20stroke='%2331AA47'%20stroke-linecap='round'%20stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  width: 14px;
  height: 14px;
  left: 50%;
  top: 50%;
  margin: -6px 0 0 -6px;
}
.component-checkbox.compact input[type=checkbox] {
  margin: 0;
  width: 16px;
  height: 16px;
  border-radius: 4px;
}
.component-checkbox.background input[type=checkbox] {
  border-color: #a2ffae;
  background-color: #31aa47;
}
.component-checkbox.background input[type=checkbox]:checked:after {
  background-image: url("data:image/svg+xml,%3Csvg%20width='13'%20height='10'%20viewBox='0%200%2013%2010'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M11.75%200.500008L3.875%209.50001L0.5%206.12501'%20stroke='%23a2ffae'%20stroke-linecap='round'%20stroke-linejoin='round'/%3E%3C/svg%3E");
}
.component-checkbox.background-on-select input[type=checkbox]:checked {
  border-color: #a2ffae;
  background-color: #31aa47;
}
.component-checkbox.background-on-select input[type=checkbox]:checked:after {
  background-image: url("data:image/svg+xml,%3Csvg%20width='13'%20height='10'%20viewBox='0%200%2013%2010'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M11.75%200.500008L3.875%209.50001L0.5%206.12501'%20stroke='%23a2ffae'%20stroke-linecap='round'%20stroke-linejoin='round'/%3E%3C/svg%3E");
}
.component-checkbox label {
  cursor: pointer;
}
.component-checkbox .tooltip {
  position: absolute;
  top: 80%;
  left: 0;
  background: #333;
  color: #fff;
  padding: 6px 8px;
  font-size: 14px;
  border-radius: 4px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(4px);
  transition: opacity 0.15s, transform 0.15s;
  width: 200px;
}

.component-text-input, .component-select-input, .component-textarea-input, .component-upload-input {
  padding-bottom: 8px;
}
.component-text-input label, .component-select-input label, .component-textarea-input label, .component-upload-input label {
  display: block;
  position: relative;
}
.component-text-input label span[class^=icon-], .component-select-input label span[class^=icon-], .component-textarea-input label span[class^=icon-], .component-upload-input label span[class^=icon-] {
  width: auto;
  height: auto;
  position: absolute;
  right: 0;
  font-size: 1.6rem;
  align-self: end;
  cursor: pointer;
}
.component-text-input input, .component-select-input input, .component-textarea-input input, .component-upload-input input {
  font-family: sans-serif;
}
.component-text-input input, .component-text-input select, .component-text-input textarea, .component-text-input .upload, .component-select-input input, .component-select-input select, .component-select-input textarea, .component-select-input .upload, .component-textarea-input input, .component-textarea-input select, .component-textarea-input textarea, .component-textarea-input .upload, .component-upload-input input, .component-upload-input select, .component-upload-input textarea, .component-upload-input .upload {
  margin: 8px 0;
}
.component-text-input textarea, .component-select-input textarea, .component-textarea-input textarea, .component-upload-input textarea {
  height: 120px;
}
.component-text-input .errortext, .component-select-input .errortext, .component-textarea-input .errortext, .component-upload-input .errortext {
  color: #BC221F;
  display: none;
  margin-bottom: 8px;
}
.component-text-input .helptext, .component-select-input .helptext, .component-textarea-input .helptext, .component-upload-input .helptext {
  display: none;
  color: #587d62;
}
.component-text-input .helptext.default, .component-select-input .helptext.default, .component-textarea-input .helptext.default, .component-upload-input .helptext.default {
  display: block;
}
.component-text-input.error input, .component-select-input.error input, .component-textarea-input.error input, .component-upload-input.error input {
  border-color: #BC221F;
}
.component-text-input.error .errortext, .component-select-input.error .errortext, .component-textarea-input.error .errortext, .component-upload-input.error .errortext {
  display: block;
}
.component-text-input.error2 input, .component-select-input.error2 input, .component-textarea-input.error2 input, .component-upload-input.error2 input {
  border-color: #BC221F;
}

.component-double-input {
  display: flex;
  column-gap: 8px;
}
.component-double-input .component-text-input, .component-double-input .component-select-input, .component-double-input .component-textarea-input {
  flex-basis: 50%;
}
@media screen and (max-width: 960px) {
  .component-double-input {
    display: unset;
  }
}

input, textarea, select {
  border-radius: 8px;
  padding: 10px;
  background-color: #fff;
  border: 1px solid #B4B4B4;
  width: 100%;
  height: 42px;
  font-size: 1.6rem;
  outline: none;
}
input::placeholder, textarea::placeholder, select::placeholder {
  color: rgba(0, 0, 0, 0.4);
}
input.shake, textarea.shake, select.shake {
  animation: input-shake 0.2s ease;
}

select {
  appearance: none;
  position: relative;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="10"><polyline points="0,0 5,5 10,0" stroke="black" fill="none" stroke-width="2"/></svg>');
  background-repeat: no-repeat;
  background-position: right 0.8em center;
  background-size: 0.5em 0.5em;
}

.autocomplete {
  background: #fff;
  z-index: 1000;
  overflow: auto;
  box-sizing: border-box;
  border: 1px solid rgba(50, 50, 50, 0.6);
}
.autocomplete * {
  font: inherit;
}
.autocomplete > div {
  padding: 2px 4px;
  line-height: 1.4;
}
.autocomplete .group {
  background: #eee;
}
.autocomplete > div.selected, .autocomplete > div:hover:not(.group) {
  background: #81ca91;
  cursor: pointer;
}

.quantity {
  position: relative;
}
.quantity button.icon {
  margin: 8px 0;
  background-color: #31aa47;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  cursor: pointer;
  position: absolute;
  top: 0;
  width: 40px !important;
  height: 42px !important;
}
.quantity button.icon.minus {
  border-radius: 8px 0 0 8px;
  left: 0;
}
.quantity button.icon.plus {
  border-radius: 0 8px 8px 0;
  right: 0;
}
.quantity input {
  border-left: none;
  border-right: none;
  border-radius: 0;
  text-align: center;
  width: calc(100% - 40px - 40px);
  margin-left: 40px;
}
.quantity input::-webkit-outer-spin-button, .quantity input::-webkit-inner-spin-button {
  appearance: none;
}

.component-upload-input {
  position: relative;
}
.component-upload-input .upload-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  text-align: center;
  width: 100%;
}
.component-upload-input .upload {
  display: inline-flex;
  justify-content: center;
  column-gap: 10px;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
}
.component-upload-input .upload.active {
  padding: 10px 0;
}
.component-upload-input .upload.invalid {
  border-color: #BC221F;
}
.component-upload-input .upload.invalid + .errortext, .component-upload-input .upload.invalid ~ .errortext {
  display: block;
}
.component-upload-input .upload.shake {
  animation: input-shake 0.2s ease;
}
.component-upload-input .upload .add-image-placeholder {
  width: 128px;
  height: 128px;
  min-width: 128px;
  border-radius: 8px;
  border: 1px solid #D9D9D9;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.component-upload-input .upload .add-image-placeholder span {
  display: block;
  margin-bottom: 10px;
}
.component-upload-input .upload .upload-item {
  text-align: center;
  cursor: pointer;
  flex: 0 0 auto;
  scroll-snap-align: start;
  position: relative;
}
.component-upload-input .upload .upload-item .image {
  background-image: url(/mit/assets/blank_image.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  width: 128px;
  height: 128px;
  border-radius: 8px;
  border: 1px solid #D9D9D9;
  position: relative;
  margin: 0 auto;
}
.component-upload-input .upload .upload-item .text-primary {
  margin-top: 5px;
  display: none;
  color: #268337;
}
.component-upload-input .upload .upload-item .text-makeprimary {
  margin-top: 5px;
  text-decoration: underline;
}
.component-upload-input .upload .upload-item .trash {
  width: 40px;
  height: 40px;
  color: #bc221f;
  display: inline-flex;
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  align-items: center;
  justify-content: center;
}
.component-upload-input .upload .upload-item .working {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 2;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 8px;
}
.component-upload-input .upload .upload-item .working .spin {
  transform-origin: 25px 25px;
  animation: spin 2s linear infinite;
}
.component-upload-input .upload .upload-item.inprogress .trash {
  display: none;
}
.component-upload-input .upload .upload-item.inprogress .working {
  display: flex;
}
.component-upload-input .upload .upload-item.primary-selected .image {
  border-color: #31aa47;
}
.component-upload-input .upload .upload-item.primary-selected .text-primary {
  display: block;
}
.component-upload-input .upload .upload-item.primary-selected .text-makeprimary {
  display: none;
}

@keyframes input-shake {
  0% {
    transform: translateX(0);
  }
  20% {
    transform: translateX(-4px);
  }
  40% {
    transform: translateX(4px);
  }
  60% {
    transform: translateX(-4px);
  }
  80% {
    transform: translateX(4px);
  }
  100% {
    transform: translateX(0);
  }
}
main {
  max-width: 1100px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  main {
    padding: 0 10px;
  }
  main.outside {
    padding: 0;
  }
}
main .app-message {
  background-color: #f4991a;
  color: #fff;
  padding: 10px;
  position: relative;
  margin-top: 10px;
}
main .app-message .close {
  position: absolute;
  right: 10px;
  top: 10px;
  font-size: 3rem;
  line-height: 0;
  cursor: pointer;
}
main .path {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 26px 0;
  font-size: 1.6rem;
}
main .path [class^=icon-] {
  font-size: 1.6rem;
}
main .path .current {
  font-weight: 600;
}
main .path span {
  white-space: nowrap;
}
main .path a {
  text-decoration: none;
  color: inherit;
}
main .header {
  padding-bottom: 8px;
  margin-bottom: 16px;
}
main .header.variant1 {
  border-bottom: 2px dashed #bfbfbf;
  margin-top: 16px;
}
main [class^=header-] {
  margin-bottom: 16px;
}
main .table {
  --border: 1px solid #bfbfbf;
  border-left: var(--border);
}
main .table .table-header {
  background-color: #E3F7E7;
  display: inline-flex;
  min-width: 100%;
  width: max-content;
  align-items: center;
  border-top: var(--border);
}
main .table .table-row {
  display: flex;
}
main .table .cell {
  padding: 12px 8px;
  border-bottom: var(--border);
  border-right: var(--border);
}
main .table .cell.image {
  width: 70px;
  min-width: 70px;
}
main .table .cell.image a {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  display: block;
  aspect-ratio: 1;
}
main .table .cell.time {
  width: 60px;
  min-width: 60px;
}
main .table .cell.date {
  width: 110px;
  min-width: 110px;
}
main .table .cell.text {
  width: 100%;
}
@media screen and (max-width: 960px) {
  main .table .cell.payoutremark {
    min-width: 160px;
  }
}
@media screen and (max-width: 960px) {
  main .table .cell.stand {
    width: 150px;
    min-width: 150px;
  }
}
@media screen and (max-width: 960px) {
  main .table .cell.invoice {
    min-width: 160px;
  }
}
main .table .cell.shop {
  width: 150px;
  min-width: 150px;
}
main .table .cell.type {
  width: 190px;
  min-width: 190px;
}
main .table .cell.type2 {
  width: 140px;
  min-width: 140px;
}
main .table .cell.account {
  width: 160px;
  min-width: 160px;
}
main .table .cell.cctv-shop {
  width: 100%;
}
@media screen and (max-width: 960px) {
  main .table .cell.cctv-shop {
    white-space: nowrap;
    min-width: 160px;
  }
}
main .table .cell.amount {
  width: 120px;
  min-width: 120px;
  text-align: right;
}
main .table .cell.amount2 {
  width: 200px;
  min-width: 200px;
  text-align: right;
}
main .table .cell.username {
  width: 160px;
  min-width: 160px;
}
main .salg, main #udbetalingertable, main #fakturatable, main #betalingertable {
  margin-bottom: 16px;
}
main .sale-group .date {
  margin-bottom: 8px;
}
main .sale-group .table {
  margin-bottom: 16px;
}
main .chart-filters {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}
main .chart-filters select {
  max-width: 200px;
}
main .chart .buttons {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  margin-bottom: 16px;
  column-gap: 32px;
}
main .chart .buttons .component-button {
  background-color: #fff;
  border-color: #bfbfbf;
  max-width: 180px;
}
@media screen and (max-width: 960px) {
  main .chart .buttons .component-button {
    max-width: 80px;
  }
}
main #chart {
  border: 1px solid #bfbfbf;
  padding: 8px;
}
main .message {
  padding: 10px;
  margin-bottom: 16px;
}
main .message.error, main .message.validation_error {
  background-color: #DD3531;
  color: #fff;
}
main .message.success {
  background-color: #94E0A2;
}
main .payments-group {
  border: 1px solid #bfbfbf;
  padding: 10px;
  margin-bottom: 16px;
}
main .payments-group form .component-button {
  margin-top: 16px;
}
main .payments-group p {
  line-height: 1.3;
  margin-bottom: 16px;
}

.outside-header {
  background-image: url(/mit/assets/b7725b71459e06038cb2ba7d1263bb08932bac1d.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 100px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  font-size: 4.4rem;
  line-height: 4.8rem;
  font-weight: 700;
  position: relative;
}
.outside-header:before {
  content: "";
  background: rgba(38, 131, 55, 0.5);
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}
.outside-header span {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 960px) {
  .outside-header {
    height: 25vh;
  }
  .outside-header:after {
    content: "";
    background: #fff;
    border-radius: 20px 20px 0 0;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 16px;
  }
}

.outside-panel {
  margin: 32px auto;
  max-width: 440px;
  border: 1px solid #d9d9d9;
  border-radius: 8px;
  min-height: calc(100vh - var(--header-height) - 100px - 64px);
  padding: 16px;
  display: flex;
  flex-direction: column;
}
.outside-panel .header-s {
  text-align: center;
  padding-top: 16px;
}
.outside-panel form {
  padding: 16px;
  flex-grow: 1;
}
.outside-panel img {
  margin: 0 auto 16px;
}
.outside-panel p {
  font-size: 1.6rem;
  line-height: 2.2rem;
}
.outside-panel p.center {
  text-align: center;
}
.outside-panel .forgot {
  font-size: 1.4rem;
  line-height: 2rem;
  display: block;
  margin-bottom: 32px;
}
.outside-panel .forgot a {
  color: #404040;
}
.outside-panel .wrong {
  color: #BC221F;
  border: 1px solid #d9d9d9;
  padding: 16px 8px 8px;
  position: relative;
  margin-bottom: 16px;
  line-height: 1.4;
}
.outside-panel .wrong:before {
  content: "";
  display: block;
  height: 8px;
  background-color: #BC221F;
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
}
.outside-panel #duplicate_email {
  line-height: 1.4;
  margin-bottom: 16px;
}
.outside-panel #duplicate_email .error {
  color: #BC221F;
}
.outside-panel #duplicate_email a {
  color: #404040;
}
.outside-panel .confirmation-code {
  display: flex;
  column-gap: 10px;
  justify-content: center;
}
.outside-panel .confirmation-code .component-text-input input {
  width: 40px;
  height: 60px;
  text-align: center;
}
@media screen and (max-width: 960px) {
  .outside-panel {
    border-radius: 0;
    border: none;
    margin: 0;
    padding: 0;
    min-height: calc(100vh - var(--header-height) - 25vh - 8px);
  }
}

#sticky-footer {
  background-color: #31aa47;
  color: #fff;
  padding: 10px;
  position: sticky;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  column-gap: 10px;
  font-size: 1.4rem;
}
#sticky-footer a {
  color: #fff;
  text-decoration: none;
  text-align: center;
  display: flex;
  flex-direction: column;
  row-gap: 5px;
}
#sticky-footer a span {
  display: block;
}
#sticky-footer a.current {
  color: #000;
}

#create-state-1 {
  display: block;
}

#create-state-2 {
  display: none;
}
#create-state-2 #confirmation-error {
  display: none;
  color: #DD3531;
}