.page-id-6341 header,
.page-id-6341 footer {
    display: none;
}

.elementor-widget-wpforms .submit-container {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    text-align: center;
    font-family: "Exo", Sans-serif;
    font-weight: 600;
    font-size: 36px;
}

.elementor-widget-wpforms .wpforms-confirmation-container {
    display: flex;
    justify-content: center;
}

#lotti-container .nshid-theme-toggle {
    position: absolute;
    right: 46px;
    bottom: 16px;
    z-index: 20;

    width: 120px;
    height: 120px;

    padding: 0;
    margin: 0;

    border: none;
    outline: none;
    background: transparent;
    box-shadow: none;

    cursor: pointer;

    display: flex;
    align-items: center;
    justify-content: center;
}

#lotti-container .nshid-theme-toggle img {
    width: 120px;
    height: 120px;
    display: block;
    pointer-events: none;
}

body.page-id-6341 {
    background-color: white;
}

body.page-id-6341.nshid-darkmode {
    background-color: #243673;
}

#lotti-container .nshid-theme-toggle:hover {
    transform: scale(1.05);
    transition: transform 0.2s ease;
}

.page-id-6341 div.fixed-header {
    position: fixed;
    z-index: 3;
    gap: 0;
}

.page-id-6341 .fixed-header img {
    height: 210px;
    width: auto;
}

.page-id-6341 #block_one,
.page-id-6341 #block_three {
    padding-top: 340px;
    margin-top: 340px;
}

.page-id-6341 #block_three {
    background-color: white;
}

.page-id-6341 #block_two {
    padding-top: 360px;
    margin-top: 424px;
}

.page-id-6341 div.ratio-container {
    width: 1080px;
    height: 1720px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.page-id-6341 div.ratio-container#block_two {
    height: 1920px;
}

.interactivedisplay_container {
    max-width: 920px;
    margin: 0 auto;
}

.interactivedisplay_container form .wpforms-field-container {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    column-gap: 0px;
}

.interactivedisplay_firstname,
.interactivedisplay_lastname,
.interactivedisplay_mail,
.interactivedisplay_phone {
    width: 45%;
    max-width: 45%;
}

.page-id-6341 #block_three .interactivedisplay_radio,
.page-id-6341 #block_three .interactivedisplay_firstname label,
.page-id-6341 #block_three .interactivedisplay_lastname label,
.page-id-6341 #block_three .interactivedisplay_mail label,
.page-id-6341 #block_three .interactivedisplay_phone label,
.page-id-6341 #block_three input {
    font-size: 24px;
}

.page-id-6341 #block_three .interactivedisplay_radio ul {
    display: flex;
    flex-direction: row;
    gap: 40px;
}

.page-id-6341 #block_three .interactivedisplay_legal,
.page-id-6341 #block_three .interactivedisplay_sub {
    font-size: 20px;
}

.page-id-6341 #block_three .interactivedisplay_container button {
    font-size: 32px;
    height: 84px;
    width: 500px;
    margin-top: 60px;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

.interactivedisplay_container form .wpforms-field-container .interactivedisplay_firstname input,
.interactivedisplay_container form .wpforms-field-container .interactivedisplay_lastname input,
.interactivedisplay_container form .wpforms-field-container .interactivedisplay_mail input,
.interactivedisplay_container form .wpforms-field-container .interactivedisplay_phone input {
    width: 100%;
    max-width: 100%;
    border-color: #f8a119;
}

.interactivedisplay_container form .wpforms-field-container .interactivedisplay_radio {
    width: 100%;
}

.interactivedisplay_container form .wpforms-field-container .interactivedisplay_radio label {
    color: #243673;
}

.interactivedisplay_container form .wpforms-submit-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.interactivedisplay_container form .wpforms-submit-container button {
    width: 400px;
    background-color: #243673;
    color: white;
}

.interactivedisplay_container form .wpforms-submit-container button:hover {
    background-color: #f8a119;

}

.page-id-6341 .button-container,
.page-id-6341 .button-container-alt {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    padding: 0;
}

.page-id-6341 .button-container .elementor-widget-container,
.page-id-6341 .button-container-alt .elementor-widget-container {
    width: 100%;
}

.page-id-6341 .button-container .elementor-widget-button a,
.page-id-6341 .button-container .elementor-widget-button,
.page-id-6341 .button-container-alt .elementor-widget-button a,
.page-id-6341 .button-container-alt .elementor-widget-button {
    width: 100%;
    max-width: 980px !important;
    height: 84px;
    display: flex;
    justify-content: center;
    align-items: center;
}

/*Chart Modul*/

#block_two {
    background: #f8a119;
}

.page-id-6341 .button-container-alt a {
    background-color: white;

}

.page-id-6341 .button-container-alt a:hover {
    background-color: white;
}

.page-id-6341 .button-container-alt a span {
    color: #f8a119;
}

.nshid-calculator {
    background: #f8a119;
    color: #ffffff;
    width: 100%;
    margin: 0 auto;
    padding: 16px 14px 10px;
    font-family: Arial, sans-serif;
    box-sizing: border-box;
}

.nshid-calculator *,
.nshid-calculator *::before,
.nshid-calculator *::after {
    box-sizing: border-box;
}

.nshid-calculator__title {
    margin: 0 0 16px;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 700;
    color: #ffffff;
    text-align: center;
}

.nshid-calculator__form {
    margin-bottom: 18px;
}

.nshid-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 20px;
    align-items: start;
}

.nshid-field {
    display: flex;
    flex-direction: column;
}

.nshid-field--single {
    grid-column: 1 / 2;
}

.nshid-field label {
    display: block;
    margin: 0 0 6px;
    font-size: 24px;
    line-height: auto;
    font-weight: 600;
    color: #ffffff;
    font-family: "Exo", Sans-serif;
}

.nshid-summary-view {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    margin-left: 30px;
    margin-right: 30px;
}

#block_one .nshid-info-layer {
    position: absolute;
    width: 100%;
    height: 100%;
}

#block_one .nshid-info-layer button {
    background: transparent;
}

#block_one .nshid-info-layer button[data-point-id="sun"] {
    position: absolute;
    left: 220px;
    top: 450px;
}

#block_one .nshid-info-layer button[data-point-id="grid"] {
    position: absolute;
    left: 820px;
    top: 160px;
}

#block_one .nshid-info-layer button[data-point-id="house"] {
    position: absolute;
    left: 670px;
    top: 810px;
}

#block_one .nshid-info-layer button[data-point-id="battery"] {
    position: absolute;
    left: 700px;
    top: 600px;
}

#block_one .nshid-info-layer button[data-point-id="wallbox"] {
    position: absolute;
    left: 630px;
    top: 1000px;
}

#block_one .nshid-info-layer button[data-point-id="moon"] {
    position: absolute;
    top: 1000px;
    left: 560px;

}

#block_one .nshid-info-layer button[data-point-id="house-night"] {
    position: absolute;
    top: 510px;
    left: 670px;

}

#block_one .nshid-info-layer button[data-point-id="battery-night"] {
    position: absolute;
    top: 740px;
    left: 570px;

}

.nshid-info-banner {
    position: absolute;
}

.nshid-info-banner[data-banner-side="right"] {
    transform: translate(25px, -50%);
}

.nshid-info-banner[data-banner-side="left"] {
    transform: translate(calc(-100% - 25px), -50%);
}

body.page-id-6341 #block_one .nshid-info-banner {
    z-index: 99;
    color: white;
    width: 600px;
    padding: 20px;
    font-size: 28px;
    background-color: #243673;
    border-radius: 15px;
    border: 7px solid #7590C3;
}

body.page-id-6341 #block_one .nshid-info-banner .nshid-info-banner-content {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;

    gap: 30px;
}

#block_one .nshid-info-banner p {
    margin-bottom: 0;
}

.nshid-slide[data-slide="3"] .double-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-evenly;
}

.nshid-slide.double-list .left,
.nshid-slide.double-list .right {
    width: 40%;
}

.nshid-slide>.nshid-result-group {
    margin-top: 40px;
    width: 100%;
}

#lotti-container {
    padding: 0px;
}

#block_one {
    padding-left: 0px;
    padding-right: 0px;
}

.nshid-summary-view .nshid-summary-label {
    font-size: 24px;
    font-family: "Exo", Sans-serif;
}

.nshid-summary-view .nshid-summary-value {
    font-size: 36px;
    font-family: "Exo", Sans-serif;
    font-weight: 700;
}

.nshid-field input,
.nshid-field select {
    width: 100%;
    max-width: 465px;
    height: 74px;
    padding: 0 12px;
    border: none;
    border-radius: 0;
    background: #f3f3f3;
    color: #6d6d6d;
    font-size: 24px;
    font-family: "Lato", Sans-serif;
    outline: none;
    box-shadow: none;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.nshid-field input::placeholder {
    color: #b7b7b7;
    opacity: 1;
}

.nshid-field select {
    cursor: pointer;
    padding-right: 34px;
    background-image: linear-gradient(45deg, transparent 50%, #334b7d 50%), linear-gradient(135deg, #334b7d 50%, transparent 50%);
    background-position: calc(100% - 18px) calc(50% - 2px), calc(100% - 13px) calc(50% - 2px);
    background-size: 5px 5px, 5px 5px;
    background-repeat: no-repeat;
}

.nshid-field select:disabled,
.nshid-field input:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}

.nshid-heating-method-wrap {
    transition: opacity 0.2s ease;
}

.nshid-form-messages {
    margin-top: 12px;
}

.nshid-message {
    margin-bottom: 8px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.18);
    color: #ffffff;
    font-size: 12px;
    line-height: 1.45;
    border-left: 3px solid rgba(255, 255, 255, 0.9);
}

.nshid-message:last-child {
    margin-bottom: 0;
}

.nshid-calculator__results {
    position: relative;
    min-height: 285px;
    margin: 10px 0 18px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.nshid-slides {
    width: 100%;
    min-height: 285px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.nshid-slide {
    display: none;
    width: 100%;
    text-align: center;
    padding: 6px 42px 6px;
}

.nshid-slide--active {
    display: block;
}

.nshid-result-group {
    margin-bottom: 28px;
}

.nshid-result-group:last-child {
    margin-bottom: 0;
}

.nshid-result-label {
    margin-bottom: 8px;
    font-size: 24px;
    font-weight: 600;
    font-family: "Exo", Sans-serif;
    color: #ffffff;
}

.nshid-result-value {
    font-size: 36px;
    line-height: 1.25;
    font-weight: 700;
    color: #ffffff;
    font-family: "Exo", Sans-serif;
}

.nshid-result-value span {
    font-size: 36px;
    line-height: 1;
    font-weight: 700;
    color: #ffffff;
    font-family: "Exo", Sans-serif;
}

.nshid-nav {
    position: absolute;
    top: 60%;
    z-index: 2;
    width: 45px;
    height: 45px;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: #f1f1f1;
    color: #efb22d;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.15s ease, opacity 0.15s ease;
}

.nshid-nav:hover {
    transform: translateY(-50%) scale(1.05);
}

.nshid-nav:focus {
    outline: 2px solid rgba(255, 255, 255, 0.8);
    outline-offset: 2px;
}

.nshid-nav span {
    display: block;
    font-size: 50px;
    line-height: 1;
    margin-top: -11px;
}

.nshid-nav--prev {
    left: 0;
}

.nshid-nav--next {
    right: 0;
}

.nshid-chart-wrap {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.nshid-chart {
    margin: 12px 0 16px;
}

.nshid-chart__pie {
    --percent: 68;
    width: 340px;
    height: 340px;
    border-radius: 50%;
    background: conic-gradient(#efd38e 0 calc(var(--percent) * 1%),
            #efefef calc(var(--percent) * 1%) 100%);
    position: relative;
}

.nshid-chart-legend {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
    text-align: left;
}

.nshid-chart-legend__item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 20px;
    font-family: "Exo", Sans-serif;
    line-height: 1.3;
    color: #ffffff;
}

.nshid-chart-info-icons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 36px;
    margin-top: 22px;
}

.nshid-chart-info-button {
    background: transparent;
    border: none;
    padding: 10px;
    margin: 0;

    display: flex;
    align-items: center;
    gap: 10px;

    color: #ffffff;
    font-family: "Exo", Sans-serif;
    font-size: 20px;
    font-weight: 600;
    line-height: 1.2;

    cursor: pointer;
    transition: transform 0.2s ease;
}

.nshid-chart-info-button:hover {
    transform: scale(1.04);
}

.nshid-chart-info-button-icon {
    width: 34px;
    height: 34px;
    display: block;
    pointer-events: none;
}

.nshid-chart-info-box {
    position: absolute;

    left: 50%;
    bottom: 55px;

    transform: translateX(-50%);

    z-index: 999;

    width: 600px;
    max-width: 90vw;

    padding: 20px;

    color: white;
    font-size: 28px;

    background-color: #243673;

    border-radius: 15px;
    border: 7px solid #7590C3;

    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
}

.nshid-chart-info-box[hidden] {
    display: none;
}

.nshid-chart-info-box-content {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;

    gap: 30px;
}

.nshid-chart-info-box-icon {
    width: 42px;
    height: 42px;

    flex: 0 0 auto;
}

.nshid-chart-info-box-text {
    margin: 0;

    color: #ffffff;

    font-family: "Exo", Sans-serif;
    font-size: 28px;
    line-height: 1.25;
}

.nshid-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex: 0 0 12px;
}

.nshid-dot--light {
    background: #efefef;
}

.nshid-dot--dark {
    background: #efd38e;
}

.nshid-calculator__actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.nshid-button {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 15px 18px;
    background: #efefef;
    color: #eea91e;
    text-decoration: none;
    text-align: center;
    font-size: 14px;
    line-height: 1.3;
    font-weight: 400;
    border-radius: 4px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.22);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.nshid-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.24);
    color: #eea91e;
    text-decoration: none;
}

.nshid-button:focus {
    outline: 2px solid rgba(255, 255, 255, 0.8);
    outline-offset: 2px;
}

@media (max-width: 767px) {
    .nshid-calculator {
        padding: 14px 14px 8px;
    }

    .nshid-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px 16px;
    }

    .nshid-field label {
        font-size: 12px;
    }

    .nshid-field input,
    .nshid-field select {
        height: 38px;
        font-size: 13px;
        line-height: 38px;
    }

    .nshid-calculator__results {
        min-height: 270px;
        margin: 8px 0 18px;
    }

    .nshid-slides {
        min-height: 270px;
    }

    .nshid-slide {
        padding: 6px 34px 6px;
    }

    .nshid-result-group {
        margin-bottom: 24px;
    }

    .nshid-result-label {
        font-size: 12px;
    }

    .nshid-result-value {
        font-size: 17px;
    }

    .nshid-result-value span {
        font-size: 33px;
    }

    .nshid-chart__pie {
        width: 150px;
        height: 150px;
    }

    .nshid-button {
        font-size: 13px;
        padding: 14px 16px;
    }
}

@media (max-width: 480px) {
    .nshid-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .nshid-field--single {
        grid-column: auto;
    }

    .nshid-calculator__results {
        min-height: 250px;
    }

    .nshid-slides {
        min-height: 250px;
    }

    .nshid-slide {
        padding-left: 28px;
        padding-right: 28px;
    }

    .nshid-nav--prev {
        left: -2px;
    }

    .nshid-nav--next {
        right: -2px;
    }
}