/* =========================================================
   EK2026 — visual refresh layer for index2026.php
   - No HTML/JS structure changes; pure visual override.
   - Merchant accent color comes from --ek-main (PHP-injected).
   ========================================================= */

.ek2026-wrap,
.ek2026-wrap * {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.ek2026-wrap {
    max-width: 1480px;
    margin: 0 auto;
    padding: 24px 16px 48px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, Roboto, "Helvetica Neue", Arial, sans-serif;
    color: #1f2937;
}

@media (min-width: 768px) {
    .ek2026-wrap { padding: 32px 24px 64px; }
}

/* ---------- Sticky stepper ---------- */
.ek2026-stepper {
    position: sticky;
    top: 0;
    z-index: 1020;
    background: rgba(255,255,255,0.92);
    backdrop-filter: saturate(180%) blur(8px);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
    border-bottom: 1px solid #eef0f3;
    margin: -24px -16px 24px;
    padding: 14px 16px 16px;
}
@media (min-width: 768px) {
    .ek2026-stepper {
        margin: -32px -24px 28px;
        padding: 18px 24px 18px;
    }
}

.ek2026-stepper-inner {
    position: relative;
    max-width: 1480px;
    margin: 0 auto;
}

.ek2026-stepper-track {
    position: absolute;
    left: 18px;
    right: 18px;
    top: 18px;
    height: 4px;
    background: #e5e7eb;
    border-radius: 999px;
    z-index: 0;
}
.ek2026-stepper-fill {
    height: 100%;
    width: 0;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--ek-main, #f58024), var(--ek-main-hover, #f58024));
    transition: width .35s ease;
}

ol.ek2026-stepper-list,
.ek2026-stepper-list {
    list-style: none !important;
    list-style-type: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    grid-auto-flow: column;
    align-items: start;
    gap: 4px;
    position: relative;
    z-index: 1;
    width: 100% !important;
    box-sizing: border-box;
}
ol.ek2026-stepper-list > li,
.ek2026-stepper-list > li.ek2026-step {
    list-style: none !important;
    list-style-type: none !important;
    display: block !important;
    float: none !important;
    width: auto !important;
    min-width: 0 !important;
}
.ek2026-stepper-list > li.ek2026-step::marker { content: ""; }
.ek2026-stepper-list > li.ek2026-step::before { content: none !important; }

.ek2026-step {
    text-align: center;
    cursor: pointer;
    user-select: none;
    color: #6b7280;
    transition: color .2s ease;
    background: transparent;
    border: 0;
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}
.ek2026-step .ek2026-step-num {
    display: inline-flex !important;
    margin: 0 auto;
}
.ek2026-step .ek2026-step-label {
    display: block !important;
}
.ek2026-step:hover { color: #1f2937; }
.ek2026-step.is-locked { cursor: not-allowed; opacity: .45; }
.ek2026-step.is-locked:hover { color: #6b7280; }

.ek2026-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #ffffff;
    border: 2px solid #e5e7eb;
    color: #9ca3af;
    font-weight: 600;
    font-size: 14px;
    transition: all .25s ease;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}

.ek2026-step-label {
    display: block;
    margin-top: 8px;
    font-size: 10px;
    font-weight: 500;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 0 2px;
}

@media (min-width: 768px) {
    .ek2026-step-label { font-size: 13px; }
}

.ek2026-step.is-done .ek2026-step-num {
    background: var(--ek-main, #f58024);
    border-color: var(--ek-main, #f58024);
    color: var(--ek-second, #fff);
}
.ek2026-step.is-active .ek2026-step-num {
    background: #ffffff;
    border-color: var(--ek-main, #f58024);
    color: var(--ek-main, #f58024);
    box-shadow: 0 0 0 4px rgba(var(--ek-main-rgb, 245,128,36), 0.18);
    transform: scale(1.06);
}
.ek2026-step.is-active { color: #1f2937; }
.ek2026-step.is-active .ek2026-step-label { font-weight: 600; }

/* very small viewports: keep labels visible but tiny */
@media (max-width: 480px) {
    .ek2026-step-label { font-size: 9px; padding: 0; }
    .ek2026-step-num { width: 30px; height: 30px; font-size: 12px; }
    .ek2026-stepper-track { left: 15px; right: 15px; top: 15px; }
}

/* ---------- Cards / panels ---------- */
.ek2026-wrap .panel-group { margin-bottom: 0; }

.ek2026-wrap .panel-default {
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    box-shadow: 0 1px 2px rgba(16,24,40,0.04), 0 1px 3px rgba(16,24,40,0.04);
    background: #ffffff;
    overflow: hidden;
    margin-bottom: 16px;
    transition: box-shadow .2s ease, border-color .2s ease;
}
.ek2026-wrap .panel-default:hover {
    box-shadow: 0 4px 12px rgba(16,24,40,0.06), 0 2px 4px rgba(16,24,40,0.04);
}

.ek2026-wrap .panel-default > .panel-heading {
    padding: 0;
    border: 0;
    background: #ffffff !important;
    color: #1f2937 !important;
    border-bottom: 1px solid #f1f3f5;
}

.ek2026-wrap .panel-title { font-size: 16px; }
.ek2026-wrap .panel-title > a {
    display: block;
    padding: 18px 22px;
    color: #1f2937 !important;
    text-decoration: none !important;
    font-weight: 600;
    letter-spacing: -0.01em;
    position: relative;
}
.ek2026-wrap .panel-title > a:after {
    content: "\25BE";
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%) rotate(180deg);
    color: #9ca3af;
    transition: transform .25s ease;
    font-size: 14px;
}
.ek2026-wrap .panel-title > a.collapsed:after {
    transform: translateY(-50%) rotate(0);
}

@media (min-width: 768px) {
    .ek2026-wrap .panel-title { font-size: 18px; }
    .ek2026-wrap .panel-title > a { padding: 22px 28px; }
}

.ek2026-wrap .panel-body {
    padding: 22px;
}
@media (min-width: 768px) {
    .ek2026-wrap .panel-body { padding: 28px; }
}

/* clearfix the float-based bootstrap 3 columns inside step bodies */
.ek2026-wrap .panel-body:after {
    content: "";
    display: table;
    clear: both;
}

/* ---------- Form sidebar (right column) ---------- */
@media (min-width: 992px) {
    /* the right-side column inside each step body */
    .ek2026-wrap .panel-body > .col-lg-4 {
        padding-left: 28px;
    }
    .ek2026-wrap .panel-body > .col-lg-4 > .input-group,
    .ek2026-wrap .panel-body > .col-lg-4 > p > .panel-default,
    .ek2026-wrap .panel-body > .col-lg-4 > .panel-default,
    .ek2026-wrap .panel-body > .col-lg-4 > .ek2026-door-preview,
    .ek2026-wrap .panel-body > .col-lg-4 > .ek2026-form-step1 {
        max-width: 380px;
    }
    .ek2026-wrap .panel-body > .col-lg-4 .iconarrow .btn,
    .ek2026-wrap .panel-body > .col-lg-4 .btn-block {
        max-width: 380px;
    }
    /* image column: a touch of breathing room */
    .ek2026-wrap .panel-body > .col-lg-8 { padding-right: 16px; }
}

/* input-group: keep transparent block — markup inconsistent across steps,
   so we don't paint a card around it. Spacing handled per form-control. */
.ek2026-wrap .panel-body .input-group {
    display: block;
    background: transparent;
    border: 0;
    padding: 0;
    margin: 0 0 8px;
}

/* form-control spacing — uniform regardless of being wrapped in input-group */
.ek2026-wrap .panel-body .form-control {
    margin-bottom: 14px;
    width: 100%;
}
.ek2026-wrap .panel-body textarea.form-control {
    height: auto;
    min-height: 88px;
    padding: 12px 14px;
}

/* drop the Bootstrap whitespace <br> noise inside form areas */
.ek2026-wrap .panel-body form br,
.ek2026-wrap .panel-body .input-group br { display: none; }

/* labels universally above the input */
.ek2026-wrap .panel-body label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    margin: 4px 0 6px;
    line-height: 1.4;
}
.ek2026-wrap .panel-body form label,
.ek2026-wrap .panel-body .input-group label { font-size: 13px; }

/* file inputs less ugly */
.ek2026-wrap .panel-body input[type="file"].form-control {
    height: auto;
    padding: 10px 12px;
    background: #f9fafb;
    cursor: pointer;
}

/* step 4 window-type selector — two images side-by-side, button below */
.ek2026-wrap #uvegTipus {
    margin: 12px 0 24px;
    line-height: 1.6;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.ek2026-wrap #uvegTipus > br { display: none; }
.ek2026-wrap #uvegTipus > #uvegFajtaLabel,
.ek2026-wrap #uvegTipus > span {
    flex-basis: 100%;
    margin-bottom: 4px;
}
/* the leading "Üveg fajtája:" text node before the span needs flex-basis 100% too —
   but it's a text node; we wrap behavior via the label being block-ish */
.ek2026-wrap #uvegTipus { padding-top: 4px; }

.ek2026-wrap #uvegTipus .ablakTipus {
    display: block;
    flex: 1 1 calc(50% - 10px);
    width: calc(50% - 10px);
    max-width: calc(50% - 10px);
    height: auto !important;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 10px;
    margin: 0 !important;
    cursor: pointer;
    border: 3px solid #ffffff !important;
    outline: 1px solid #e5e7eb;
    box-sizing: border-box;
    transition: outline-color .15s ease, transform .12s ease;
}
.ek2026-wrap #uvegTipus .ablakTipus:hover {
    outline-color: #cbd5e1;
    transform: translateY(-1px);
}
.ek2026-wrap #uvegTipus .ablakTipus.activeAblakTipus {
    border-color: #ffffff !important;
    outline: 3px solid var(--ek-main, #f58024);
}

/* spacing between window selector and the next button */
.ek2026-wrap .panel-body .iconarrow {
    margin-top: 20px !important;
    clear: both;
    position: relative;
    z-index: 1;
}

/* secondary buttons (Panel módosítása, choose color) — full width but tidy */
.ek2026-wrap .panel-body .btn-info.btn-block {
    margin-top: 4px;
    margin-bottom: 14px;
}
.ek2026-wrap .panel-body .iconarrow {
    margin: 0 0 12px;
}
.ek2026-wrap .panel-body .iconarrow:last-child { margin-bottom: 0; }

/* tighten extra <p> wrappers Bootstrap 3 markup uses */
.ek2026-wrap .panel-body p { margin-bottom: 12px; }
.ek2026-wrap .panel-body p:empty { display: none; }
.ek2026-wrap .panel-body > .col-lg-4 > p { margin-bottom: 0; }

/* nested help panels inside steps — keep but soften */
.ek2026-wrap .panel-body .panel-default {
    box-shadow: none;
    background: #f9fafb;
    border-color: #eef0f3;
    border-radius: 10px;
    display: block !important;
    width: 100% !important;
    float: none !important;
    clear: both !important;
    box-sizing: border-box;
}
.ek2026-wrap .panel-body .panel-default .panel-body {
    width: auto !important;
    float: none !important;
}
.ek2026-wrap .panel-body .panel-default .panel-body {
    padding: 14px 16px;
    color: #4b5563;
    font-size: 14px;
    line-height: 1.55;
}

/* responsive image inside panels */
.ek2026-wrap .imageborder {
    border-radius: 10px;
    overflow: hidden;
}

/* ---------- Inputs ---------- */
.ek2026-wrap .form-control {
    height: 46px;
    padding: 10px 14px;
    border-radius: 10px;
    border: 1.5px solid #e5e7eb;
    background: #ffffff;
    font-size: 16px;
    color: #1f2937;
    box-shadow: none;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.ek2026-wrap .form-control:focus {
    border-color: var(--ek-main, #f58024);
    box-shadow: 0 0 0 4px rgba(var(--ek-main-rgb, 245,128,36), 0.18);
    outline: none;
}
.ek2026-wrap .input-group label {
    display: block;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #374151 !important;
    line-height: 1.4;
    margin: 0 0 6px !important;
    letter-spacing: -0.005em;
}
.ek2026-wrap .input-group label:first-child { margin-top: 0 !important; }
.ek2026-wrap .input-group .form-control + label,
.ek2026-wrap .input-group br + label { margin-top: 14px !important; }
/* form-control inside step 1 input-group: no extra bottom margin (gap handled by label margin-top) */
.ek2026-wrap .panel-body .input-group .form-control {
    margin-bottom: 0 !important;
}

/* Bootstrap 3 strips border-radius from .form-control inside .input-group
   (assumes there's a button/addon next to it). Force the modern rounded look. */
.ek2026-wrap .input-group .form-control,
.ek2026-wrap .input-group .form-control:first-child,
.ek2026-wrap .input-group .form-control:last-child {
    border-radius: 10px !important;
    border-top-left-radius: 10px !important;
    border-top-right-radius: 10px !important;
    border-bottom-left-radius: 10px !important;
    border-bottom-right-radius: 10px !important;
}

/* the A/B/C/D/E badge inside labels */
.ek2026-wrap .input-group label .jeloles {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 6px;
    font-size: 12px;
    margin-right: 6px;
    vertical-align: middle;
}

/* ---------- Buttons ---------- */
.ek2026-wrap .btn {
    border-radius: 10px;
    font-weight: 600;
    letter-spacing: 0.01em;
    transition: transform .08s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
    border-width: 1px;
}
.ek2026-wrap .btn-lg {
    padding: 14px 22px;
    font-size: 15px;
}

.ek2026-wrap .btn-success,
.ek2026-wrap .kerdesButton {
    background: linear-gradient(180deg, var(--ek-main, #f58024), var(--ek-main-hover, #f58024)) !important;
    border-color: var(--ek-main, #f58024) !important;
    color: var(--ek-second, #fff) !important;
    box-shadow: 0 1px 2px rgba(16,24,40,0.06), 0 4px 12px rgba(var(--ek-main-rgb, 245,128,36), 0.25);
}
.ek2026-wrap .btn-success:hover,
.ek2026-wrap .kerdesButton:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(16,24,40,0.08), 0 8px 18px rgba(var(--ek-main-rgb, 245,128,36), 0.32);
}
.ek2026-wrap .btn-success:active,
.ek2026-wrap .kerdesButton:active {
    transform: translateY(0);
    box-shadow: 0 1px 2px rgba(16,24,40,0.08);
}
.ek2026-wrap .btn-success[disabled],
.ek2026-wrap .btn-success.disabled {
    opacity: 0.55;
    box-shadow: none;
    transform: none;
}

.ek2026-wrap .btn-info {
    background: #f3f4f6 !important;
    border-color: #e5e7eb !important;
    color: #1f2937 !important;
    box-shadow: none;
}
.ek2026-wrap .btn-info:hover {
    background: #e9ebef !important;
    border-color: #d1d5db !important;
    color: #1f2937 !important;
    transform: translateY(-1px);
}

.ek2026-wrap .iconarrow .glyphicon { font-size: 13px; opacity: 0.85; }

/* ---------- Sticky price chip ---------- */
#sumAr {
    background: rgba(17,24,39,0.92) !important;
    border-radius: 999px !important;
    padding: 10px 18px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    margin: 12px !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.18) !important;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    right: 0 !important;
    top: 0 !important;
}
#sumAr b {
    color: var(--ek-main, #f58024);
    font-weight: 700;
    margin-left: 4px;
}

/* ---------- Modals ---------- */
.modal-content {
    border-radius: 16px;
    border: 0;
    box-shadow: 0 20px 60px rgba(16,24,40,0.25), 0 6px 20px rgba(16,24,40,0.10);
    overflow: hidden;
}
.modal-header {
    padding: 18px 22px;
    border-bottom: 1px solid #f1f3f5;
    background: #ffffff;
}
.modal-header .modal-title {
    color: #1f2937;
    font-weight: 600;
    font-size: 17px;
}
.modal-header .close {
    color: #6b7280;
    opacity: 0.8;
    font-size: 24px;
    line-height: 1;
    transition: opacity .15s ease, transform .1s ease;
}
.modal-header .close:hover { opacity: 1; transform: scale(1.1); }
.modal-body { padding: 22px; }
.modal-footer {
    padding: 16px 22px;
    border-top: 1px solid #f1f3f5;
    background: #fafbfc;
}
.modal-backdrop.in { opacity: 0.55; }

/* start modal — modern look */
#myModalStart .modal-dialog {
    width: auto;
    max-width: 480px;
    margin: 30px auto;
}
@media (max-width: 519px) {
    #myModalStart .modal-dialog { margin: 16px; }
}
#myModalStart .modal-content {
    border-radius: 18px;
    overflow: hidden;
}
#myModalStart .modal-header {
    border-bottom: 0;
    padding: 24px 28px 8px;
    background: #ffffff;
}
#myModalStart .modal-header > p {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #1f2937;
    margin: 0 !important;
    width: auto !important;
    line-height: 1.3;
    text-align: left !important;
    padding: 0 !important;
}
#myModalStart .modal-header > p b { font-weight: 700; }
#myModalStart .modal-header .close {
    position: absolute;
    right: 18px;
    top: 18px;
    z-index: 2;
    font-size: 26px;
    color: #6b7280;
    opacity: 0.8;
}
#myModalStart .modal-body {
    padding: 8px 28px 28px;
    text-align: left !important;
}
#myModalStart .modal-body h4 {
    font-size: 14px !important;
    font-weight: 600;
    color: #6b7280;
    margin: 18px 0 10px !important;
    text-align: left !important;
    letter-spacing: 0.01em;
}
#myModalStart .modal-body hr {
    border: 0 !important;
    border-top: 1px solid #eef0f3 !important;
    margin: 20px 0 0 !important;
}
#myModalStart .defaultMeretValaszto {
    display: block;
    padding: 14px 20px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    border-radius: 12px !important;
    background: linear-gradient(180deg, var(--ek-main, #f58024), var(--ek-main-hover, #f58024)) !important;
    color: var(--ek-second, #fff) !important;
    box-shadow: 0 1px 2px rgba(16,24,40,0.06), 0 4px 12px rgba(var(--ek-main-rgb, 245,128,36), 0.25);
    transition: transform .12s ease, box-shadow .15s ease;
    text-align: center;
    margin: 0 0 10px;
    line-height: 1.3;
}
#myModalStart .defaultMeretValaszto:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(16,24,40,0.08), 0 8px 18px rgba(var(--ek-main-rgb, 245,128,36), 0.32);
}
#myModalStart .defaultMeretValaszto:active {
    transform: translateY(0);
}
#myModalStart .modal-body > br { display: none; }
#myModalStart .modal-body > div[style*="font-size:18px"] {
    font-size: 13px !important;
    color: #6b7280;
    text-align: center;
    margin-top: 18px;
    font-weight: 500;
}

/* window / door confirm modals — narrower, modern */
#myModalWindowConfirm .modal-dialog,
#myModalDoorConfirm .modal-dialog {
    width: auto;
    max-width: 460px;
    margin: 60px auto;
}
@media (max-width: 499px) {
    #myModalWindowConfirm .modal-dialog,
    #myModalDoorConfirm .modal-dialog { margin: 30px 16px; }
}
#myModalWindowConfirm .modal-content,
#myModalDoorConfirm .modal-content { border-radius: 18px; }
#myModalWindowConfirm .modal-header,
#myModalDoorConfirm .modal-header {
    border-bottom: 0;
    padding: 24px 28px 0;
}
#myModalWindowConfirm .modal-body,
#myModalDoorConfirm .modal-body {
    padding: 16px 28px 28px !important;
    text-align: center !important;
}
#myModalWindowConfirm .modal-body h3,
#myModalDoorConfirm .modal-body h3 {
    font-size: 22px;
    font-weight: 700;
    color: #1f2937;
    margin: 0 0 22px !important;
    line-height: 1.3;
}
#myModalWindowConfirm .modal-body br,
#myModalDoorConfirm .modal-body br { display: none; }
#myModalWindowConfirm .modal-body .kerdesButton,
#myModalDoorConfirm .modal-body .kerdesButton {
    display: inline-block;
    margin: 0 6px !important;
    padding: 12px 28px !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    min-width: 140px;
}

/* door (ajto) selector modal — narrower, modern, hide footer */
#myModalAjto .modal-dialog {
    width: auto;
    max-width: 920px;
    margin: 30px auto;
}
@media (max-width: 959px) {
    #myModalAjto .modal-dialog { margin: 20px; }
}
@media (max-width: 767px) {
    #myModalAjto .modal-dialog { margin: 10px; }
}
#myModalAjto .modal-content { border-radius: 16px; }
#myModalAjto .modal-header {
    padding: 20px 28px;
    border-bottom: 1px solid #f1f3f5;
}
#myModalAjto .modal-body { padding: 24px !important; }
/* Several modals (myModalAblak, myModalAjto, myModalMotor, myModalThx) have
   their <div class="modal-footer"> placed OUTSIDE the <div class="modal-content">
   — that's invalid Bootstrap 3 structure and renders as a stray bar at the
   bottom of the dialog. Hide every such orphan footer. */
.modal-dialog > .modal-footer {
    display: none !important;
}

#myModalAjto #doorDetailsTable {
    width: 100%;
    border-collapse: separate;
    border-spacing: 12px;
}
#myModalAjto #doorDetailsTable td {
    width: 33.333%;
    background: #ffffff;
    border: 1.5px solid #e5e7eb;
    border-radius: 14px;
    padding: 22px 18px !important;
    transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease;
    cursor: pointer;
    vertical-align: top;
}
#myModalAjto #doorDetailsTable td:hover {
    border-color: var(--ek-main, #f58024);
    box-shadow: 0 6px 18px rgba(16,24,40,0.08);
    transform: translateY(-2px);
}
#myModalAjto #doorDetailsTable td { padding: 0 !important; border: 0 !important; }
#myModalAjto .ek2026-door-card {
    display: block;
    margin: 0;
    padding: 18px 18px 20px;
    background: #ffffff;
    border: 2px solid #e5e7eb;
    border-radius: 14px;
    cursor: pointer;
    transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease, background .15s ease;
    font-weight: normal;
    text-align: center;
}
#myModalAjto .ek2026-door-card:hover {
    border-color: #cbd5e1;
    box-shadow: 0 6px 18px rgba(16,24,40,0.08);
    transform: translateY(-2px);
}
#myModalAjto .ek2026-door-card img {
    border-radius: 10px;
    max-width: 100%;
    height: auto;
    margin: 0 auto 14px;
    display: block;
}
#myModalAjto .ek2026-door-card .ajtoCheckbox {
    position: absolute !important;
    opacity: 0 !important;
    pointer-events: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
}
#myModalAjto .ek2026-door-card b {
    display: block;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.45;
    color: #1f2937;
    text-align: center;
}

/* selected state — whole card highlighted in merchant color */
#myModalAjto .ek2026-door-card:has(.ajtoCheckbox:checked) {
    border-color: var(--ek-main, #f58024);
    background: rgba(var(--ek-main-rgb, 245,128,36), 0.06);
    box-shadow: 0 0 0 3px rgba(var(--ek-main-rgb, 245,128,36), 0.18);
}
#myModalAjto .ek2026-door-card:has(.ajtoCheckbox:checked) b {
    color: var(--ek-main, #f58024);
}

@media (max-width: 767px) {
    #myModalAjto #doorDetailsTable,
    #myModalAjto #doorDetailsTable tbody,
    #myModalAjto #doorDetailsTable tr { display: block; }
    #myModalAjto #doorDetailsTable td {
        display: block;
        width: 100% !important;
        margin-bottom: 12px;
    }
}

/* color selector modal — narrower + modern swatches */
#myModal .modal-dialog,
#myModalAblakKeretSzin .modal-dialog {
    width: auto;
    max-width: 900px;
    margin: 30px auto;
}
@media (max-width: 939px) {
    #myModal .modal-dialog,
    #myModalAblakKeretSzin .modal-dialog { margin: 20px; }
}
@media (max-width: 767px) {
    #myModal .modal-dialog,
    #myModalAblakKeretSzin .modal-dialog { margin: 10px; }
}
#myModal .modal-content,
#myModalAblakKeretSzin .modal-content { border-radius: 16px; }
#myModal .modal-header,
#myModalAblakKeretSzin .modal-header {
    padding: 20px 28px;
    border-bottom: 1px solid #f1f3f5;
}
#myModal .modal-body,
#myModalAblakKeretSzin .modal-body { padding: 18px 22px 24px !important; }

/* color swatch polish */
#myModal .color,
#myModalAblakKeretSzin .color {
    display: block;
    height: 56px;
    line-height: 56px;
    border-radius: 8px;
    margin: 4px 0;
    text-align: center;
    color: #ffffff;
    font-size: 12px;
    font-weight: 600;
    text-shadow: 0 1px 2px rgba(0,0,0,0.4);
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.05);
    cursor: pointer;
    transition: transform .12s ease, box-shadow .15s ease;
    position: relative;
}
#myModal .color:hover,
#myModalAblakKeretSzin .color:hover {
    transform: scale(1.06);
    box-shadow: 0 4px 12px rgba(16,24,40,0.18), inset 0 0 0 1px rgba(0,0,0,0.05);
    z-index: 2;
}
#myModal a,
#myModalAblakKeretSzin a {
    text-decoration: none !important;
    display: block;
}
#myModal a > [class*="col-"],
#myModalAblakKeretSzin a > [class*="col-"] {
    padding-left: 4px;
    padding-right: 4px;
}

/* panel selector modal — narrower + modern panel cards */
#myModalpanel .modal-dialog {
    width: auto;
    max-width: 1080px;
    margin: 30px auto;
}
@media (max-width: 1119px) {
    #myModalpanel .modal-dialog { margin: 30px 20px; }
}
@media (max-width: 767px) {
    #myModalpanel .modal-dialog { margin: 10px; }
}
#myModalpanel .modal-content { border-radius: 16px; }
#myModalpanel .modal-header {
    padding: 20px 28px;
    border-bottom: 1px solid #f1f3f5;
}
#myModalpanel .modal-header .modal-title {
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
}
#myModalpanel .modal-body { padding: 8px 22px 24px; }

/* section titles inside the modal */
#myModalpanel .modal-body h3 {
    font-size: 18px !important;
    font-weight: 700;
    color: #1f2937;
    height: auto !important;
    margin: 22px 0 6px !important;
    letter-spacing: -0.01em;
}
#myModalpanel .modal-body h3:first-child { margin-top: 8px !important; }
#myModalpanel .modal-body hr {
    border: 0 !important;
    border-top: 1px solid #eef0f3 !important;
    margin: 0 0 16px !important;
}

/* panel card */
#myModalpanel .panelBox {
    padding: 8px;
    margin-bottom: 4px;
}
#myModalpanel .boxlink {
    display: block;
    text-decoration: none !important;
    color: inherit;
}
#myModalpanel .zpanel {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    overflow: hidden;
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    box-shadow: 0 1px 2px rgba(16,24,40,0.04);
    position: relative;
    padding: 0 !important;
    cursor: pointer;
}
#myModalpanel .zpanel:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(16,24,40,0.10), 0 2px 4px rgba(16,24,40,0.06);
    border-color: var(--ek-main, #f58024);
}

/* override the inline padding-top:80px on the img — title is now in flow above */
#myModalpanel .zpanel .ztitle {
    position: static !important;
    display: block;
    padding: 12px 14px !important;
    background: linear-gradient(180deg, var(--ek-main, #f58024), var(--ek-main-hover, #f58024)) !important;
    color: var(--ek-second, #fff) !important;
    border: 0 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    text-align: center;
    min-height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0;
}
#myModalpanel .zpanel img.responsive,
#myModalpanel .zpanel img.zoomPic {
    padding-top: 16px !important;
    padding-bottom: 16px;
    width: auto;
    max-width: 90%;
    margin: 0 auto;
    display: block;
}

/* selected panel highlight */
#myModalpanel .selectedDoor .zpanel,
#myModalpanel .zpanel.selectedDoor {
    border-color: var(--ek-main, #f58024) !important;
    box-shadow: 0 0 0 3px rgba(var(--ek-main-rgb, 245,128,36), 0.18) !important;
}

@media (max-width: 767px) {
    #myModalpanel .zpanel .ztitle {
        font-size: 12px !important;
        min-height: 56px;
        padding: 10px 12px !important;
    }
}

/* ---------- Misc legacy elements polish ---------- */
.ek2026-wrap .selectMotorButton {
    border-radius: 12px;
    transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
}
.ek2026-wrap .selectMotorButton:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(16,24,40,0.08);
}

/* labels on top of garage image */
.ek2026-wrap .jeloles {
    border-radius: 6px;
    font-weight: 700;
    font-size: 12px;
}

/* placeholder windows / personnel doors get rounded */
.ek2026-wrap .palceholderWindow,
.ek2026-wrap .szemelybejaro {
    border-radius: 4px;
}

/* once a door is selected, hide the other un-chosen placeholders so only
   the actual door visualization shows. visibility: hidden (not display:none)
   preserves the layout — otherwise the selected slot would shift to the left. */
.ek2026-wrap #szemelybejaro:has(.selectedDoor) .szemelybejaro:not(.selectedDoor) {
    visibility: hidden !important;
    animation: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

/* personnel-door placeholder — strongly visible on any panel color */
.ek2026-wrap #szemelybejaro .szemelybejaro {
    position: relative;
    border: 4px solid var(--ek-main, #f58024) !important;
    border-radius: 6px;
    box-shadow:
        0 0 0 2px rgba(0, 0, 0, 0.55),                                   /* dark outer hairline */
        0 0 0 4px rgba(255, 255, 255, 0.85),                             /* white separator */
        inset 0 0 0 2px rgba(0, 0, 0, 0.45),                             /* dark inner hairline */
        inset 0 0 0 3px rgba(255, 255, 255, 0.6),                        /* white inner stroke */
        inset 0 0 60px rgba(var(--ek-main-rgb, 245, 128, 36), 0.30),     /* warm inner glow */
        0 0 22px rgba(var(--ek-main-rgb, 245, 128, 36), 0.45);           /* outer glow */
    background:
        repeating-linear-gradient(
            45deg,
            rgba(var(--ek-main-rgb, 245, 128, 36), 0.18) 0,
            rgba(var(--ek-main-rgb, 245, 128, 36), 0.18) 10px,
            rgba(0, 0, 0, 0.20) 10px,
            rgba(0, 0, 0, 0.20) 20px
        ) !important;
    transition: background-color .2s ease, box-shadow .2s ease, transform .2s ease;
    animation: ek2026-door-pulse 2.4s ease-in-out infinite;
    cursor: pointer;
}

@keyframes ek2026-door-pulse {
    0%, 100% {
        box-shadow:
            0 0 0 2px rgba(0, 0, 0, 0.55),
            0 0 0 4px rgba(255, 255, 255, 0.85),
            inset 0 0 0 2px rgba(0, 0, 0, 0.45),
            inset 0 0 0 3px rgba(255, 255, 255, 0.6),
            inset 0 0 60px rgba(var(--ek-main-rgb, 245, 128, 36), 0.30),
            0 0 22px rgba(var(--ek-main-rgb, 245, 128, 36), 0.45);
    }
    50% {
        box-shadow:
            0 0 0 2px rgba(0, 0, 0, 0.55),
            0 0 0 4px rgba(255, 255, 255, 0.85),
            inset 0 0 0 2px rgba(0, 0, 0, 0.45),
            inset 0 0 0 3px rgba(255, 255, 255, 0.6),
            inset 0 0 60px rgba(var(--ek-main-rgb, 245, 128, 36), 0.45),
            0 0 36px rgba(var(--ek-main-rgb, 245, 128, 36), 0.75);
    }
}

.ek2026-wrap #szemelybejaro .szemelybejaro:hover {
    transform: scale(1.015);
    animation-play-state: paused;
    box-shadow:
        0 0 0 2px rgba(0, 0, 0, 0.55),
        0 0 0 4px rgba(255, 255, 255, 1),
        inset 0 0 0 2px rgba(0, 0, 0, 0.45),
        inset 0 0 0 3px rgba(255, 255, 255, 0.7),
        inset 0 0 80px rgba(var(--ek-main-rgb, 245, 128, 36), 0.55),
        0 0 48px rgba(var(--ek-main-rgb, 245, 128, 36), 0.85) !important;
}

/* the floating door label overlay is replaced by #doorPreview in step 5 */
.fromAjanlatDoorLabel {
    display: none !important;
}

/* selected-door preview card (step 5, above TOVÁBB button) */
.ek2026-wrap .ek2026-door-preview {
    margin-bottom: 14px;
}
.ek2026-wrap .ek2026-door-thumb {
    display: flex;
    gap: 12px;
    align-items: center;
    padding: 12px 14px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    box-shadow: 0 1px 2px rgba(15,23,42,0.04);
}
.ek2026-wrap .ek2026-door-thumb img {
    width: 64px;
    height: auto;
    border-radius: 8px;
    flex-shrink: 0;
    border: 1px solid rgba(0,0,0,0.06);
}
.ek2026-wrap .ek2026-door-name {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.4;
    color: #1f2937;
    letter-spacing: -0.005em;
}

/* small "Személybejáró törlése" button under the door preview thumbnail */
.ek2026-wrap .ek2026-door-remove-btn {
    display: block;
    width: 100%;
    margin-top: 10px;
    padding: 10px 14px;
    background: #ffffff;
    color: #6b7280;
    border: 1.5px solid #e5e7eb;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all .15s ease;
}
.ek2026-wrap .ek2026-door-remove-btn:hover {
    background: #fee2e2;
    border-color: #f87171;
    color: #b91c1c;
}

/* "Nem kérek személybejárót" button at the bottom of #myModalAjto */
.ek2026-no-door-row {
    text-align: center;
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid #f1f3f5;
}
.ek2026-no-door-btn {
    background: #f3f4f6 !important;
    color: #1f2937 !important;
    border: 2px solid #9ca3af !important;
    border-radius: 10px !important;
    padding: 12px 28px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: -0.005em;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    transition: all .15s ease;
    cursor: pointer;
}
.ek2026-no-door-btn:hover {
    background: #fee2e2 !important;
    border-color: #f87171 !important;
    color: #b91c1c !important;
    box-shadow: 0 2px 6px rgba(220, 38, 38, 0.18);
    transform: translateY(-1px);
}
.ek2026-no-door-btn:active {
    transform: translateY(0);
}

/* the legacy duplicate — keep the modern card definition below in sync */
.fromAjanlatDoorLabel-legacy {
    /* anchored to the bottom of the door (not centered) — handle stays visible */
    top: auto !important;
    bottom: 14px !important;
    transform: translateX(-50%) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    color: #111827 !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, Roboto, "Helvetica Neue", Arial, sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
    letter-spacing: -0.005em !important;
    padding: 12px 16px !important;
    border-radius: 12px !important;
    border: 1px solid rgba(15, 23, 42, 0.08) !important;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.06),
        0 6px 16px rgba(15, 23, 42, 0.16),
        0 18px 36px rgba(15, 23, 42, 0.18) !important;
    width: max-content !important;
    max-width: 92% !important;
    min-width: 0;
    text-align: center !important;
    backdrop-filter: blur(10px) saturate(140%) !important;
    -webkit-backdrop-filter: blur(10px) saturate(140%) !important;
    pointer-events: none;
    /* white-space: nowrap would hide overflow at narrow doors — keep wraps but let
       the box grow horizontally as much as it needs up to max-width */
    white-space: normal;
}

/* selected personnel door — only a wide frame painted in the panel color,
   transparent interior so the panels and windows behind stay visible. A
   small knob is rendered via ::after. */
.ek2026-wrap #szemelybejaro .szemelybejaro.selectedDoor {
    border: 10px solid var(--ek-door-color, #9ca3af) !important;
    border-radius: 3px;
    background: transparent !important;
    background-image: none !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.55),                /* outer dark hairline */
        inset 0 0 0 1px rgba(0, 0, 0, 0.45),          /* inner dark hairline */
        inset 1px 0 0 rgba(255, 255, 255, 0.20),      /* left highlight */
        inset -1px 0 0 rgba(0, 0, 0, 0.18),           /* right shadow */
        /* lifted-off-the-kapu effect — multi-stop drop shadow */
        2px 4px 6px rgba(0, 0, 0, 0.20),
        4px 10px 18px rgba(0, 0, 0, 0.28),
        6px 18px 36px rgba(0, 0, 0, 0.22) !important;
    animation: none;
    position: relative;
    cursor: pointer;
    transition: filter .15s ease;
}
.ek2026-wrap #szemelybejaro .szemelybejaro.selectedDoor:hover {
    filter: brightness(1.05);
}

/* doorknob — small metallic circle near the right edge, vertically centered */
.ek2026-wrap #szemelybejaro .szemelybejaro.selectedDoor::after {
    content: "";
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background:
        radial-gradient(
            circle at 32% 30%,
            #ffffff 0%,
            #e5e7eb 35%,
            #9ca3af 75%,
            #4b5563 100%
        );
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.55),
        0 2px 4px rgba(0, 0, 0, 0.45);
    pointer-events: none;
    z-index: 2;
}

/* respect motion-reduced preference */
@media (prefers-reduced-motion: reduce) {
    .ek2026-wrap #szemelybejaro .szemelybejaro {
        animation: none;
    }
}

/* ---------- Garage preview — proportional to entered dimensions ---------- */

/* Drop the legacy corkboard frame image only when it follows a .kapuContainer
   (steps 2..5). Step 1's measurement diagram uses .imageborder too — keep it. */
.ek2026-wrap .kapuContainer ~ .imageborder,
.ek2026-wrap .kapuContainer + .imageborder {
    display: none !important;
}

/* The kapu preview container = the actual garage opening, sized to the real
   width/height ratio. JS sets --ek-kapu-ratio after every setGarageSize.
   Multi-layer box-shadow draws a stylized garage frame: dark jamb + light wall
   around the opening, plus a subtle floor strip and drop shadow. */
.ek2026-wrap .kapuContainer {
    position: relative !important;
    width: calc(100% - 36px) !important;
    max-width: 700px !important;
    height: auto !important;
    aspect-ratio: var(--ek-kapu-ratio, 1.6);
    margin: 28px auto 44px !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    border-radius: 6px;
    overflow: hidden;
    /* fallback gradient visible before a panel is chosen */
    background:
        linear-gradient(180deg, #e5e7eb 0%, #cbd5e1 100%);
    box-shadow:
        /* inner highlight & shadow for door depth */
        inset 0 1px 0 rgba(255,255,255,0.45),
        inset 0 -2px 0 rgba(0,0,0,0.18),
        inset 0 0 0 1px rgba(15,23,42,0.15),
        /* dark jamb (door frame) */
        0 0 0 6px #1f2937,
        /* lighter wall around the jamb */
        0 0 0 16px #d1d5db,
        /* fine outer separator */
        0 0 0 17px rgba(15,23,42,0.10),
        /* floor / drop shadow */
        0 22px 32px -6px rgba(16,24,40,0.22),
        0 8px 14px -2px rgba(16,24,40,0.10);
    transition: aspect-ratio .2s ease;
}

/* tiny "floor" strip at the bottom of the wall for extra garage feel */
.ek2026-wrap .kapuContainer::after {
    content: "";
    position: absolute;
    left: -16px;
    right: -16px;
    bottom: -22px;
    height: 6px;
    background: linear-gradient(180deg, #6b7280, #4b5563);
    border-radius: 0 0 4px 4px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.22);
    pointer-events: none;
    z-index: -1;
}

/* Panels and personnel-door overlays fill the kapu area — override whatever
   theme.css positioning was used previously */
.ek2026-wrap .kapuContainer > .panelSelected,
.ek2026-wrap .kapuContainer > #segmentAblak,
.ek2026-wrap .kapuContainer > #segmentAblakOnDoors,
.ek2026-wrap .kapuContainer > #szemelybejaro,
.ek2026-wrap .kapuContainer > .slideElement {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

/* responsive: on small screens shrink with the column */
@media (max-width: 767px) {
    .ek2026-wrap .kapuContainer {
        max-width: 100% !important;
    }
}

/* fromAjanlat restore paints .ablakKeret on every .panelSelected (step 2..5) —
   suppress the visual everywhere except the window/door step containers */
.panelSelected:not(#segmentAblak):not(#segmentAblakOnDoors) .palceholderWindow,
.panelSelected:not(#segmentAblak):not(#segmentAblakOnDoors) .ablakKeret {
    display: none !important;
    background-image: none !important;
    box-shadow: none !important;
    border: 0 !important;
}

/* placed window — see-through slice with thick frame
   (the actual image / size / position / border / color are set inline
    by v2026.js so each cell can show the correct slice of the scene). */
.ek2026-wrap .ablakKeret {
    cursor: pointer;
    transition: filter .15s ease;
    background-clip: padding-box;
    /* dark outer separator so adjacent windows don't visually merge */
    outline: 1px solid rgba(0, 0, 0, 0.45);
    outline-offset: -1px;
    border-radius: 2px;
}
.ek2026-wrap .ablakKeret:hover {
    filter: brightness(1.05);
}

/* hide the pre-section empty <h1> spacer block on big screens — it's just whitespace */
.ek2026-wrap .bg-white > .col-xs-3,
.ek2026-wrap .bg-white > .col-xs-9 { display: none; }

/* ---------- Mobile column stack improvements ---------- */
@media (max-width: 991px) {
    .ek2026-wrap .col-sm-12,
    .ek2026-wrap .col-xs-12 {
        margin-bottom: 18px;
    }
    .ek2026-wrap .col-sm-12:last-child,
    .ek2026-wrap .col-xs-12:last-child { margin-bottom: 0; }
}

/* ---------- Step 7 — contact form (structured) ---------- */
.ek2026-wrap #collapseSeven .panel-body { padding: 28px 22px; text-align: center; }

.ek2026-wrap .ek2026-form-intro {
    color: #6b7280;
    font-size: 14px;
    margin: 0 auto 12px;
    max-width: 720px;
}

.ek2026-wrap .ek2026-discount-banner {
    display: inline-block;
    background: var(--ek-main, #f58024);
    color: #ffffff;
    padding: 10px 20px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 500;
    margin: 0 auto 24px;
    box-shadow: 0 4px 14px rgba(var(--ek-main-rgb, 245,128,36), 0.28);
}
.ek2026-wrap .ek2026-discount-banner b { font-weight: 700; }

.ek2026-wrap .ek2026-form {
    max-width: 720px;
    text-align: left;
    display: grid;
    grid-template-columns: 1fr;
    column-gap: 16px;
    row-gap: 14px;
}

.ek2026-wrap #myform.ek2026-form {
    margin: 0 auto;
}

/* Step 1 (méretek) form lives inside a narrow col-lg-4 — keep single column
   on every breakpoint, never wider than the surrounding help panel/button */
.ek2026-wrap .ek2026-form-step1 {
    grid-template-columns: minmax(0, 1fr) !important;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    /* match the help panel / button alignment — left edge of col, not centered */
    margin: 0 0 14px 0 !important;
}
.ek2026-wrap .ek2026-form-step1 .ek2026-field {
    min-width: 0;
    box-sizing: border-box;
}
.ek2026-wrap .ek2026-form-step1 .ek2026-field-full {
    grid-column: 1 / -1;
}
.ek2026-wrap .ek2026-form-step1 .form-control {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}
/* hidden wrapper around C/D/E (felmero mode) — pass-through grid context */
.ek2026-wrap .ek2026-form-step1 > div[style*="display:none"],
.ek2026-wrap .ek2026-form-step1 > div:not([class]) {
    display: contents;
}

@media (min-width: 768px) {
    .ek2026-wrap .ek2026-form {
        grid-template-columns: 1fr 1fr;
    }
    .ek2026-wrap .ek2026-field-full { grid-column: 1 / -1; }
    .ek2026-wrap .ek2026-field-half { grid-column: span 1; }
}

.ek2026-wrap .ek2026-field { margin: 0; }
.ek2026-wrap .ek2026-field > label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 6px;
}
.ek2026-wrap .ek2026-field > .form-control {
    width: 100%;
    margin: 0;
}
.ek2026-wrap .ek2026-field > textarea.form-control {
    height: auto;
    min-height: 100px;
}

/* priority pill row */
.ek2026-wrap .ek2026-prio-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.ek2026-wrap .ek2026-prio-row .toggleButton {
    flex: 1 1 auto;
    text-align: center;
    padding: 12px 18px;
    border: 1.5px solid #e5e7eb;
    border-radius: 10px;
    background: #ffffff;
    font-size: 14px;
    font-weight: 600;
    color: #374151;
    cursor: pointer;
    transition: all .15s ease;
}
.ek2026-wrap .ek2026-prio-row .toggleButton:hover {
    border-color: #9ca3af;
    background: #f9fafb;
}
.ek2026-wrap .ek2026-prio-row .toggleButton.toggleButtonActive {
    border-color: var(--ek-main, #f58024) !important;
    background: var(--ek-main, #f58024) !important;
    color: var(--ek-second, #fff) !important;
    box-shadow: 0 2px 8px rgba(var(--ek-main-rgb, 245,128,36), 0.3);
}

/* file inputs grid */
.ek2026-wrap .ek2026-files {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
}
@media (min-width: 768px) {
    .ek2026-wrap .ek2026-files {
        grid-template-columns: 1fr 1fr;
    }
}
.ek2026-wrap .ek2026-files input[type="file"] {
    margin: 0;
    height: auto;
    padding: 10px 12px;
    background: #f9fafb;
    cursor: pointer;
}

/* submit row */
.ek2026-wrap .ek2026-submit-row { margin-top: 12px; text-align: center; }
.ek2026-wrap .ek2026-submit-row .iconarrow {
    margin: 0 0 10px !important;
    text-align: center;
}
.ek2026-wrap .ek2026-submit-btn {
    background: linear-gradient(180deg, #90f542, #6cd420) !important;
    color: #1f3b00 !important;
    border: 0 !important;
    border-radius: 12px !important;
    padding: 16px 40px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.12) !important;
    transition: transform .12s ease, box-shadow .15s ease;
}
.ek2026-wrap .ek2026-submit-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.18) !important;
}
.ek2026-wrap .ek2026-submit-comment {
    font-size: 13px;
    color: #6b7280;
    margin: 0;
}

/* ---------- Print friendliness ---------- */
@media print {
    .ek2026-stepper, #sumAr { display: none !important; }
    .ek2026-wrap .panel-default { box-shadow: none; border-color: #ccc; }
}
