:root {
    --colourYes: #44aa00;
    --colourNo: #d40000;
    --colourConditional: var(--colourYellow);
}

html.loading {
    overflow: hidden;
}

/**
 * Step 1
 */
.massnahmenpakete .image {
    position: relative;
    max-width: 768px;

    border: 1px solid var(--colourGreenDark);
    border-radius: var(--radiusDefault);
    background-color: #fff;
    background-image: url('../img/upload.svg');
    background-repeat: no-repeat;
    background-size: 50% 50%;
    background-position: center;

    overflow: hidden;
}

.massnahmenpakete .image label {
    cursor: pointer;
}

.massnahmenpakete .image input[type="file"] {
    position: absolute;
    bottom: 0;
    left: 0;

    width: 100%;
}

.massnahmenpakete .image img {
    display: block;
    width: 100%;
    height: auto;
    min-height: 160px;

    text-align: center;
}


/**
 * Step 3
 */
 .step-3 {
    margin: var(--paddingDefaultY) calc( -1 * var(--paddingDefaultX) );
    padding: var(--paddingDefault);

    background-color: #fff;
}


/**
 * Breadcrumbs
 */
ul.breadcrumbs {
    margin: 0 0 1em 0;
    padding: 0;

    list-style: none;
}

ul.breadcrumbs li {
    display: inline-block;
    padding: 0.2em 0.8em;
    margin: 0 0.4em 0 0;
    position: relative;

    border: 2px solid var(--colourGreenDark);
    border-radius: var(--radiusDefault);
    cursor: pointer;
}

ul.breadcrumbs li.disabled {
    opacity: 1;
    cursor: default;
}

ul.breadcrumbs li a {
    color: inherit;
    cursor: default;
    text-decoration: none;
}

ul.breadcrumbs li a[href] {
    cursor: pointer;
}

ul.breadcrumbs li.active,
ul.breadcrumbs li:hover {
    color: #fff;
    border-color: var(--colourGreenButton);
    background-color: var(--colourGreenButton);
}

ul.breadcrumbs li > * {
    display: block;
}

/**
 * Form
 */
form h2 {
    margin: 2em 0 0.2em 0;
}

form fieldset {
    padding: 0;

    border: none;
}


/**
 * Form Filter
 */
#formFilter p {
    display: none;
}

#formFilter .options label {
    display: block;
}

#formFilter input[type="submit"] {
    margin: 0;
}

#formFilter .details {
    display: none;
}

#formFilter fieldset {
    margin: 0 0 0.8em 0;
}

#formFilter #formFilterDetails {
    display: block;
    margin-top: 0.8em;
}
@media (max-width: 375px) {
	/* iPhone SE */
    #formFilter #formFilterDetails {
        margin-top: 0.4em;
    }
}
@media (max-width: 599px) {
    #formFilter fieldset {
        margin: 0 0 0.4em 0;
    }

    #formFilter #formFilterDetails {
        text-align: center;
    }

    #formFilter fieldset > label {
        display: none;
    }
}


/**
 * Switch
 */
.switch {
    border: 2px solid var(--colourGreenDark);
    border-radius: var(--radiusDefault);

    white-space: nowrap;
    overflow: hidden;
}

.switch input[type="radio"] {
    display: none;
}

.switch label {
    display: inline-block;
    line-height: var(--lineHeightDefault);

    cursor: pointer;

    border-right: 2px solid var(--colourGreenDark);
}

.switch label:last-of-type {
    border-right: none;
}

.switch label input[type=radio] ~ span {
    display: inline-block;
    padding: 0.2em 0.8em;

    color: #fff;
    background-color: var(--colourGreenDark);
}

.switch label:hover input[type=radio] ~ span,
.switch label input[type=radio]:checked ~ span {
    color: var(--colourText);
    background-color: var(--colourGreenLight);
}


/**
 * Maßnahmenpakete
 */
.massnahmenpaket {
    margin: 4em calc( -1 * var(--paddingDefaultX) );
    padding: 4em var(--paddingDefaultX);

    background-color: #f4f4f4;
    border-top: 2px solid var(--colourGreenDark);
    border-bottom: 2px solid var(--colourGreenDark);
}

.massnahmenpaket p {
    margin: 0;
}

.massnahmenpaket .summary {
    display: grid;
    grid-template-columns: auto min-content;
    grid-template-rows: repeat(2, auto);
    gap: 1em;
}

.massnahmenpaket .summary h2 {
    margin: 0;
}

.massnahmenpaket .conditionalBox {
    display: none;
}

.massnahmenpaket .summary .switch {
    align-self: center;
    justify-self: flex-end;
    user-select: none;
}

.massnahmenpaket .summary div.conditionalBox,
.massnahmenpaket .summary div.excerpt {
    grid-column: 1 / 3;
}

@media(max-width: 768px) {
    .massnahmenpaket .summary {
        grid-template-columns: auto;
        grid-template-rows: auto;
    }

    .massnahmenpaket .summary .switch {
        grid-area: auto;
        justify-self: flex-start;
    }

    .massnahmenpaket .summary div.conditionalBox,
    .massnahmenpaket .summary div.excerpt {
        grid-area: auto;
    }
}

.massnahmenpaket .description {
    display: none;
    grid-column: 1 / 3;
}

.massnahmenpaket > div > div textarea {
    max-width: 100%;
}


/**
 * Share pic
 */
#sharepicPlaceholder {
    width: 1024px;
    height: 1024px;
}

.socialImage {
    position: relative;
}

.socialImage * {
    margin: 0;
}

.socialImage .type,
.socialImage .profile,
.socialImage .title,
.socialImage .testamonial,
.socialImage .name,
.socialImage .party,
.socialImage .district {
    position: absolute;
}

.socialImage .type {
    top: 1%;

    font-size: 24pt;
    font-weight: bold;

    color: #fff;
}
.socialImage .candidate .type {
    right: 2%;
}
.socialImage .non-candidate .type {
    left: 2%;
}

.socialImage .profile {
    width: 40%;
    height: 40%;

    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;

    z-index: -1;
}
.socialImage .candidate .profile {
    top: 15%;
    left: 50%;
}
.socialImage .non-candidate .profile {
    top: 12%;
    left: 6%;
}

.socialImage .testamonial,
.socialImage .name,
.socialImage .district,
.socialImage .party {
    left: 0;
}

.socialImage .title {
    max-width: 42%;
    top: 16%;

    padding: 10%;

    font-size: 40pt;
    font-weight: normal;
    line-height: 1.4;
}
.socialImage .candidate .title {
    left: 0;
}
.socialImage .non-candidate .title {
    top: 12%;
    left: 38%;

    font-size: 28pt;
}

.socialImage .dots {
    display: inline-block;
    white-space: nowrap;
}
.socialImage .dot {
    display: inline-block;

    background-color: var(--colourYellow);
    border-radius: 50%;
}
.socialImage .title .dot {
    width: 22px;
    height: 22px;
    margin-left: 10px;
    vertical-align: baseline;
}
.socialImage .testamonial .dot {
    width: 18px;
    height: 18px;
    margin-right: 8px;
    vertical-align: text-bottom;
}

.socialImage .testamonial {
    top: 54%;
    left: 10%;
    right: 10%;
    height: 21%;

    font-size: 20pt;
    overflow: hidden;
}

.socialImage .name,
.socialImage .party,
.socialImage .district{
    padding-left: 10%;

    font-size: 20pt;
}

.socialImage .name {
    bottom: 20%;
}

.socialImage .party,
.socialImage .district {
    font-size: 16pt;
}

.socialImage .party {
    bottom: calc( 19.6% - 1.4em );
}

.socialImage .district {
    bottom: calc( 19.6% - 2.8em );

    font-weight: bold;
}

/**
 * Modal
 */
.modal {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;

    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;

    background-color: rgba(255, 255, 255, 0.92);

    z-index: 9;
}

#modalSharepic {
    display: none;
}

#modalSharepic .row {
    flex-wrap: nowrap;
    width: 80%;
    height: 50%;
    padding-bottom: 4%;
}

#modalSharepic .row > * {
    flex: 0 1 50%;
}

#modalSharepic .preview {
    text-align: right;
}

#modalSharepic img {
    display: none;

    max-width: 100%;
    max-height: 100%;

    border: 4px solid var(--colourGreenDark);
    box-sizing: border-box;
}

#modalSharepic .buttons {
    display: none;
}

#modalSharepic .buttons a {
    display: block;
    max-width: 300px;
}


/**
 * Row
 */
.row {
    --gutter: 1em;

    display: flex;
    justify-content: space-between;
    width: 100%;

    margin-bottom: var(--gutter);
}

.row:last-child {
    margin-bottom: 0;
}

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

.row > * {
    flex: 1 1 100%;

    margin-right: var(--gutter);
}

.row > *:last-child {
    margin-right: 0;
}

@media (max-width: 768px) {
    .row {
        flex-wrap: wrap;
    }

    .row > * {
        flex-grow: 1;

        margin-right: 0;
        margin-bottom: var(--gutter);
    }

    .row > *:last-child {
        margin-bottom: 0;
    }
}


/**
 * Pagination
 */
.pagination {
    margin: 2em 0;
    text-align: center;
}

.pagination > * {
    display: inline-block;
}

.pagination .pages,
.pagination .pages > * {
    display: inline-block;
}

.pagination .pages > * {
    margin-right: 0.4em;
}

.pagination .pages :last-child {
    margin-right: 0;
}

.pagination .pages .button {
    min-width: auto;
    width: auto;
    margin-top: 0;
    padding: 0.2em 0.8em;

    cursor: pointer;
    color: inherit;
    background-color: transparent;
    border: 2px solid var(--colourGreenDark);
}

.pagination .pages .button svg {
    max-height: 100%;

    vertical-align: text-top;
}

.pagination .pages .button:hover,
.pagination .pages .button.active {
    opacity: 1;

    color: #fff;
    border-color: var(--colourGreenButton);
    background-color: var(--colourGreenButton);
}

.pagination .pages .button.disabled:hover {
    cursor: not-allowed;

    border-color: inherit;
    color: inherit;
    background-color: inherit;
}


/**
 * Results
 */
.results {
    margin: 2em calc( -1 * var(--paddingDefaultX) );
    padding: var(--paddingDefault);

    background-color: #f4f4f4;
}
@media (max-width: 375px) {
	/* iPhone SE */
    .results {
        margin-top: 0.4em;
    }
}
.results > * {
    margin-bottom: 0.6em;
}

.results :last-child {
    margin-bottom: 0;
}


/**
 * Contact Preview
 */
.contactPreview,
.contactPreview + .contactDetails {
    --imageSize: calc( 4em * var(--lineHeightDefault) );
    --gapX: 0.8rem;
}

.contactPreview,
.contactPreview + .contactDetails .grid {
    transition: grid-template-columns 0.2s ease,
                grid-template-rows 0.2s ease;

    display: grid;
}

.contactPreview + .contactDetails .grid,
.contactPreview + .contactDetails .introduction,
.contactPreview + .contactDetails .call_to_action,
.contactPreview + .contactDetails .social {
    padding: var(--gapX);
}

.contactPreview {
    transition: all 0.2s ease;

    grid-template-columns: max-content auto max-content;
    grid-template-rows: repeat( 4, 1fr );

    height: var(--imageSize);

    border-radius: var(--radiusDefault);
    background-color: #fff;
    border-bottom: 1px solid transparent;
    box-shadow: 0 0 2px #ddd;
}
@media (max-width: 375px) {
    .contactPreview {
        grid-template-columns: max-content auto 100px;
    }
}

.contactPreview.open {
    border-bottom-color: #f4f4f4;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.contactPreview .image {
    grid-row: 1 / 4;

    width: calc( 2 * var(--imageSize) );

    box-sizing: border-box;
}
.contactPreview .image > div {
    display: inline-block;
    width: var(--imageSize);
    height: var(--imageSize);
}
@media (max-width: 599px) {
    .contactPreview .image {
        width: var(--imageSize);
    }

    .contactPreview .image .partyImage {
        display: none;
    }
}
.results.person .contactPreview .image,
.results.organisation .contactPreview .image {
    width: var(--imageSize);
}
.results.person .contactPreview .image .partyImage,
.results.organisation .contactPreview .image .partyImage {
    display: none;
}

.contactPreview .name,
.contactPreview .role,
.contactPreview .party,
.contactPreview .score,
.contactPreview .websites {
    padding: 0 0.2em;

    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;

    align-self: center;
}

.contactPreview .contactImage {
    background-color: #fff;
    background-image: url('../img/user.svg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;

    text-align: center;
    line-height: 1;
    overflow: hidden;
}

.contactPreview .contactImage img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 20%;

    font-size: 10pt;
}

.contactPreview .partyImage img {
    display: block;
    width: 100%;
    height: 100%;

    object-fit: contain;
    object-position: center;
}

.contactPreview .name {
    grid-row: 1 / 2;
}

.contactPreview .party {
    grid-row: 2 / 3;
}

.contactPreview .score {
    grid-row: 3 / 4;
}

.contactPreview .score div {
    display: inline-block;
}

.contactPreview .score div .unpositioned {
    font-style: italic;
    font-size: 0.8em;
    color: #777;
}

.contactPreview .websites {
    grid-row: 4 / 5;
    grid-column: 2 / 3;

    display: flex;
    height: 100%;
    justify-content: stretch;
}

.contactPreview .websites a svg,
.contactPreview .websites a img {
    width: 24px;
    height: 100%;
    padding: 0.2em;
    box-sizing: border-box;
}

.contactPreview .action {
    grid-row: 1 / 4;

    margin: auto 8px;
}
.contactPreview .action.expanded {
    grid-row: 1 / 4;
    align-self: center;
}

.contactPreview .action .button {
    padding: 6px 8px;

    font-size: inherit;
}
@media (max-width: 599px) {
    .contactPreview .action .button svg {
        display: none;
    }
}

.contactPreview .scoreVisual {
    display: flex;
    flex-flow: row nowrap;
    grid-row: 4 / 5;
    grid-column: 3 / 4;

    margin: 0 8px 8px 8px;

    border-radius: 2px;
    overflow: hidden;
}

.contactPreview .scoreVisual .bar {
    flex: 1 1 auto;
    margin-right: 2px;

    background-color: var(--colourGreenDark);
}
.contactPreview .scoreVisual .bar:last-of-type {
    margin-right: 0;
}
.contactPreview .scoreVisual .bar.no { background-color: var(--colourNo); }
.contactPreview .scoreVisual .bar.yes { background-color: var(--colourYes); }
.contactPreview .scoreVisual .bar.conditional { background-color: var(--colourConditional); }

.contactPreview + .contactDetails .introduction svg {
    width: 1.2em;
    height: 1.2em;

    vertical-align: middle;
}

.contactPreview + .contactDetails .vote {
    white-space: nowrap;
    opacity: 0.2;
}

.contactPreview + .contactDetails .vote svg {
    width: calc( 1em * var(--lineHeightDefault ) );
    height: calc( 1em * var(--lineHeightDefault ) );
    margin-right: 0.4ch;

    vertical-align: middle;

    color: inherit;
}

.contactPreview + .contactDetails .vote.yes,
.contactPreview + .contactDetails .vote.no,
.contactPreview + .contactDetails .vote.conditional {
    opacity: 1;
}

.contactPreview + .contactDetails .vote.yes a,
.contactPreview + .contactDetails .vote.yes svg { color: var(--colourYes); }
.contactPreview + .contactDetails .vote.no a,
.contactPreview + .contactDetails .vote.no svg { color: var(--colourNo); }
.contactPreview + .contactDetails .vote.conditional a,
.contactPreview + .contactDetails .vote.conditional svg { color: var(--colourConditional); }

.contactPreview + .contactDetails {
    display: none;

    background-color: #fff;
}

.contactPreview + .contactDetails .name {
    color: inherit;
}

.contactPreview + .contactDetails .content {
    display: none;
    max-height: 60vh;
    padding: var(--gapX) var(--gapX) var(--gapX) 0;
    margin-bottom: var(--gapX);
    grid-column: 1 / 4;

    overflow: auto;
    word-wrap: anywhere;
}
.contactPreview + .contactDetails.contactDetails.has_voted_anonymously .content {
    grid-column: 1 / 5;
}

.contactPreview + .contactDetails .reason {
    white-space: nowrap;
}

.contactPreview + .contactDetails .reason span {
    color: inherit;
    vertical-align: middle;
}

.contactPreview + .contactDetails .reason svg:last-of-type {
    color: #0a9fd8 !important;
    width: 1em;
    height: 1em;
    margin-left: 0.2em;
}

.contactPreview + .contactDetails .grid {
    grid-template-columns: min-content auto 128px;
    grid-auto-rows: auto;
}
.contactPreview + .contactDetails.has_voted_anonymously .grid {
    grid-template-columns: min-content auto repeat(2, 128px);
}

.contactPreview + .contactDetails .grid p.heading {
    margin: 0;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;

    font-weight: 550;
}

.contactPreview + .contactDetails .grid .numberWrapper {
    text-align: right;
    margin-right: 0.2ch;
}

.contactPreview + .contactDetails .grid .vote_result {
    box-sizing: content-box;
}

.contactPreview + .contactDetails .call_to_action p {
    margin-bottom: 0.2em;
}

@media(max-width: 768px) {
    .contactPreview + .contactDetails .grid {
        grid-template-columns: min-content auto 128px;
    }
    .contactPreview + .contactDetails.has_voted_anonymously .grid {
        grid-template-columns: min-content auto repeat(2, 128px);
    }

    .contactPreview + .contactDetails .grid p.heading span {
        display: none;
    }

}

@media(max-width: 599px) {

    .contactPreview + .contactDetails .grid {
        grid-template-columns: min-content auto 128px;
        grid-template-rows: max-content;
        grid-auto-rows: min-content max-content;
        align-items: baseline;
    }
    .contactPreview + .contactDetails.has_voted_anonymously .grid {
        grid-template-columns: min-content auto repeat(2, 128px);
    }

    .contactPreview + .contactDetails .grid .vote_result {
        position: sticky;
        top: var(--paddingDefault);
        width: 1.7em;
        height: 1.7em;
        padding: 0;
    }

    .contactPreview + .contactDetails .grid .content {
        max-height: unset;
    }
}

/**
 * Table
 */
table {
    margin: 0;
}

.cols-2 tr td:first-of-type {
    width: 30%;
}


/**
 * Form
 */
.label {
    font-weight: bold;
}

select {
    box-sizing: border-box;
}

p.description,
label + input + p,
label + select + p {
    margin: 0;

    color: #777;
    font-size: 10pt;
}

.groups label {
    white-space: nowrap;
}

.parties label {
    display: inline-block;
    height: 64px;
    vertical-align: middle;
}

.parties label input[type="checkbox"] {
    display: none;
}

.parties label img {
    transition: border-color 0.2s ease, background-color 0.2s ease;

    display: block;
    height: 100%;
    box-sizing: border-box;

    border: 2px solid transparent;
    background-color: #fff;
}

.parties label input[type="checkbox"]:checked + img {
    border-color: var(--colourGreenGradientLight);
}

.districts {
    max-height: calc(8em * var(--lineHeightDefault));
    overflow: auto;
}

.districts label {
    display: none;
}

.post-230.has-post-thumbnail .post-thumbnail {
    display: none;
}

/**
 * Sharepic Slider
 */
.sharepic-slider {
	--swiper-theme-color: var(--colourText);

    margin: 2em 0;

    border: 2px solid var(--colourYellow);
    border-radius: var(--radiusDefault);

    overflow: hidden;
}

/**
 * Simple Light Box
 */
.slbCloseBtn:hover,
.slbArrow:hover {
	color: #fff;
	background-color: transparent;
	border-color: transparent;
}

.slbContentOuter {
    max-width: 768px !important;
    max-height: 50%;
}

.slbContent {
    max-height: 50vh;

    overflow: auto;
}

.contentInPopup {
    padding: 2em;
}
