/**
 * Separate Datei für spezifische Änderungen
 * Hintergrund: Administratoren können in Backend die "Moms" bearbeiten (Menu --> Verwaltung --> Benutzer --> (Tab) MOM Einsgellungen.
 * Das Design entspricht dem Desing in Frontend, in Backend soll die Ansicht genau so sein, wie im Frontend.
 * Problem: man kann nicht die komplette freemom-template.css Datei in Backend reinladen.
 */

/* variables */
:root {
    --freemom-color-success: var(--qui-message-success-color);
    --freemom-color-success-light: var(--qui-message-success-color-light);
    --freemom-color-attention: var(--qui-message-attention-color);
    --freemom-color-attention-light: var(--qui-message-attention-color-light);
    --freemom-color-danger: var(--qui-message-error-color);
    --freemom-color-danger-light: var(--qui-message-error-color-light);
    --freemom-color-light: #e6e8eb;

    --freemom-bg-light: #f6f7fb;
    --freemom-border-color: #ded5d4;
    --freemom-border-color-light: #e6e6eb;
    --mom-border-color-translucent: rgba(97, 104, 118, 0.16);
    --qui-color-secondary: #2E054D;
    --qui-color-secondary--light: #503880;
    --qui-fs-1: 2.5rem;
    --qui-fs-2: 2.074rem;
    --qui-fs-3: 1.728rem;
    --qui-fs-4: 1.44rem;
    --qui-fs-5: 1.2rem;

    --freemom-gap: var(--freemom-spacing);
    --freemom-gap-lg: calc(var(--freemom-gap) * 2);
    --freemom-gap-md: calc(var(--freemom-gap) * 1.5);
    --freemom-gap-sm: calc(var(--freemom-gap) / 2);
    --freemom-gap-xs: calc(var(--freemom-gap) / 4);

    --freemom-border-radius: 1rem;
    --freemom-border-radius-sm: calc(0.5 * var(--freemom-border-radius));

    --qui-message-attention-color: var(--qui-message-warning-color);
    --qui-message-attention-color-light: var(--qui-message-warning-color-light);
    --qui-message-error-color: #dc473a;
    --qui-message-error-color-light: #fdf2f1;
    --qui-message-information-color: #5ec4f0;
    --qui-message-information-color-light: #ddf3fc;
    --qui-message-success-color: #74b816;
    --qui-message-success-color-light: #ecf8ec;
    --qui-message-warning-color: #ffc65d;
    --freemom-application-color: #6366f1;
    --freemom-application-color-light: #f2f2fd;
    --freemom-application-color-accent: #fff;

    --qui-message-warning-color-dark: orange;
    --qui-message-warning-color-light: #fff6e5;
    --freemom-spacing: 1.5rem; /* base */
    --freemom-spacing-md: 2rem;
    --freemom-spacing-sm: 1rem;
    --freemom-spacing-xs: 0.5rem;

    --freemom-spacing-landingpage: 5rem;
    --freemom-color-bg: url('/media/cache/freemom/Unternehmen/freemom-bg.webp');

    --qui-form-input-bg: #f1f3f7;

    --qui-transition-fast: 0.15s all ease;
    --qui-transition-duration-fast: 0.15s;
    --qui-transition-normal: 0.3s all ease;
    --qui-transition-duration-normal: 0.3s;

    --freemom-status-color-Created: #616876;
    --freemom-status-color-ApplicationPending: #f59f00;
    --freemom-status-color-Successful: #2fb344;
    --freemom-status-color-Cancelled: #d63939;
    --freemom-status-color-SubmittedForReview: #206bc4;
    --freemom-status-color-Rejected: #ae3ec9;
    --freemom-status-color-Accepted: #5bc7c7;
    --freemom-status-color-Billing: #b2ebf2;
    --freemom-status-color-Contracting: #039be5;
    --freemom-status-color-TimeTracking: #90caf9;
    --freemom-status-color-Accounting: #90f9e6;
    --freemom-status-color-StatementOfWork: #ffcc80;
    --freemom-status-color-Vetting: #ffeb3b;
    --freemom-status-color-Rating: #9ccc65;

    --max-container-width: 1400px;
    --max-width-600: 600px;
    --max-narrow-content-width: 750px;
    --menu-logo-height: 40px;
    --menu-logo-block-margin: 10px;
}

@media screen and (max-width: 1600px) {
    :root {
        --qui-fs-1: 2.25rem;
        --qui-fs-2: 2.074rem;
        --qui-fs-3: 1.728rem;
        --qui-fs-4: 1.44rem;
        --qui-fs-5: 1.2rem;
    }
}

@media screen and (max-width: 1200px) {
    :root {
        --freemom-spacing: 1rem; /* base */
        --freemom-spacing-md: 1.25rem;
        --freemom-spacing-sm: 0.75rem;
        --freemom-spacing-xs: 0.5rem;

        --freemom-spacing-landingpage: 4rem;
    }
}


@media screen and (max-width: 767px) {
    :root {
        --qui-fs-1: 2rem;
        --qui-fs-2: 1.325rem;
        --qui-fs-3: 1.175rem;
        --qui-fs-4: 1.125rem;
        --qui-fs-5: 1.05rem;

        --freemom-border-radius: 0.75rem;
        --freemom-spacing-landingpage: 2rem;

        --menu-logo-height: 30px;
    }
}

@media screen and (min-width: 1800px) {
    :root {
        --max-container-width: clamp(1400px, 80vw, 2400px);
        --max-width-600: clamp(800px, 50vw, 1200px);
        --max-narrow-content-width: clamp(750px, 50vw, 1000px);
        --menu-logo-height: 60px;
        --menu-logo-block-margin: 20px;

        /* text: font size */
        --qui-fs-body: clamp(16px, calc(0.7vw - 1px), 21px); /* base */

        --qui-body-container-top: 120px !important;
        --qui-nav-height: 120px !important;
    }

    /**
      1. ugly hack because of how template presentation set the --qui-body-container-top
      variable if there is a brick in the header brick area.
     */
    .header-brick-area.start-page-header:first-child {
        margin-top: -120px; /* 1 */
    }
}

body .qui-select {
    padding-left: calc(1.25em - 2px);
    padding-right: calc(1.25em - 2px);
}

.text-lead, .lead {
    line-height: 1.5;
}

body .control-content {
    margin-bottom: calc(1.5 * var(--freemom-spacing));
    padding-bottom: 0;
}

.freemom-help {
    width: 1.5rem;
    line-height: 1.5rem;
    display: inline-block;
    background: var(--qui-color-main);
    text-align: center;
    border-radius: 50%;
    color: #fff;
    font-weight: bold;
    cursor: help;
}

.freemom-help:before {
    content: '?';
}

/*****************************/
/* QUI Loader position fixed */
/*****************************/
.qui-loader-inner .fa-circle-notch {
    margin-bottom: 2rem;
    margin-top: 2rem;
    position: fixed !important;
    top: 50% !important;
}

/*************/
/* container */
/*************/
.gap-sm {
    gap: var(--freemom-gap-sm) !important;
}

.gap-xs {
    gap: var(--freemom-gap-xs) !important;
}

.gap {
    gap: var(--freemom-gap) !important;
}

.gap-md {
    gap: var(--freemom-gap-md) !important;
}

.gap-lg {
    gap: var(--freemom-gap-lg) !important;
}

.container {
    display: flex;
    gap: var(--freemom-gap);
    margin-bottom: var(--freemom-spacing);
    margin-top: var(--freemom-spacing);
}

.container.wrap {
    flex-wrap: wrap;
}

.container > .freemom-card-container {
    margin-top: 0;
    margin-bottom: 0;
}

.container > .freemom-card-container_main {
    flex-grow: 1;
    width: calc(75% - var(--freemom-gap));
}

.container > .freemom-card-container_aside {
    min-width: 250px;
    width: 25%;
    position: sticky;
    top: calc(80px + var(--freemom-spacing));
    align-self: flex-start;
    flex-grow: 1;
}

@media screen and (max-width: 1000px) {
    .container > .freemom-card-container_aside {
        width: 100%;
    }
}

/* container with bigger gap */
.container.container__md {
    gap: var(--freemom-gap-md);
}

.container.container__md > .freemom-card-container_main {
    width: calc(75% - var(--freemom-gap-md));
}

/* highlight card */
.freemom-card__success {
    outline: 2px solid var(--freemom-color-success);
}

.freemom-card__attention {
    outline: 2px solid var(--freemom-color-attention)
}

.freemom-card__danger {
    outline: 2px solid var(--freemom-color-danger)
}

/****************************/
/* Extra freemom list style */
/****************************/
ul.freemom-list {
    list-style-type: none;
    margin-left: 2rem;
    padding-left: 0;
}

ul.freemom-list > li {
    margin-bottom: 1.5rem;
    padding: 0;
    position: relative;
}

ul.freemom-list > li:before {
    color: var(--qui-color-primary);
    content: "\f05d";
    font-size: 1.5em;
    line-height: 1;
    font-family: 'FontAwesome';
    left: -2rem;
    position: absolute;
}

ul.freemom-list--white > li:before {
    color: #fff;
}

.freemom-boxes-4er .grid-children {
    overflow: visible !important;
}

.freemom-boxes-4er .control-content {
    padding-bottom: 0;
}

.freemom-boxes-4er .quiqqer-boxContentAdvanced-4 {
    flex-grow: 1;
    min-width: 250px;
}

.freemom-boxes-4er .quiqqer-boxContentAdvanced-entry {
    border-bottom: 5px solid var(--qui-color-primary);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
    margin: 20px;
    padding: 1.5rem;
    width: 100%;
}

.freemom-boxes-4er .quiqqer-boxContentAdvanced-entry p {
    text-align: left;
}

/***************************/
/* Card List ***************/
/* Container for card list */
/***************************/
.freemom-cardList {
    background-color: var(--freemom-bg-light);
    border-radius: 1rem;
    gap: var(--freemom-spacing);
    padding: calc(1.5 * var(--freemom-spacing)) calc(1.5 * var(--freemom-spacing)) calc(1.5 * var(--freemom-spacing)) calc(1.5 * var(--freemom-spacing));
}

.freemom-cardList__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(18rem, 100%), 1fr));
}

.freemom-cardList__grid .freemom-card {
    height: 100%;
}

.freemom-cardList__grid.freemom-cardList__small {
    gap: var(--freemom-spacing-sm);
    grid-template-columns: repeat(auto-fill, minmax(min(14rem, 100%), 1fr));
}

/* no results info */
.noResultsInfo,
.freemom-cardList__grid .card-list-noResultsInfo {
    text-align: center;
    color: var(--qui-color-muted);
    max-width: 38rem;
    margin: calc(2 * var(--freemom-spacing)) auto calc(2 * var(--freemom-spacing));
}

.freemom-cardList__grid .card-list-noResultsInfo {
    grid-column-start: 1;
    grid-column-end: -1;
}


/********/
/* card */
/********/
.freemom-card-container {
    background-color: var(--freemom-bg-light);
    border-radius: 1rem;
    margin-bottom: var(--freemom-spacing);
    margin-top: var(--freemom-spacing);
    padding: calc(1.5 * var(--freemom-spacing)) calc(1.5 * var(--freemom-spacing)) calc(1.5 * var(--freemom-spacing));
}

@media screen and (max-width: 767px) {
    .freemom-card-container {
        /*margin-bottom: calc(1.5 * var(--freemom-spacing));*/
        /*margin-top: calc(1.5 * var(--freemom-spacing));*/
    }
}

.freemom-card-container__sm {
    padding: var(--freemom-spacing);
}

.freemom-card {
    background-color: #fff;
    border: 1px solid #e6e6eb;
    border-radius: 1rem;
    --freemom-card-titleSpacing: var(--freemom-spacing);
    display: flex;
    flex-direction: column;
    padding: var(--freemom-spacing);
    position: relative;
}

.freemom-card-highlighted {
    border: 3px solid #ff770b;
}

.freemom-card p {
    text-align: left;
}

/* card title */
.freemom-card-title {
    align-items: flex-start;
    border-bottom: 1px solid var(--freemom-border-color-light);
    display: flex;
    margin-bottom: var(--freemom-spacing);
    padding-bottom: calc(0.5 * var(--freemom-spacing));
    --font-size: 1rem;
    --font-size-icon: 1.25rem;
}

.freemom-card-title h2 {
    font-size: var(--font-size);
    line-height: var(--qui-line-height);
    margin: 0;
    padding: 0;
}

.freemom-card-title > h2 > .fa {
    font-size: var(--font-size-icon);
    margin-right: 0.5rem;
    text-align: center;
    vertical-align: middle;
    width: 1.75rem;
}

/* card title with background */
.freemom-card-title__bg {
    margin: calc(-1.5 * var(--freemom-spacing)) calc(-1.5 * var(--freemom-spacing)) calc(0.75 * var(--freemom-spacing));
    padding: calc(1 * var(--freemom-spacing)) calc(1.5 * var(--freemom-spacing));
    background-color: var(--qui-color-primary);
    background-image: url('/media/cache/freemom/Assets/freemom-design-white-transparent.svg'), linear-gradient(45deg, var(--qui-color-main), rgba(46, 5, 77, 0.60));
    background-position: 60% -50px, center;
    background-repeat: no-repeat, no-repeat;
    border-radius: 1rem;
    color: #fff;
    --font-size: 1.5rem;
}

.freemom-card-title__bg h2 {
    color: inherit;
}


.freemom-card .no-text {
    text-align: center;
    margin: 1rem 0;
    color: var(--color, var(--qui-color-muted));
}

.freemom-card-footer {
    margin-top: auto;
}

/* card sizing - sm */
.freemom-card.freemom-card__sm {
    --freemom-spacing: var(--freemom-spacing-sm);
}

/* title spacing depends on card sizing */
.freemom-card.freemom-card__sm .freemom-card-title {
    margin-top: calc(-0.5 * var(--freemom-spacing-sm));
    padding-bottom: calc(0.25 * var(--freemom-spacing-sm));
}

/* title spacing */
.freemom-card__title-sm .freemom-card-title {
    margin-top: calc(-0.5 * var(--freemom-spacing));
    padding-bottom: calc(0.25 * var(--freemom-spacing));
}

/*************/
/* Card hero */
/*************/
.freemom-cardHero {
    background-color: #fff;
    background-image: linear-gradient(90deg, transparent 50%, #f2f0f4);
    border: 4px solid #ccc2d3;
    border-radius: 1rem;
    margin: var(--freemom-spacing) 0;
    min-height: 200px;
    overflow: hidden;
    padding: var(--freemom-spacing);
    position: relative;
    isolation: isolate;
}

.freemom-cardHero h4,
.freemom-cardHero p {
    max-width: 50rem;
    text-align: left;
}

.freemom-cardHero p strong {
    border-bottom: 3px solid;
    color: #2E054D;
}

.freemom-cardHero svg {
    height: auto;
    position: absolute;
    right: -4rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: -1;
}

.freemom-cardHero__invert {
    background-color: #4F3880;
    background-image: linear-gradient(90deg, transparent 50%, #281550);
    border-color: #4F3880;
    color: #d8ceed;
}

.freemom-cardHero__invert :where(h1, h2, h3, h4, h5),
.freemom-cardHero__invert p strong {
    color: #fff;
}

.freemom-cardHero__invert .freemom-card-title {
    border-bottom-color: #655190;
}

.freemom-cardHero__invert svg.freemom-icon {
    filter: invert(1) brightness(4.5) contrast(3) opacity(0.25);
}

/*********************/
/* card list styling */
/*********************/
.freemom-card-list {
    background: var(--freemom-bg-light);
    border: 1px solid transparent;
    border-radius: 0.5rem;
    padding: 0.5rem;
    transition: var(--qui-transition-fast);
}

.freemom-card-list:not(:last-child) {
    margin-bottom: 1rem;
}

.freemom-card-list:not(.no-hover):hover {
    border-color: #76797d;
}

/* card row - like a table */
.freemom-card-list-row {
    display: grid;
    grid-template-columns: minmax(10rem, 25%) 1fr;
    padding: 0.25rem 0.5rem;
}

.freemom-card-list:not(.no-hover) .freemom-card-list-row:hover {
    background: rgba(0, 0, 0, 0.03);
}

@media screen and (max-width: 767px) {
    .freemom-card-list-row {
        grid-template-columns: 1fr;
    }

    .freemom-card-list-row:not(:last-child) {
        margin-bottom: 0.25rem;
    }
}

.freemom-card-list-row-label {
    color: var(--qui-color-muted);
    font-size: var(--qui-fs-sm);
    margin-top: 1px;
    padding-right: 0.5rem;
    word-break: break-word;
}

.freemom-card-list-row-value,
.freemom-card-list-value {
    overflow: hidden; /* To work with the text-overflow: ellipsis */
}

/*******************/
/* Box container ***/
/* Box for content */
/********************/
.freemom-box {
    border: 1px solid var(--freemom-border-color);
    padding: calc(var(--freemom-spacing) / 2);
    border-radius: var(--radius, 0.5rem);
    position: relative;
    background-color: var(--bg, var(--freemom-bg-light));
}

.freemom-box:not(:last-of-type) {
    margin-bottom: calc(var(--freemom-spacing) / 2);
}

/* bg transparent */
.freemom-box--transparent {
    background-color: transparent;
}

/********/
/* Hero */
/********/
.freemom-hero {
    align-items: center;
    background-color: var(--qui-color-primary);
    background-image: url('/media/cache/freemom/Assets/freemom-design-white-transparent.svg'), linear-gradient(45deg, var(--qui-color-main), rgba(46, 5, 77, 0.60));
    background-position: 60% -50px, center;
    background-repeat: no-repeat, no-repeat;
    border-radius: 1rem;
    color: #fff;
    display: flex;
    --freemom-hero-minHeight: 200px;
    --freemom-hero-spacing: calc(2 * var(--freemom-spacing));
    min-height: var(--freemom-hero-minHeight);
    padding: calc(var(--freemom-spacing) * 1.25) var(--freemom-hero-spacing);
}

@media screen and (min-width: 768px) and (min-height: 800px) {
    .freemom-hero {
        --freemom-hero-minHeight: 250px;
        --freemom-hero-spacing: calc(3 * var(--freemom-spacing));
        padding-bottom: calc(var(--freemom-spacing) * 1.5);
        padding-top: calc(var(--freemom-spacing) * 1.5);
    }
}

@media screen and (min-width: 1200px) and (min-height: 800px) {
    .freemom-hero {
        --freemom-hero-minHeight: 350px;
        --freemom-hero-spacing: calc(4 * var(--freemom-spacing));
        padding-bottom: calc(var(--freemom-spacing) * 2);
        padding-top: calc(var(--freemom-spacing) * 2);
    }
}

.freemom-hero-body {
    width: 100%;
}

.freemom-hero-body p:last-child {
    margin-bottom: 0;
}

.freemom-hero :where(h1, h2, h3, h4, h5) {
    color: inherit;
}

.freemom-hero.freemom-hero__pageHeader {
    margin-bottom: var(--freemom-spacing);
}

.freemom-hero.freemom-hero__sm {
    --freemom-hero-minHeight: 200px;
}

.freemom-hero a {
    color: inherit;
}

.freemom-hero a:hover {
    text-decoration: underline;
}

/* hero light */
.freemom-hero.freemom-hero__light {
    color: inherit;
    box-shadow: 0 0 0 10px #fff;
    background-color: var(--freemom-bg-light);
    background-image: url('/media/cache/freemom/Assets/hero-bg-1.svg');
    background-size: 100% auto;
    background-position: top right;
}


/***************/
/* Freemom Tag */
/***************/
.freemom-tag,
.freemom-tag-site,
.qui-control.quiqqer-tags-tag,
.quiqqer-tags-group-window-search-groups .quiqqer-tags-group-window-search-suggests-entry {
    background: var(--tagBackgroundColor, #f0edf6);
    border: none;
    border-radius: 2rem;
    color: var(--tagFontColor, #4f3880);
    display: inline-block;
    float: none;
    font-size: var(--qui-fs-sm);
    margin-right: 0.25em;
    max-width: 100%;
    overflow: hidden;
    padding: 0.25em 0.75em;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.freemom-tag-site {
    font-weight: normal;
}

.qui-control.quiqqer-tags-tag .quiqqer-tags-tag--delete {
    vertical-align: middle;
}

.quiqqer-tags-group-window-search-groups .quiqqer-tags-group-window-search-suggests-entry {
    border-color: #d9d5e2;
}

.quiqqer-tags-group-window-search-groups .quiqqer-tags-group-window-search-suggests-entry:hover {
    background: #f0edf6;
    filter: brightness(0.95);
    border: none;
    color: #4f3880;
}

/* highlight / active */
.freemom-tag.highlight,
.qui-control.quiqqer-tags-tag.highlight,
.quiqqer-tags-group-window-search-groups .quiqqer-tags-group-window-search-suggests-entry--active,
.quiqqer-tags-group-window-search-groups .quiqqer-tags-group-window-search-suggests-entry--active:hover {
    background-color: #4f3880;
    border-color: #4f3880;
    color: #fff;
}

.freemom-tag__success {
    background-color: var(--freemom-color-success);
    color: #fff;
}

.freemom-tag__attention {
    background-color: var(--freemom-color-attention);
}

.freemom-tag__danger {
    background-color: var(--freemom-color-danger);
    color: #fff;
}

/* Search tag window */
.quiqqer-tags-group-window-search h2 {
    font-size: var(--qui-fs-4) !important;
}

.quiqqer-tags-group-window-search .quiqqer-tags-group-window-search-selected {
    background: #fff;
    border: 1px solid var(--freemom-border-color-light);
    border-radius: 1rem;
}

/****************/
/* No ui slider */
/****************/
body .noUi-target {
    align-items: center;
    background: #e8ebf0;
    border: none;
    border-radius: 0;
    display: flex;
    margin-bottom: 1rem;
    margin-top: 1rem;
}

body .noUi-horizontal {
    height: 8px;
}

body .noUi-base,
body .noUi-connects {
    cursor: pointer;
    height: 32px;
}

body .noUi-connect {
    background-color: var(--qui-color-main) !important;
    height: 8px;
    opacity: 0.5;
    top: 12px;
}

body .noUi-horizontal .noUi-handle {
    background: var(--qui-color-main);
    border-color: #ff8273;
    box-shadow: inset 0 0 1px #fff, inset 0 1px 7px #e27063, 0 3px 6px -3px #bbb;
    height: 20px;
    right: -5px;
    top: 6px;
    width: 10px;
}

body .noUi-handle:before, body .noUi-handle:after {
    display: none;

    background: #fff;
    left: 8px;
    top: 3px;
}

body .noUi-handle:after {
    left: 11px;
}

/* make touch area a bit larger */
body .noUi-touch-area {
    width: 32px;
    height: 32px;
    transform: translate(-50%, -50%);
    position: relative;
    top: 50%;
    left: 50%;
}

/*********************************/
/* warning status - missing data */
/*********************************/
.warning-status button.btn-add {
    background-color: var(--qui-message-attention-color);
    border-color: var(--qui-message-attention-color);
}

/********/
/* Form */
/********/

label {
    display: block;
    margin-bottom: 1rem;
}

/**
 * iOS fix
 */
input[type="checkbox"],
input[type="radio"] {
    padding: 0;
}

/**
 * iOS fix: date input (updated)
 *
 * 1. reset the ios blue font color
 */
input[type="date"],
input[type="datetime-local"] {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    color: inherit; /* 1 */
}
input[type="date"]::-webkit-date-and-time-value,
input[type="datetime-local"]::-webkit-date-and-time-value {
    text-align: left !important;
}

/*
 * iOS fix for date input
 * Nachtrag: es war doch nicht ganz überdacht. Bitte nicht mehr benutzen.
 */
.freemom-ios [type="date"] {
    -webkit-appearance: textfield;
    appearance: textfield;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 120px;
    min-width: 100%;
    height: 3rem;
    color: inherit;
}

.freemom-ios input::webkit-date-and-time-value {
    text-align: left !important;
}

form input {
    margin-bottom: 0;
    margin-top: 0;
}

input[type="search"] {
    -webkit-appearance: none;
}

form :where(input:not([type="checkbox"], [type="radio"]), button, select) {
    line-height: 2;
}

:is(fieldset:not(:last-child)) {
    margin-bottom: 2rem;
}

.qui-form legend {
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: var(--qui-fs-xs);
}


/* input group */
.input-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--freemom-spacing);
}

.input-group > * {
    flex: 1;
}

.input-group label > input:not([type="checkbox"], [type="radio"]) {
    width: 100%;
}

.input-group :where(button, .button, [type="button"], [type="submit"]) {
    white-space: nowrap;
}

/* search with icon */
.freemom-searchInputWithIcon {
    position: relative;
    --freemom-searchInputwithIcon-width: 50px;
    margin-bottom: 0;
}

.freemom-searchInputWithIcon > input {
    padding-left: var(--freemom-searchInputwithIcon-width);
}

.freemom-searchInputWithIcon > .fa {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    left: 0;
    opacity: 0.5;
    position: absolute;
    text-align: center;
    top: 0;
    transition: var(--qui-transition-fast);
    width: var(--freemom-searchInputwithIcon-width);
}

.freemom-searchInputWithIcon > input:where(:hover, :focus) ~ .fa {
    opacity: 1;
}

@media screen and (max-width: 767px) {
    .freemom-searchInputWithIcon {
        --freemom-searchInputwithIcon-width: 40px;
    }
}

/**************/
/* Form white */
/**************/
.form-white {
    /*color: #fff;*/
}

.form-white input:not([type="checkbox"], [type="radio"], [type="button"], [type="submit"]),
.form-white select,
.form-white textarea {
    background-color: #fff;
    border-color: #fff;
}

.form-white .freemom-searchInputWithIcon > .fa {
    color: var(--qui-color-muted);
}

@media screen and (max-width: 767px) {
    .form-white .freemom-searchInputWithIcon > .fa {
        padding: 0.5em 1.25em;
        line-height: 2;
        height: initial;
        border: 2px solid transparent;
    }
}

form.form-white select:hover,
form.form-white textarea:hover,
form.form-white input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]):hover,
.qui-window-popup form.form-white select:hover,
.qui-window-popup form.form-white textarea:hover,
.qui-window-popup form.form-white input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]):hover {
    filter: none;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
}

form.form-white select:focus,
form.form-white textarea:focus,
form.form-white input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]):focus,
.qui-window-popup form.form-white select:focus,
.qui-window-popup form.form-white textarea:focus,
.qui-window-popup form.form-white input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]):focus {
    border-color: var(--qui-color-main);
}

/* styling for radio and checkbox inputs */
input:is([type="radio"], [type="checkbox"]).checkbox-style {
    appearance: none;
    -webkit-appearance: none;
    width: 1rem;
    border: none;
    margin-right: 1rem;
    flex-shrink: 0;
    flex-grow: 0;
}

input:is([type="radio"], [type="checkbox"]).checkbox-style:after {
    content: "\f096";
    font-family: FontAwesome;
    display: inline-block;
    font-size: 1.5em;
    width: 0;
}

input:is([type="radio"], [type="checkbox"]).checkbox-style:checked:after {
    content: "\f046";
    color: var(--freemom-color-success);
}


/************/
/* Markdown */
/************/
.markdown h1 {
    font-size: var(--qui-fs-lg);
}

.markdown h2 {
    font-size: var(--qui-fs-md);
}

.markdown h3,
.markdown h4,
.markdown h5 {
    font-size: var(--qui-fs-body);
}

.markdown :is(h1, h2, h3, h4, h5) {
    margin-bottom: 0.25rem;
    margin-top: 1rem;
}

.markdown :is(h1, h2, h3, h4, h5):first-child {
    margin-top: 0;
}

.markdown p {
    margin-bottom: 0.25em;
    margin-top: 0.25em;
}

.markdown li {
    margin-bottom: 0;
    margin-top: 0;
}

/*******************************/
/* simple freemom progress bar */
/*******************************/
.freemom-progress-bar, .freemom-progress-bar:after {
    background: #ddd;
    border-radius: 10px;
    display: block;
    height: 10px;
    position: relative;
    width: 100%;
}

.freemom-progress-bar:after {
    background: var(--freemom-progress-bar-color, var(--qui-color-main));
    content: '';
    left: 0;
    position: absolute;
    top: 0;
    transition: var(--qui-transition-normal);
    width: clamp(2%, var(--freemom-progress-bar-value, 0), 100%);
}

.freemom-progress-bar-indicator {
    background-color: #fff;
    border: 1px solid #e6e6eb;
    border-radius: 4px;
    box-shadow: 0 0 8px rgb(0 0 0 / 10%);
    font-size: 12px;
    left: clamp(calc(2% - 23px), calc(var(--freemom-progress-bar-value, 0) - 23px), calc(99% - 23px));
    position: absolute;

    text-align: center;
    top: 2em;
    transition: var(--qui-transition-normal);
    width: 46px;
}

.freemom-progress-bar-indicator:before {
    border-color: transparent transparent var(--qui-color-muted) transparent;
    border-style: solid;
    border-width: 0 4px 5px 4px;
    content: '';

    height: 0;
    left: calc(50% - 4px);
    position: absolute;
    top: -5px;
    width: 0;
}

/* indicator on the top */
.freemom-progress-bar__indicator-top .freemom-progress-bar-indicator {
    bottom: 2em;
    top: initial;
}

.freemom-progress-bar__indicator-top .freemom-progress-bar-indicator:before {
    border-color: var(--qui-color-muted) transparent transparent transparent;
    border-width: 5px 4px 0 4px;
    bottom: -5px;;
    top: initial;
}


/******************/
/* Text and image */
/******************/
.quiqqer-textImage-box picture img {
    border-radius: 1rem;
}

/**********************/
/* Register page: mom */
/**********************/
body .registration-sign-in-logo img {
    height: 60px;
}

body.type-quiqqer-frontend-users-types-registrationSignUp {
    overflow: hidden;
}

.registration-sign-in-fullscreen {
    background-color: #fafafa !important;
}

.registration-sign-in-container > .fa-spinner {
    line-height: 0 !important;
    width: initial;
    transform: translate(-50%, -50%);
    top: 50%;
    position: absolute;
    left: 50%;
}

.registration-sign-in-container {
    max-width: 1100px;
    background: #fff !important;
    border-radius: 2rem;
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
    transition: 0.3s ease;
}

/* register success */
.quiqqerFrontendUsersRegisterSuccess.registration-sign-in-container {
    box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    background: transparent !important;
}

.quiqqerFrontendUsersRegisterSuccess.registration-sign-in-container .quiqqer-fu-registrationSignUp-registration {
    padding: 0;
}

.quiqqerFrontendUsersRegisterSuccess .content-message-information {
    padding-left: 1.25rem;
    text-align: left;
}

.quiqqerFrontendUsersRegisterSuccess .content-message-information:before,
.quiqqerFrontendUsersRegisterSuccess .content-message-information:after {
    display: none;
}

/* END: register success */

/* register: user activate activated */
.quiqqerFrontendUsersUserActivate.registration-sign-in-container {
    box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    background: transparent !important;
}

.quiqqerFrontendUsersUserActivate.registration-sign-in-container .quiqqer-fu-registrationSignUp-registration {
    padding: 0;
}

.quiqqerFrontendUsersUserActivate .content-message-success {
    padding-left: 1.25rem;
    text-align: left;
}

.quiqqerFrontendUsersUserActivate .content-message-success:before,
.quiqqerFrontendUsersUserActivate .content-message-success:after {
    display: none;
}

.quiqqer-fu-registrationSignUp-registration-nextlinks > a:not(:hover) {
    color: inherit;
}

/* END register: user activate */

.quiqqer-fu-registrationSignUp {
    margin: 0 !important;
    align-items: center;
}

.quiqqer-fu-registrationSignUp-info {
    align-self: stretch;
    border-radius: 2rem;
    background-color: #f8f8f8;
    background-size: 1100px;
    background-repeat: no-repeat;
    background-position: 100px -270px;
    background-image: url('/media/cache/freemom/Assets/freemom-design-extra-hell-medium-optimized.svg');
}

.quiqqer-fu-login-container-width {
    padding: 2rem;
}

.quiqqer-fu-registrationSignUp-login-close {
    margin-right: 1rem;
    margin-top: 1rem;
}

/**
 * Sehr schlecht, das muss irgendwann in quiqqer/frontend-users behoben werden
 */
div.quiqqer-fu-login-forget-password-reset button[name="cancel"] {
    position: initial;
    width: 100%;
    border-color: var(--freemom-border-color-light);
    background-color: var(--freemom-border-color-light);
    color: var(--qui-color-body);
    margin-top: 0.5rem;
}

.quiqqer-fu-login-activation-info {
    max-width: 360px;
    margin-inline: auto !important;
}

.quiqqer-fu-login-activation-info button {
    width: 100%;
}

@media screen and (min-width: 768px) {
    .registration-sign-in-container {
        min-height: 400px;
        overflow: hidden;
    }

    .quiqqer-fu-registrationSignUp-info,
    .quiqqer-fu-registrationSignUp-registration,
    .quiqqer-fu-login-container-width {
        width: 50% !important;
    }

    .quiqqer-fu-registrationSignUp-info {
        padding: 4rem 2rem !important;
    }
}

@media screen and (max-width: 1200px) {
    .registration-sign-in-container {
        margin-top: 100px;
        max-width: calc(100% - 2rem) !important;
    }
}

@media screen and (max-width: 767px) {
    .quiqqer-fu-registrationSignUp {
        flex-direction: column !important;
    }

    .quiqqer-fu-registrationSignUp-registration {
        padding-top: 4rem !important;
        padding-bottom: 4rem !important;
    }
}

body .quiqqer-fu-registrationSignUp-terms {
    font-size: 1rem;
}

body .quiqqer-fu-registrationSignUp-terms-text [name="decline"] {
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 0 10px rgb(0 0 0 / 10%);
    width: 2.5rem;
    line-height: 2.5rem;
    padding: 0;
    right: 1rem;
}

.quiqqer-fu-registrationSignUp-registration-email label .icon {
    z-index: 1;
}

@media screen and (max-width: 767px) {
    body .quiqqer-fu-registrationSignUp-terms-text [name="decline"] {
        right: 0;
    }
}

/**************/
/* Job status */
/**************/
.free-mom-job-status {
    border-radius: 100%;
    display: inline-block;
    height: 10px;
    width: 10px;
    background-color: var(--freemom-job-status-color);
}

.free-mom-job-status--Created {
    --freemom-job-status-color: var(--freemom-status-color-Created, #616876);
}

.free-mom-job-status--ApplicationPending {
    --freemom-job-status-color: var(--freemom-status-color-ApplicationPending, #f59f00);
}

.free-mom-job-status--Successful {
    --freemom-job-status-color: var(--freemom-status-color-Successful, #2fb344);
}

.free-mom-job-status--Cancelled {
    --freemom-job-status-color: var(--freemom-status-color-Cancelled, #d63939);
}

.free-mom-job-status--SubmittedForReview {
    --freemom-job-status-color: var(--freemom-status-color-SubmittedForReview, #206bc4);
}

.free-mom-job-status--Rejected {
    --freemom-job-status-color: var(--freemom-status-color-Rejected, #ae3ec9);
}

.free-mom-job-status--ApplicationAccepted {
    --freemom-job-status-color: var(--freemom-status-color-Accepted , #5bc7c7);
}

.free-mom-job-status--Billing {
    --freemom-job-status-color: var(--freemom-status-color-Billing , #b2ebf2);
}

.free-mom-job-status--Contracting {
    --freemom-job-status-color: var(--freemom-status-color-Contracting, #039be5);
}

.free-mom-job-status--TimeTracking {
    --freemom-job-status-color: var(--freemom-status-color-TimeTracking, #90caf9);
}

.free-mom-job-status--Accounting {
    --freemom-job-status-color: var(--freemom-status-color-Accounting, #90f9e6);
}

.free-mom-job-status--Vetting {
    --freemom-job-status-color: var(--freemom-status-color-Vetting, #ffeb3b);
}

.free-mom-job-status--StatementOfWork {
    --freemom-job-status-color: var(--freemom-status-color-StatementOfWork, #ffcc80);
}

.free-mom-job-status--Rating {
    --freemom-job-status-color: var(--freemom-status-color-Rating , #9ccc65);
}

/**********/
/* Ribbon */
/**********/
.freemom-ribbon {
    --bg: var(--freemom-application-color);
    --color: var(--freemom-application-color-accent);
    height: 8rem;
    width: 8rem;
    overflow: hidden;
    position: absolute;
    z-index: 1;
    top: -0.5rem;
    right: -0.5rem;
}

.freemom-ribbon::before {
    top: 0;
    left: 0;
}

.freemom-ribbon::before,
.freemom-ribbon::after {
    border: 0.25rem solid var(--bg);
    filter: brightness(0.75);
    content: "";
    position: absolute;
    z-index: -1;
}

.freemom-ribbon::before,
.freemom-ribbon::after {
    border-top-color: rgba(0, 0, 0, 0);
    border-right-color: rgba(0, 0, 0, 0);
}

.freemom-ribbon::after {
    bottom: 0;
    right: 0;
}

.freemom-ribbon .freemom-ribbon-title {
    transform: translate(-0.8125rem, 1.875rem) rotate(45deg);
}

.freemom-ribbon-title {
    background-color: var(--bg);
    color: var(--freemom-application-color-accent);
    position: absolute;
    padding: 0.5rem 0;
    text-transform: uppercase;
    text-align: center;
    width: 11.3125rem;
    font-weight: normal;
    font-size: var(--qui-fs-sm);
}

.freemom-ribbon--sm {
    height: 6rem;
    width: 6rem;
}

.freemom-ribbon--sm .freemom-ribbon-title {
    padding: 0.25rem 0;
    width: calc(9.3125rem - 0.25rem);
    transform: translate(calc(-0.8125rem - 0.25rem), calc(0.875rem + 0.25rem)) rotate(45deg);
}

@media screen and (max-width: 767px) {
    /* nur schnell, muss noch besser gemacht werden */
    .freemom-ribbon {
        transform: scale(0.75) translate(15%, -15%);
    }
}

/**********************/
/* Ribbon TOP project */
/**********************/
.freemom-ribbon-highlighted {
    --bg: #ff770b;
    --color: var(--freemom-application-color-accent); background-color: var(--bg);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: var(--freemom-border-radius);
    border-bottom-right-radius: var(--freemom-border-radius);
    color: var(--freemom-application-color-accent);
    font-size: var(--qui-fs-xs);
    padding: 0.25em 2em 0;
    position: absolute;
    z-index: 1;
    bottom: 1rem;
    left: -0.5rem;
}

.freemom-ribbon-highlighted > span.fa {
    margin-right: 0.5em;
}

/**
 * Project type badge
 */
.projectTypeBadge {
    border: 1px solid var(--borderColor);
    border-radius: 10px;
    display: inline-block;
    font-size: 9px;
    line-height: 1;
    padding: 5px 10px 2px;
    background-color: var(--bgColor);
    color: var(--textColor);
    margin-bottom: 0.75em;
}

.projectTypeBadge--light {
    --borderColor: #cfd7d9;
    --bgColor: #e0e9eb;
    --textColor: #4f5657;
}
.projectTypeBadge--standard {
    --borderColor: #abcc78;
    --bgColor: #c9ed99;
    --textColor: #252e16;
}

.projectTypeBadge--exclusive {
    --borderColor: #e3da20;
    --bgColor: #fff51e;
    --textColor: #4e4b09;
}
