/* ============================================================
   Masér – Kalkulačka sazby  |  kalkulator.css
   ============================================================ */

:root {
    --mk-green:   #2c7a4b;
    --mk-green-l: #e8f5ee;
    --mk-gold:    #c07b10;
    --mk-gold-l:  #fff8e6;
    --mk-red:     #c0392b;
    --mk-bg:      #f7f9f8;
    --mk-border:  #dce8e2;
    --mk-text:    #222;
    --mk-muted:   #666;
    --mk-radius:  10px;
    --mk-shadow:  0 2px 12px rgba(44,122,75,.10);
}

/* ---- Wrap ---- */
.mkalk-wrap {
    max-width: 720px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--mk-text);
}

/* ---- Progress bar ---- */
.mkalk-progress-outer {
    height: 6px;
    background: var(--mk-border);
    border-radius: 3px;
    margin-bottom: 6px;
    overflow: hidden;
}
.mkalk-progress-bar {
    height: 100%;
    background: var(--mk-green);
    transition: width .4s ease;
}

/* ---- Step nav labels ---- */
.mkalk-steps-nav {
    display: flex;
    gap: 4px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}
.mkalk-snav {
    font-size: 12px;
    color: var(--mk-muted);
    padding: 3px 8px;
    border-radius: 20px;
    cursor: default;
}
.mkalk-snav.active {
    background: var(--mk-green-l);
    color: var(--mk-green);
    font-weight: 700;
}

/* ---- Step titles ---- */
.mkalk-step-title {
    font-size: 22px;
    font-weight: 800;
    margin: 0 0 6px;
    color: var(--mk-green);
}
.mkalk-step-desc {
    color: var(--mk-muted);
    margin: 0 0 24px;
    font-size: 14px;
    line-height: 1.5;
}

/* ---- Fields ---- */
.mkalk-field {
    margin-bottom: 20px;
}
.mkalk-field--mt {
    margin-top: 28px;
}
.mkalk-field label {
    display: block;
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 6px;
}
.mkalk-field input[type="text"],
.mkalk-field input[type="email"],
.mkalk-field input[type="number"] {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    font-size: 15px;
    box-sizing: border-box;
    transition: border-color .2s;
}
.mkalk-field input:focus {
    outline: none;
    border-color: var(--mk-green);
    box-shadow: 0 0 0 3px rgba(44,122,75,.12);
}
.mkalk-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.mkalk-input-wrap input {
    flex: 1;
    padding-right: 70px !important;
}
.mkalk-unit {
    position: absolute;
    right: 12px;
    font-size: 12px;
    color: var(--mk-muted);
    white-space: nowrap;
}
.mkalk-hint {
    display: block;
    font-size: 12px;
    color: var(--mk-muted);
    margin-top: 5px;
    line-height: 1.4;
}

/* ---- Radio cards ---- */
.mkalk-radio-group {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.mkalk-radio-card {
    flex: 1;
    min-width: 140px;
    cursor: pointer;
}
.mkalk-radio-card input[type="radio"] {
    display: none;
}
.mkalk-radio-inner {
    display: block;
    border: 2px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 10px 14px;
    transition: border-color .2s, background .2s;
}
.mkalk-radio-inner strong {
    display: block;
    font-size: 13px;
}
.mkalk-radio-inner small {
    display: block;
    font-size: 11px;
    color: var(--mk-muted);
    margin-top: 2px;
}
.mkalk-radio-card input:checked + .mkalk-radio-inner {
    border-color: var(--mk-green);
    background: var(--mk-green-l);
}
.mkalk-radio-group--sm .mkalk-radio-card {
    min-width: 100px;
}

/* ---- Sliders ---- */
.mkalk-slider-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
}
.mkalk-slider-wrap input[type="range"] {
    flex: 1;
    accent-color: var(--mk-green);
    height: 4px;
    cursor: pointer;
}
.mkalk-slider-out {
    min-width: 60px;
    text-align: right;
    font-weight: 700;
    font-size: 15px;
    color: var(--mk-green);
}

/* ---- Cost list (fixní/variabilní položky) ---- */
.mkalk-cost-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 10px;
}
.mkalk-cost-row {
    display: flex;
    align-items: center;
    gap: 8px;
}
.mkalk-cost-row input[type="text"] {
    flex: 2;
    padding: 8px 12px;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}
.mkalk-cost-row input[type="number"] {
    flex: 1;
    padding: 8px 12px;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    text-align: right;
}
.mkalk-cost-row input:focus {
    outline: none;
    border-color: var(--mk-green);
}
.mkalk-cost-row .mkalk-remove {
    background: none;
    border: none;
    color: #c00;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 4px 6px;
    border-radius: 4px;
    flex-shrink: 0;
}
.mkalk-cost-row .mkalk-remove:hover { background: #fde; }

.mkalk-total-bar {
    background: var(--mk-green-l);
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    padding: 10px 16px;
    font-size: 14px;
    margin: 10px 0 4px;
}
.mkalk-total-bar strong {
    color: var(--mk-green);
    font-size: 16px;
}

/* ---- Live preview ---- */
.mkalk-preview {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 14px 18px;
    margin: 18px 0;
}
.mkalk-preview-row {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    padding: 4px 0;
    border-bottom: 1px solid var(--mk-border);
}
.mkalk-preview-row:last-child { border-bottom: none; }
.mkalk-preview-row--highlight strong {
    color: var(--mk-green);
    font-size: 16px;
}

/* ---- Divider ---- */
.mkalk-divider {
    border-top: 1.5px solid var(--mk-border);
    margin: 24px 0;
}

/* ---- Nav buttons ---- */
.mkalk-nav {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 28px;
}
.mkalk-btn {
    padding: 11px 24px;
    border: none;
    border-radius: var(--mk-radius);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: opacity .2s, transform .15s;
}
.mkalk-btn:hover { opacity: .88; }
.mkalk-btn:active { transform: scale(.97); }

.mkalk-btn--next,
.mkalk-btn--submit {
    background: var(--mk-green);
    color: #fff;
}
.mkalk-btn--back {
    background: var(--mk-border);
    color: var(--mk-text);
}
.mkalk-btn--add {
    background: none;
    border: 1.5px dashed var(--mk-green);
    color: var(--mk-green);
    font-size: 13px;
    padding: 7px 14px;
}
.mkalk-btn--reset {
    background: var(--mk-border);
    color: var(--mk-text);
    margin-top: 20px;
}

/* ---- Checkbox / GDPR ---- */
.mkalk-checkbox-label {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    font-size: 13px;
    line-height: 1.5;
    cursor: pointer;
}
.mkalk-checkbox-label input { flex-shrink: 0; margin-top: 2px; }
.mkalk-checkbox-label a { color: var(--mk-green); }

/* ---- Error ---- */
.mkalk-error {
    background: #fde;
    border: 1.5px solid #c00;
    border-radius: 8px;
    padding: 10px 14px;
    color: var(--mk-red);
    font-size: 14px;
    margin-bottom: 12px;
}

/* ============================================================
   VÝSLEDKOVÁ OBRAZOVKA
   ============================================================ */
.mkalk-result-hero {
    text-align: center;
    padding: 20px 0 10px;
}
.mkalk-checkmark {
    width: 56px;
    height: 56px;
    background: var(--mk-green);
    color: #fff;
    font-size: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
}
.mkalk-result-hero h2 {
    margin: 0;
    font-size: 22px;
    color: var(--mk-green);
}

/* Result cards */
.mkalk-result-cards {
    display: flex;
    gap: 14px;
    margin: 22px 0;
    flex-wrap: wrap;
}
.mkalk-card {
    flex: 1;
    min-width: 180px;
    border-radius: var(--mk-radius);
    padding: 20px;
    text-align: center;
}
.mkalk-card--green {
    background: var(--mk-green-l);
    border: 2px solid var(--mk-green);
}
.mkalk-card--gold {
    background: var(--mk-gold-l);
    border: 2px solid var(--mk-gold);
}
.mkalk-card-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
    color: var(--mk-muted);
    margin: 0 0 6px;
}
.mkalk-card-value {
    font-size: 38px;
    font-weight: 900;
    margin: 0;
    line-height: 1;
    color: var(--mk-green);
}
.mkalk-card--gold .mkalk-card-value { color: var(--mk-gold); }
.mkalk-card-sub {
    font-size: 12px;
    color: var(--mk-muted);
    margin: 6px 0 0;
}

/* Bod zvratu vizualizace */
.mkalk-bz-section {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin: 0 0 20px;
}
.mkalk-bz-section h3 { margin: 0 0 14px; font-size: 16px; }
.mkalk-bz-bar-wrap { margin-bottom: 12px; }
.mkalk-bz-bar {
    height: 22px;
    background: #eee;
    border-radius: 11px;
    overflow: hidden;
    display: flex;
}
.mkalk-bz-fill {
    height: 100%;
    transition: width .6s ease;
}
.mkalk-bz-fill--fn   { background: #e07b3b; }
.mkalk-bz-fill--mzda { background: var(--mk-green); }
.mkalk-bz-fill--zisk { background: #a0c8b0; }

.mkalk-bz-legend {
    font-size: 12px;
    color: var(--mk-muted);
    margin-top: 8px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}
.mkalk-bz-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    vertical-align: middle;
}
.mkalk-bz-dot--fn   { background: #e07b3b; }
.mkalk-bz-dot--mzda { background: var(--mk-green); }
.mkalk-bz-dot--zisk { background: #a0c8b0; }

.mkalk-bz-labels {
    font-size: 13px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Detail rozpis */
.mkalk-result-detail {
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 16px 20px;
    margin-bottom: 20px;
}
.mkalk-result-detail h3 { margin: 0 0 14px; font-size: 16px; }
.mkalk-detail-row {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    padding: 6px 0;
    border-bottom: 1px solid var(--mk-border);
}
.mkalk-detail-row:last-child { border-bottom: none; }
.mkalk-detail-row strong { color: var(--mk-green); }

/* Positioning tip */
.mkalk-positioning-tip {
    background: #fffbf0;
    border-left: 4px solid var(--mk-gold);
    border-radius: 0 var(--mk-radius) var(--mk-radius) 0;
    padding: 16px 20px;
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.6;
}
.mkalk-positioning-tip h3 { margin: 0 0 10px; font-size: 15px; }
.mkalk-positioning-tip p { margin: 0 0 8px; }
.mkalk-positioning-tip p:last-child { margin-bottom: 0; }

/* Disclaimer */
.mkalk-disclaimer {
    font-size: 12px;
    color: var(--mk-muted);
    background: #fffde7;
    border: 1px solid #ffe082;
    border-radius: 6px;
    padding: 10px 14px;
    margin-bottom: 16px;
}

/* ---- Responsive ---- */
@media (max-width: 520px) {
    .mkalk-result-cards { flex-direction: column; }
    .mkalk-radio-group  { flex-direction: column; }
    .mkalk-cost-row input[type="text"] { font-size: 13px; }
    .mkalk-card-value { font-size: 30px; }
}

/* ============================================================
   v1.1 – Diagnostika, cenové hladiny, tržní srovnání, lead magnet
   ============================================================ */

/* ---- Sekce titulky ---- */
.mkalk-section-title {
    font-size: 16px;
    font-weight: 800;
    color: var(--mk-green);
    margin: 0 0 14px;
}

/* ---- Diagnostika zdraví praxe ---- */
.mkalk-diagnostika {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 20px 24px;
    margin-bottom: 20px;
}
.mkalk-diag-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 12px;
}
.mkalk-diag-title {
    font-size: 18px;
    font-weight: 800;
    margin: 0 0 4px;
    color: var(--mk-text);
}
.mkalk-diag-subtitle {
    font-size: 13px;
    color: var(--mk-muted);
    margin: 0;
}
.mkalk-diag-score-wrap {
    display: flex;
    align-items: baseline;
    gap: 2px;
    flex-shrink: 0;
}
.mkalk-diag-score {
    font-size: 42px;
    font-weight: 900;
    color: var(--mk-green);
    line-height: 1;
}
.mkalk-diag-score-wrap.score--low .mkalk-diag-score { color: var(--mk-red); }
.mkalk-diag-score-wrap.score--mid .mkalk-diag-score { color: var(--mk-gold); }
.mkalk-diag-score-label { font-size: 14px; color: var(--mk-muted); }
.mkalk-diag-bar-outer {
    height: 8px;
    background: #e0e0e0;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 16px;
}
.mkalk-diag-bar-inner {
    height: 100%;
    background: var(--mk-green);
    border-radius: 4px;
    transition: width .8s ease;
}
.mkalk-diag-body {
    display: flex;
    gap: 20px;
}
.mkalk-diag-col { flex: 1; }
.mkalk-diag-col-title {
    font-size: 13px;
    font-weight: 700;
    margin: 0 0 8px;
}
.mkalk-diag-col ul {
    margin: 0;
    padding: 0 0 0 16px;
    font-size: 13px;
    line-height: 1.7;
    color: var(--mk-text);
}

/* ---- 3 cenové hladiny ---- */
.mkalk-ceny-wrap { margin-bottom: 20px; }
.mkalk-ceny-grid {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.mkalk-cena-card {
    flex: 1;
    min-width: 160px;
    border: 2px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 16px;
    text-align: center;
    position: relative;
}
.mkalk-cena--dop {
    border-color: var(--mk-green);
    background: var(--mk-green-l);
}
.mkalk-cena--prem {
    border-color: #9c6fd6;
    background: #f5f0ff;
}
.mkalk-cena-badge {
    position: absolute;
    top: -11px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--mk-green);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 10px;
    border-radius: 20px;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.mkalk-cena-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--mk-muted);
    font-weight: 700;
    margin: 0 0 6px;
}
.mkalk-cena--dop .mkalk-cena-label { display: none; }
.mkalk-cena-value {
    font-size: 34px;
    font-weight: 900;
    color: var(--mk-text);
    margin: 0;
    line-height: 1;
}
.mkalk-cena--dop .mkalk-cena-value { color: var(--mk-green); }
.mkalk-cena--prem .mkalk-cena-value { color: #7c4dcc; }
.mkalk-cena-unit {
    font-size: 12px;
    color: var(--mk-muted);
    margin: 4px 0 8px;
}
.mkalk-cena-desc {
    font-size: 12px;
    color: var(--mk-muted);
    line-height: 1.4;
    margin: 0;
}

/* ---- Tržní srovnání ---- */
.mkalk-trh-wrap {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin-bottom: 20px;
}
.mkalk-trh-grid {
    display: flex;
    gap: 0;
    margin-bottom: 12px;
}
.mkalk-trh-item {
    flex: 1;
    text-align: center;
    padding: 0 8px;
    border-right: 1px solid var(--mk-border);
}
.mkalk-trh-item:last-child { border-right: none; }
.mkalk-trh-label { font-size: 11px; color: var(--mk-muted); margin: 0 0 4px; }
.mkalk-trh-value {
    font-size: 22px;
    font-weight: 900;
    color: var(--mk-text);
    margin: 0;
}
.mkalk-trh-value--vas { color: var(--mk-green); }
.mkalk-trh-note { font-size: 12px; color: var(--mk-muted); margin: 0; font-style: italic; }

/* ---- Bod zvratu stats ---- */
.mkalk-bz-stats {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 12px;
    font-size: 13px;
}
.mkalk-bz-stat {
    display: flex;
    align-items: center;
    gap: 6px;
}
.mkalk-bz-stat strong { color: var(--mk-green); font-size: 15px; }

/* ---- Lead magnet ---- */
.mkalk-leadmagnet {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    border-radius: var(--mk-radius);
    padding: 24px;
    margin-bottom: 20px;
    color: #fff;
}
.mkalk-lm-header h3 {
    margin: 0 0 6px;
    font-size: 18px;
    color: #fff;
}
.mkalk-lm-header p {
    margin: 0 0 14px;
    font-size: 13px;
    color: rgba(255,255,255,.8);
    line-height: 1.5;
}
.mkalk-lm-benefits {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 18px;
}
.mkalk-lm-benefits span {
    background: rgba(255,255,255,.15);
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 12px;
    color: #fff;
}
.mkalk-lm-form {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.mkalk-lm-form input[type="email"] {
    padding: 11px 14px;
    border: none;
    border-radius: 8px;
    font-size: 15px;
    width: 100%;
    box-sizing: border-box;
}
.mkalk-lm-gdpr { color: rgba(255,255,255,.85) !important; font-size: 12px !important; }
.mkalk-lm-gdpr a { color: #fff; }
.mkalk-leadmagnet .mkalk-btn--submit {
    background: #fff;
    color: var(--mk-green);
    font-size: 15px;
    align-self: flex-start;
}
.mkalk-leadmagnet .mkalk-error {
    background: rgba(255,255,255,.15);
    border-color: rgba(255,255,255,.4);
    color: #fff;
}
.mkalk-lm-sent {
    display: flex;
    align-items: center;
    gap: 12px;
}
.mkalk-lm-sent p { margin: 0; color: #fff; }
.mkalk-checkmark--sm {
    width: 36px;
    height: 36px;
    font-size: 18px;
    flex-shrink: 0;
}

@media (max-width: 520px) {
    .mkalk-ceny-grid    { flex-direction: column; }
    .mkalk-trh-grid     { flex-direction: column; }
    .mkalk-trh-item     { border-right: none; border-bottom: 1px solid var(--mk-border); padding: 8px 0; }
    .mkalk-trh-item:last-child { border-bottom: none; }
    .mkalk-diag-body    { flex-direction: column; }
    .mkalk-lm-benefits  { flex-direction: column; }
}

/* ============================================================
   v1.2 – Interpretace, segment, simulace
   ============================================================ */

/* ---- Interpretace výsledku ---- */
.mkalk-interpretace {
    background: #f0faf4;
    border: 1.5px solid var(--mk-border);
    border-left: 4px solid var(--mk-green);
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin-bottom: 20px;
}
.mkalk-interpretace-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--mk-border);
    font-size: 14px;
    line-height: 1.5;
}
.mkalk-interpretace-item:last-child { border-bottom: none; }
.mkalk-interp-icon { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.mkalk-interp-text strong { display: block; margin-bottom: 2px; }

/* ---- Segment praxe ---- */
.mkalk-segment {
    display: flex;
    align-items: center;
    gap: 16px;
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 16px 20px;
    margin-bottom: 20px;
}
.mkalk-segment-badge {
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 800;
    padding: 6px 14px;
    border-radius: 20px;
    white-space: nowrap;
    text-align: center;
}
.seg--zacatecnik  { background: #e3f2fd; color: #1565c0; }
.seg--podhodnocen { background: #fff3e0; color: #e65100; }
.seg--stabilni    { background: var(--mk-green-l); color: var(--mk-green); }
.seg--premium     { background: #f5f0ff; color: #6a1b9a; }

.mkalk-segment-title {
    font-weight: 700;
    font-size: 15px;
    margin: 0 0 4px;
}
.mkalk-segment-desc {
    font-size: 13px;
    color: var(--mk-muted);
    margin: 0;
    line-height: 1.4;
}

/* ---- Simulace cen ---- */
.mkalk-simulace {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin-bottom: 20px;
}
.mkalk-sim-table-wrap { overflow-x: auto; }
.mkalk-sim-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.mkalk-sim-table th {
    text-align: left;
    padding: 8px 12px;
    background: var(--mk-border);
    font-size: 12px;
    color: var(--mk-muted);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.mkalk-sim-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--mk-border);
}
.mkalk-sim-table tr:last-child td { border-bottom: none; }
.mkalk-sim-table tr.sim-row--highlight td {
    background: var(--mk-green-l);
    font-weight: 700;
}
.mkalk-sim-table tr.sim-row--highlight td:first-child {
    border-left: 3px solid var(--mk-green);
}
.mkalk-sim-positive { color: var(--mk-green); font-weight: 700; }
.mkalk-sim-negative { color: var(--mk-red); }
.mkalk-sim-zero     { color: var(--mk-muted); }

/* ---- Tržní srovnání s interpretací ---- */
.mkalk-trh-interpretace {
    margin-top: 10px;
    padding: 10px 14px;
    background: var(--mk-gold-l);
    border-left: 3px solid var(--mk-gold);
    border-radius: 0 6px 6px 0;
    font-size: 13px;
    line-height: 1.5;
    color: #555;
}

/* ============================================================
   v1.3 – Faktory skóre, doporučení segmentu, roční dopad
   ============================================================ */

/* Faktory skóre */
.mkalk-diag-faktory {
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--mk-border);
}
.mkalk-diag-faktory-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    margin: 0 0 8px;
}
.mkalk-faktor-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    padding: 3px 0;
}
.mkalk-faktor-icon { flex-shrink: 0; font-size: 14px; }
.mkalk-faktor-text { flex: 1; }
.mkalk-faktor-body {
    font-weight: 700;
    font-size: 13px;
    min-width: 36px;
    text-align: right;
}
.mkalk-faktor--plus .mkalk-faktor-body { color: var(--mk-green); }
.mkalk-faktor--minus .mkalk-faktor-body { color: var(--mk-red); }

/* Doporučený další krok */
.mkalk-segment-doporuceni {
    background: #fff;
    border: 1.5px solid var(--mk-border);
    border-top: 3px solid var(--mk-green);
    border-radius: 0 0 var(--mk-radius) var(--mk-radius);
    padding: 14px 20px;
    margin-top: -6px;
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.5;
}
.mkalk-dopor-title {
    font-weight: 700;
    margin: 0 0 6px;
    color: var(--mk-text);
}
.mkalk-dopor-body {
    margin: 0;
    color: var(--mk-muted);
}

/* Roční dopad navýšení */
.mkalk-sim-dopad {
    margin: 14px 0 0;
    padding: 12px 16px;
    background: var(--mk-green-l);
    border-left: 4px solid var(--mk-green);
    border-radius: 0 6px 6px 0;
    font-size: 14px;
    line-height: 1.5;
}

/* ============================================================
   v1.4 – Typy masáží grid (s cenou v řádku)
   ============================================================ */
.mkalk-massages-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 8px;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    overflow: hidden;
}

/* Hlavička */
.mkalk-massage-header {
    display: flex;
    align-items: center;
    background: var(--mk-border);
    padding: 6px 12px;
    gap: 8px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
}
.mkalk-mh-label  { flex: 0 0 130px; }
.mkalk-mh-pocet  { flex: 0 0 80px; text-align: right; }
.mkalk-mh-delka  { flex: 0 0 72px; text-align: right; margin-left: 20px; }
.mkalk-mh-cena   { flex: 1; text-align: right; }

/* Řádky */
.mkalk-massage-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--mk-border);
    background: #fff;
}
.mkalk-massage-row:last-child { border-bottom: none; }
.mkalk-massage-row:nth-child(even) { background: #fafafa; }

.mkalk-massage-row label {
    flex: 0 0 130px;
    font-weight: 600;
    font-size: 13px;
    margin: 0;
    line-height: 1.3;
}
.mkalk-massage-row label small {
    display: block;
    font-weight: 400;
    color: var(--mk-muted);
    font-size: 11px;
}
.mkalk-massage-inputs {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
}
/* Šířky jednotlivých políček */
.mkalk-iw--pocet { flex: 0 0 96px; }
.mkalk-iw--delka { flex: 0 0 88px; }
.mkalk-iw--cena  { flex: 0 0 104px; margin-left: auto; }

.mkalk-massage-inputs input[type="number"] {
    width: 100%;
    padding: 9px 30px 9px 8px !important;
    border: 1.5px solid var(--mk-border);
    border-radius: 6px;
    font-size: 14px;
    text-align: right;
    box-sizing: border-box;
}
.mkalk-iw--cena input { border-color: #b8d4c8; background: #f0faf4; }
.mkalk-iw--cena input:focus { border-color: var(--mk-green); outline: none; }
.mkalk-massage-inputs input:focus {
    outline: none;
    border-color: var(--mk-green);
}
.mkalk-massage-x {
    font-size: 14px;
    color: var(--mk-muted);
    flex-shrink: 0;
}
.mkalk-massage-fixed {
    flex: 0 0 72px;
    font-size: 13px;
    color: var(--mk-muted);
    text-align: right;
    padding-right: 4px;
}
.mkalk-massage-summary {
    background: var(--mk-green-l);
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    padding: 10px 16px;
    font-size: 14px;
    margin: 8px 0 20px;
}
.mkalk-massage-summary strong { color: var(--mk-green); }

@media (max-width: 580px) {
    .mkalk-massage-header { display: none; }
    .mkalk-massage-row    { flex-wrap: wrap; padding: 12px; gap: 6px; }
    .mkalk-massage-row label { flex: 0 0 100%; margin-bottom: 4px; }
    .mkalk-massage-inputs { flex-wrap: wrap; }
    .mkalk-iw--pocet,
    .mkalk-iw--delka,
    .mkalk-iw--cena  { flex: 0 0 80px; margin-left: 0; }
}

/* ============================================================
   v1.5 – Současná cena, přehled nákladů, srovnání
   ============================================================ */

/* Pill výběr sazby */
.mkalk-sazba-choices {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 4px;
}
.mkalk-sazba-pill {
    cursor: pointer;
}
.mkalk-sazba-pill input[type="radio"] { display: none; }
.mkalk-sazba-pill span,
.mkalk-sazba-pill {
    display: inline-block;
    padding: 7px 16px;
    border: 2px solid var(--mk-border);
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    color: var(--mk-text);
    transition: border-color .2s, background .2s;
    user-select: none;
}
.mkalk-sazba-pill input:checked + span,
.mkalk-sazba-pill:has(input:checked) {
    border-color: var(--mk-green);
    background: var(--mk-green-l);
    color: var(--mk-green);
}
.mkalk-sazba-pill--vlastni {
    border-style: dashed;
}

/* Přehled nákladů */
.mkalk-prehled-nakladu {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin-bottom: 20px;
}
.mkalk-prehled-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--mk-border);
    font-size: 14px;
}
.mkalk-prehled-row:last-child { border-bottom: none; }
.mkalk-prehled-row--total {
    font-weight: 800;
    font-size: 15px;
    border-top: 2px solid var(--mk-border);
    margin-top: 4px;
    padding-top: 10px;
}
.mkalk-prehled-row--total strong { color: var(--mk-green); }
.mkalk-prehled-note {
    margin: 12px 0 0;
    font-size: 13px;
    color: var(--mk-muted);
    font-style: italic;
    line-height: 1.5;
}

/* Srovnání současné vs. doporučené */
.mkalk-srovnani {
    background: #fff;
    border: 2px solid var(--mk-green);
    border-radius: var(--mk-radius);
    padding: 20px;
    margin-bottom: 20px;
}
.mkalk-srovnani-grid {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.mkalk-srov-item {
    flex: 1;
    min-width: 100px;
    text-align: center;
    padding: 12px 8px;
    background: var(--mk-bg);
    border-radius: 8px;
}
.mkalk-srov-item--rozdil {
    background: var(--mk-green-l);
}
.mkalk-srov-arrow {
    font-size: 22px;
    color: var(--mk-muted);
    flex-shrink: 0;
}
.mkalk-srov-label {
    font-size: 11px;
    color: var(--mk-muted);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin: 0 0 4px;
    font-weight: 700;
}
.mkalk-srov-value {
    font-size: 28px;
    font-weight: 900;
    margin: 0;
    line-height: 1;
}
.mkalk-srov-value--current { color: var(--mk-muted); }
.mkalk-srov-value--dop     { color: var(--mk-green); }
.mkalk-srov-sub { font-size: 12px; color: var(--mk-muted); margin: 4px 0 0; }

/* Killer věta */
.mkalk-killer-veta {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    color: #fff;
    border-radius: 8px;
    padding: 14px 18px;
    font-size: 15px;
    line-height: 1.6;
    font-weight: 600;
}
.mkalk-killer-veta strong { color: #ffd54f; }

@media (max-width: 520px) {
    .mkalk-srovnani-grid { flex-direction: column; }
    .mkalk-srov-arrow    { transform: rotate(90deg); }
}

/* Variabilní náklady – detail blok */
.mkalk-var-detail {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1.5px dashed var(--mk-border);
}
.mkalk-var-detail-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    margin: 0 0 8px;
}
.mkalk-var-detail-row {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    padding: 4px 0;
    border-bottom: 1px solid var(--mk-border);
}
.mkalk-var-detail-row:last-child { border-bottom: none; }
.mkalk-var-detail-row--accent strong { color: var(--mk-green); font-size: 14px; }

/* ============================================================
   v2.0 – Nová struktura výsledků
   ============================================================ */

/* Bloky */
.mkalk-blok {
    background: #fff;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 20px 24px;
    margin-bottom: 16px;
}
.mkalk-blok-title {
    font-size: 17px;
    font-weight: 800;
    color: var(--mk-text);
    margin: 0 0 14px;
}
.mkalk-blok-desc {
    font-size: 13px;
    color: var(--mk-muted);
    margin: -8px 0 16px;
    line-height: 1.5;
}

/* Blok 1 – Situace */
.mkalk-blok--situace { border-left: 4px solid var(--mk-green); }

.mkalk-situace-hero {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 14px;
}
.mkalk-sit-main { flex: 1; }
.mkalk-sit-label {
    font-size: 12px;
    color: var(--mk-muted);
    text-transform: uppercase;
    letter-spacing: .5px;
    font-weight: 700;
    margin: 0 0 4px;
}
.mkalk-sit-value {
    font-size: 42px;
    font-weight: 900;
    color: var(--mk-green);
    margin: 0;
    line-height: 1;
}
.mkalk-sit-sub {
    font-size: 12px;
    color: var(--mk-muted);
    margin: 4px 0 0;
}

/* Rozpis služeb */
.mkalk-sit-sluzby {
    background: var(--mk-bg);
    border-radius: 8px;
    padding: 10px 14px;
    margin-bottom: 14px;
    font-size: 13px;
}
.mkalk-sit-sluzba-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    border-bottom: 1px solid var(--mk-border);
    color: var(--mk-muted);
}
.mkalk-sit-sluzba-row:last-child { border-bottom: none; }
.mkalk-sit-sluzba-row strong { color: var(--mk-text); }

/* Metriky */
.mkalk-sit-metriky {
    display: flex;
    gap: 0;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    overflow: hidden;
}
.mkalk-sit-metrika {
    flex: 1;
    text-align: center;
    padding: 10px 8px;
    border-right: 1px solid var(--mk-border);
}
.mkalk-sit-metrika:last-child { border-right: none; }
.mkalk-sit-metrika--accent { background: var(--mk-green-l); }
.mkalk-sit-m-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    font-weight: 700;
    display: block;
    margin-bottom: 4px;
}
.mkalk-sit-m-val {
    font-size: 17px;
    font-weight: 800;
    color: var(--mk-text);
    display: block;
}
.mkalk-sit-metrika--accent .mkalk-sit-m-val { color: var(--mk-green); }
.mkalk-sit-no-price {
    font-size: 13px;
    color: var(--mk-muted);
    margin: 10px 0 0;
    font-style: italic;
}

/* Blok 3 – Porovnání */
.mkalk-blok--porovnani { border-left: 4px solid #e6a020; }

/* Ekonomické vyhodnocení */
.mkalk-vyhodnoceni {
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 12px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.5;
}
.mkalk-vyhodnoceni--zelene { background: #e8f5ee; color: #1b5e20; border-left: 4px solid var(--mk-green); }
.mkalk-vyhodnoceni--zlute  { background: #fff8e6; color: #7d5800; border-left: 4px solid var(--mk-gold); }
.mkalk-vyhodnoceni--cervene { background: #fde8e8; color: #7f1515; border-left: 4px solid var(--mk-red); }

/* srov arrow jako text */
.mkalk-srov-arrow {
    font-size: 14px;
    font-weight: 700;
    color: var(--mk-muted);
    flex-shrink: 0;
}

@media (max-width: 520px) {
    .mkalk-sit-metriky { flex-wrap: wrap; }
    .mkalk-sit-metrika { flex: 0 0 50%; border-bottom: 1px solid var(--mk-border); }
    .mkalk-sit-metrika:nth-child(even) { border-right: none; }
}

/* ---- Select pro okres ---- */
.mkalk-select {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    font-size: 15px;
    background: #fff;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}
.mkalk-select:focus {
    outline: none;
    border-color: var(--mk-green);
    box-shadow: 0 0 0 3px rgba(44,122,75,.12);
}

/* ============================================================
   v2.1 – Hlavní závěr (Blok 1)
   ============================================================ */
.mkalk-zaver {
    border: none !important;
    padding: 0 !important;
    overflow: hidden;
    border-radius: var(--mk-radius) !important;
}
.mkalk-zaver-indicator {
    height: 6px;
}
.mkalk-zaver--zelena .mkalk-zaver-indicator { background: var(--mk-green); }
.mkalk-zaver--zluta  .mkalk-zaver-indicator { background: var(--mk-gold); }
.mkalk-zaver--cervena .mkalk-zaver-indicator { background: var(--mk-red); }

.mkalk-zaver-body {
    padding: 20px 24px 16px;
    border: 1.5px solid var(--mk-border);
    border-top: none;
    border-radius: 0 0 var(--mk-radius) var(--mk-radius);
}
.mkalk-zaver-titulek {
    font-size: 20px;
    font-weight: 800;
    margin: 0 0 8px;
}
.mkalk-zaver--zelena .mkalk-zaver-titulek { color: var(--mk-green); }
.mkalk-zaver--zluta  .mkalk-zaver-titulek { color: #8a6000; }
.mkalk-zaver--cervena .mkalk-zaver-titulek { color: var(--mk-red); }

.mkalk-zaver-text {
    font-size: 15px;
    color: var(--mk-text);
    line-height: 1.6;
    margin: 0 0 10px;
}
.mkalk-zaver-tipy {
    margin: 8px 0 0;
    padding: 0 0 0 20px;
    font-size: 14px;
    color: var(--mk-muted);
    line-height: 1.7;
}

/* Mini srovnání v závěru */
.mkalk-zaver-srovnani {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 24px 20px;
    border: 1.5px solid var(--mk-border);
    border-top: 1px solid var(--mk-border);
    background: var(--mk-bg);
    flex-wrap: wrap;
    border-radius: 0 0 var(--mk-radius) var(--mk-radius);
    margin-top: -1px;
}
.mkalk-zsrov-item { flex: 1; min-width: 80px; text-align: center; }
.mkalk-zsrov-label { font-size: 11px; color: var(--mk-muted); text-transform: uppercase; letter-spacing: .5px; display: block; margin-bottom: 3px; font-weight: 700; }
.mkalk-zsrov-val { font-size: 22px; font-weight: 900; color: var(--mk-text); display: block; }
.mkalk-zsrov-val--dop { color: var(--mk-green); }
.mkalk-zsrov-item--rozdil .mkalk-zsrov-val { font-size: 18px; }
.mkalk-zsrov-arrow { font-size: 18px; color: var(--mk-muted); flex-shrink: 0; }

/* Bod zvratu – hlavní stat */
.mkalk-bz-stat--hlavni {
    background: var(--mk-green-l);
    border-radius: 6px;
    padding: 8px 12px;
    font-weight: 700;
}
.mkalk-bz-stat--hlavni strong { font-size: 18px; }

@media (max-width: 520px) {
    .mkalk-zaver-srovnani { flex-direction: column; }
    .mkalk-zsrov-arrow { transform: rotate(90deg); }
}

/* ============================================================
   v2.0 – Rozcestník + Režim A
   ============================================================ */

/* Rozcestník */
.mkalk-rozcestnik { padding: 8px 0 24px; }
.mkalk-rc-title {
    font-size: 24px;
    font-weight: 800;
    text-align: center;
    margin: 0 0 6px;
    color: var(--mk-text);
}
.mkalk-rc-desc {
    text-align: center;
    color: var(--mk-muted);
    margin: 0 0 24px;
    font-size: 15px;
}
.mkalk-rc-grid {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}
.mkalk-rc-card {
    flex: 1;
    min-width: 220px;
    background: #fff;
    border: 2px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 24px 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, box-shadow .2s, transform .15s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.mkalk-rc-card:hover {
    border-color: var(--mk-green);
    box-shadow: var(--mk-shadow);
    transform: translateY(-2px);
}
.mkalk-rc-icon { font-size: 36px; }
.mkalk-rc-card strong { font-size: 18px; font-weight: 800; display: block; }
.mkalk-rc-card p { font-size: 13px; color: var(--mk-muted); line-height: 1.5; margin: 0; }
.mkalk-rc-btn {
    display: inline-block;
    margin-top: 8px;
    background: var(--mk-green);
    color: #fff;
    padding: 8px 20px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 700;
}

/* Hlavičky režimů */
.mkalk-rezim-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    font-size: 14px;
    font-weight: 600;
    color: var(--mk-muted);
}
.mkalk-back-rc {
    background: none;
    border: 1.5px solid var(--mk-border);
    border-radius: 6px;
    padding: 5px 12px;
    font-size: 13px;
    cursor: pointer;
    color: var(--mk-muted);
}
.mkalk-back-rc:hover { border-color: var(--mk-green); color: var(--mk-green); }

/* Pill tlačítka */
.mkalk-pills-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.mkalk-pills-grid--sm { gap: 8px; }
.mkalk-pill {
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.mkalk-pill input[type="radio"] { display: none; }
.mkalk-pill {
    padding: 10px 20px;
    border: 2px solid var(--mk-border);
    border-radius: 24px;
    font-size: 15px;
    font-weight: 600;
    color: var(--mk-text);
    transition: border-color .15s, background .15s;
    background: #fff;
    text-align: center;
    min-width: 80px;
}
.mkalk-pill small { display: block; font-size: 11px; font-weight: 400; color: var(--mk-muted); margin-top: 2px; }
.mkalk-pill:has(input:checked) {
    border-color: var(--mk-green);
    background: var(--mk-green-l);
    color: var(--mk-green);
}
.mkalk-pill--vlastni { border-style: dashed; }

/* Výsledek režimu A */
.mkalk-a-sazba-hero {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin: 10px 0;
}
.mkalk-a-sazba-hero span {
    font-size: 52px;
    font-weight: 900;
    color: var(--mk-green);
    line-height: 1;
}
.mkalk-a-sazba-hero small { font-size: 15px; color: var(--mk-muted); }

/* Daňová doporučení */
.mkalk-dane-grid { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; }
.mkalk-dane-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    font-size: 14px;
}
.mkalk-dane-row--dop { border-color: var(--mk-green); background: var(--mk-green-l); }
.mkalk-dane-row strong { font-size: 13px; }
.mkalk-dane-badge {
    font-size: 11px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 20px;
    background: var(--mk-green);
    color: #fff;
}

@media (max-width: 520px) {
    .mkalk-rc-grid { flex-direction: column; }
    .mkalk-pills-grid { gap: 8px; }
    .mkalk-pill { font-size: 14px; padding: 8px 14px; }
}

/* ============================================================
   v2.2 – Hero blok + realismus + obsazenost sim + detail toggle
   ============================================================ */

/* Hero blok */
.mkalk-hero-blok {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    border-radius: var(--mk-radius);
    padding: 28px 28px 22px;
    margin-bottom: 16px;
    text-align: center;
    color: #fff;
}
.mkalk-hero-label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
    color: rgba(255,255,255,.75);
    margin: 0 0 8px;
}
.mkalk-hero-cena {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 8px;
    margin-bottom: 10px;
}
.mkalk-hero-cena span {
    font-size: 58px;
    font-weight: 900;
    color: #fff;
    line-height: 1;
}
.mkalk-hero-cena small { font-size: 16px; color: rgba(255,255,255,.75); }
.mkalk-hero-cil {
    display: inline-block;
    background: rgba(255,255,255,.15);
    border-radius: 6px;
    padding: 6px 14px;
    font-size: 14px;
    color: #fff;
    margin-bottom: 14px;
}
.mkalk-hero-parametry {
    font-size: 12px;
    color: rgba(255,255,255,.65);
    line-height: 1.8;
}

/* Realismus blok */
.mkalk-blok--realismus { padding-bottom: 0 !important; }
.mkalk-realismus-body {
    padding: 16px 20px 12px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.5;
}
.mkalk-realismus--zelena { border-left: 4px solid var(--mk-green); }
.mkalk-realismus--zluta  { border-left: 4px solid var(--mk-gold); }
.mkalk-realismus--cervena { border-left: 4px solid var(--mk-red); }

/* Tržní srovnání inline */
.mkalk-trh-inline {
    border-top: 1px solid var(--mk-border);
    padding: 14px 20px 16px;
    background: var(--mk-bg);
    border-radius: 0 0 var(--mk-radius) var(--mk-radius);
}
.mkalk-trh-inline-grid {
    display: flex;
    gap: 0;
    margin-bottom: 10px;
}
.mkalk-tri-item {
    flex: 1;
    text-align: center;
    padding: 8px;
    border-right: 1px solid var(--mk-border);
}
.mkalk-tri-item:last-child { border-right: none; }
.mkalk-tri-item--dop { background: var(--mk-green-l); }
.mkalk-tri-label { font-size: 11px; color: var(--mk-muted); display: block; margin-bottom: 3px; text-transform: uppercase; letter-spacing: .5px; font-weight: 700; }
.mkalk-tri-val { font-size: 20px; font-weight: 800; color: var(--mk-text); display: block; }
.mkalk-tri-val--dop { color: var(--mk-green); }
.mkalk-tri-interp { font-size: 13px; color: var(--mk-muted); margin: 0; line-height: 1.5; }

/* Obsazenost simulace */
.mkalk-blok--obsazenost .mkalk-sim-table tr.obs-row--highlight td {
    background: var(--mk-green-l);
    font-weight: 700;
}
.mkalk-blok--obsazenost .mkalk-sim-table tr.obs-row--highlight td:first-child {
    border-left: 3px solid var(--mk-green);
}

/* Detail toggle */
.mkalk-detail-toggle {
    text-align: center;
    margin: 8px 0;
}
.mkalk-detail-btn {
    background: none;
    border: 1.5px solid var(--mk-border);
    border-radius: 20px;
    padding: 8px 20px;
    font-size: 13px;
    color: var(--mk-muted);
    cursor: pointer;
    transition: border-color .2s, color .2s;
}
.mkalk-detail-btn:hover { border-color: var(--mk-green); color: var(--mk-green); }
.mkalk-detail-btn.open .mkalk-detail-btn-text::before { content: '▲ '; }

@media (max-width: 520px) {
    .mkalk-hero-cena span { font-size: 44px; }
    .mkalk-trh-inline-grid { flex-wrap: wrap; }
    .mkalk-tri-item { flex: 0 0 50%; border-bottom: 1px solid var(--mk-border); }
}

/* ============================================================
   Blok "Jak jsme k ceně došli"
   ============================================================ */
.mkalk-odvozeni {
    padding: 0 !important;
    overflow: hidden;
}
.mkalk-odvozeni-toggle {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 20px;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 15px;
    font-weight: 700;
    color: var(--mk-green);
    text-align: left;
}
.mkalk-odvozeni-toggle:hover { background: var(--mk-green-l); }
.mkalk-odvozeni-arrow { font-size: 12px; color: var(--mk-muted); }

.mkalk-odvozeni-body {
    border-top: 1px solid var(--mk-border);
    padding: 16px 20px 18px;
}
.mkalk-odvozeni-kroky {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 14px;
}
.mkalk-odv-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
    border-bottom: 1px solid var(--mk-border);
    font-size: 14px;
}
.mkalk-odv-row:last-child { border-bottom: none; }
.mkalk-odv-row--highlight {
    background: var(--mk-green-l);
    font-weight: 700;
    border-radius: 6px;
    margin-top: 4px;
    border-bottom: none;
}
.mkalk-odv-label { color: var(--mk-muted); }
.mkalk-odv-row--highlight .mkalk-odv-label { color: var(--mk-green); font-weight: 700; }
.mkalk-odv-value {
    font-weight: 700;
    color: var(--mk-text);
    white-space: nowrap;
}
.mkalk-odv-value small { font-weight: 400; color: var(--mk-muted); font-size: 12px; margin-left: 2px; }
.mkalk-odv-row--highlight .mkalk-odv-value { color: var(--mk-green); font-size: 16px; }

.mkalk-odv-vzorec {
    background: #f9f9f9;
    border-radius: 6px;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--mk-muted);
    margin: 0;
    line-height: 1.6;
    border-left: 3px solid var(--mk-green);
}
.mkalk-odv-vzorec strong { color: var(--mk-green); font-size: 15px; }

/* Podpoložky v odvozeni bloku */
.mkalk-odv-sub {
    background: #f9f9f9;
    border-left: 3px solid var(--mk-border);
    margin: 0 0 2px 12px;
    border-radius: 0 0 4px 4px;
}
.mkalk-odv-sub-row {
    display: flex;
    justify-content: space-between;
    padding: 5px 12px;
    font-size: 12px;
    color: var(--mk-muted);
    border-bottom: 1px solid #eee;
}
.mkalk-odv-sub-row:last-child { border-bottom: none; }
.mkalk-odv-sub-row span:last-child {
    font-weight: 600;
    color: var(--mk-text);
    white-space: nowrap;
}

/* ============================================================
   Daňové karty – Režim A krok 5
   ============================================================ */
.mkalk-danove-karty {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.mkalk-danove-karta {
    border: 2px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 14px 16px;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    position: relative;
}
.mkalk-danove-karta:hover { border-color: var(--mk-green); }
.mkalk-danove-karta--vybrana {
    border-color: var(--mk-green);
    background: var(--mk-green-l);
}
.mkalk-danove-karta--dop {
    border-color: var(--mk-green);
}
.mkalk-dk-badge {
    display: inline-block;
    background: var(--mk-green);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 10px;
    border-radius: 20px;
    margin-bottom: 8px;
}
.mkalk-dk-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}
.mkalk-dk-header strong { font-size: 15px; }
.mkalk-dk-odvody {
    font-size: 20px;
    font-weight: 900;
    color: var(--mk-green);
}
.mkalk-dk-odvody small { font-size: 12px; font-weight: 400; color: var(--mk-muted); margin-left: 2px; }
.mkalk-dk-popis {
    font-size: 13px;
    color: var(--mk-muted);
    margin: 0 0 4px;
}
.mkalk-dk-detail {
    font-size: 12px;
    color: #888;
    margin: 0 0 6px;
    font-style: italic;
}
.mkalk-dk-usp {
    font-size: 12px;
    color: var(--mk-red);
    margin: 0 0 6px;
    font-weight: 600;
}
.mkalk-dk-pros, .mkalk-dk-cons {
    margin: 4px 0;
    padding: 0 0 0 14px;
    font-size: 12px;
    line-height: 1.7;
}
.mkalk-dk-pros { color: #2c7a4b; }
.mkalk-dk-cons { color: #888; }

/* Co vám zůstane – blok výsledků Režim A */
.mkalk-a-zustane {
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 16px 18px;
    margin-top: 14px;
}
.mkalk-a-zustane-title {
    font-size: 16px;
    font-weight: 800;
    margin: 0 0 6px;
}
.mkalk-a-zustane-desc {
    font-size: 13px;
    color: var(--mk-muted);
    margin: 0 0 12px;
    line-height: 1.5;
}
.mkalk-a-zustane-grid {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.mkalk-a-zustane-item {
    flex: 1;
    min-width: 130px;
    background: #fff;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    position: relative;
}
.mkalk-a-zustane-item--best {
    border-color: var(--mk-green);
    background: var(--mk-green-l);
}
.mkalk-a-zustane-forma {
    font-size: 11px;
    color: var(--mk-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.mkalk-a-zustane-castka {
    font-size: 22px;
    font-weight: 900;
    line-height: 1;
}
.mkalk-a-zustane-best {
    font-size: 10px;
    font-weight: 700;
    color: var(--mk-green);
    text-transform: uppercase;
    letter-spacing: .5px;
}
.mkalk-a-zustane-cil {
    font-size: 13px;
    color: var(--mk-muted);
    margin: 0;
}
.mkalk-a-zustane-cil strong { color: var(--mk-text); }

/* ---- Kompaktní daňové karty s rozbalením ---- */
.mkalk-dk-main {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.mkalk-dk-left {
    flex: 1;
    min-width: 160px;
    font-size: 14px;
}
.mkalk-dk-popis-inline {
    font-size: 12px;
    color: var(--mk-muted);
    font-weight: 400;
}
.mkalk-dk-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    flex-shrink: 0;
}
.mkalk-dk-odvody-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    font-weight: 700;
}
.mkalk-dk-usp-inline {
    font-size: 11px;
    color: var(--mk-red);
    font-weight: 600;
}
.mkalk-dk-toggle {
    background: none;
    border: 1px solid var(--mk-border);
    border-radius: 4px;
    padding: 2px 8px;
    font-size: 11px;
    cursor: pointer;
    color: var(--mk-muted);
    flex-shrink: 0;
    transition: background .15s;
}
.mkalk-dk-toggle:hover { background: var(--mk-bg); }
.mkalk-dk-detail-panel {
    padding: 10px 0 2px;
    border-top: 1px solid var(--mk-border);
    margin-top: 8px;
}
.mkalk-dk-odvody-rozpis {
    font-size: 12px;
    color: #555;
    margin: 0 0 6px;
}

.mkalk-dk-vysvetleni {
    font-size: 12px;
    color: #555;
    background: #fffbe6;
    border-left: 3px solid var(--mk-gold);
    padding: 6px 10px;
    border-radius: 0 4px 4px 0;
    margin: 0 0 8px;
    line-height: 1.4;
}

/* ============================================================
   Režim A – nová výsledková obrazovka
   ============================================================ */

/* Hero */
.mkalk-a-hero {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    border-radius: var(--mk-radius);
    padding: 22px 24px 18px;
    margin-bottom: 12px;
    color: #fff;
}
.mkalk-a-hero-label {
    font-size: 13px;
    color: rgba(255,255,255,.75);
    margin: 0 0 6px;
    font-weight: 600;
}
.mkalk-a-hero-cena {
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.mkalk-a-hero-cena span {
    font-size: 54px;
    font-weight: 900;
    color: #fff;
    line-height: 1;
}
.mkalk-a-hero-cena small { font-size: 15px; color: rgba(255,255,255,.7); }

/* 3 metriky */
.mkalk-a-metriky {
    display: flex;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    overflow: hidden;
    margin-bottom: 12px;
}
.mkalk-a-metrika {
    flex: 1;
    padding: 12px 10px;
    text-align: center;
    border-right: 1px solid var(--mk-border);
}
.mkalk-a-metrika:last-child { border-right: none; }
.mkalk-a-metrika--accent { background: var(--mk-green-l); }
.mkalk-a-m-label {
    display: block;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    font-weight: 700;
    margin-bottom: 4px;
}
.mkalk-a-m-val {
    display: block;
    font-size: 16px;
    font-weight: 800;
    color: var(--mk-text);
}
.mkalk-a-metrika--accent .mkalk-a-m-val { color: var(--mk-green); }

/* Sbalitelné lišty */
.mkalk-a-listy {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 12px;
}
.mkalk-a-lista {
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    overflow: hidden;
    background: #fff;
}
.mkalk-a-lista-header {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-size: 14px;
    font-weight: 600;
    transition: background .15s;
}
.mkalk-a-lista-header:hover { background: var(--mk-bg); }
.mkalk-a-lista-icon { font-size: 16px; flex-shrink: 0; }
.mkalk-a-lista-nazev { flex: 1; }
.mkalk-a-lista-castka {
    font-size: 13px;
    font-weight: 700;
    color: var(--mk-green);
    white-space: nowrap;
}
.mkalk-a-lista-arrow { font-size: 11px; color: var(--mk-muted); flex-shrink: 0; }
.mkalk-a-lista-body { border-top: 1px solid var(--mk-border); }

/* Tabulka v liště */
.mkalk-a-lista-tabulka { padding: 4px 0; }
.mkalk-a-lt-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 7px 16px;
    font-size: 13px;
    gap: 8px;
}
.mkalk-a-lt-row--alt { background: #fafafa; }
.mkalk-a-lt-row--header {
    background: var(--mk-border);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: var(--mk-muted);
}
.mkalk-a-lt-row--total {
    background: var(--mk-green-l);
    font-weight: 800;
    border-top: 1px solid var(--mk-border);
}
.mkalk-a-lt-row--total strong { color: var(--mk-green); font-size: 14px; }
.mkalk-a-lt-note {
    padding: 8px 16px;
    font-size: 12px;
    color: var(--mk-muted);
    border-top: 1px solid var(--mk-border);
    margin: 0;
}

@media (max-width: 520px) {
    .mkalk-a-metriky { flex-wrap: wrap; }
    .mkalk-a-metrika { flex: 0 0 50%; border-bottom: 1px solid var(--mk-border); }
    .mkalk-a-hero-cena span { font-size: 40px; }
}

/* Tržní srovnání – Režim A */
.mkalk-a-trzni {
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 16px 18px;
    margin: 12px 0;
}
.mkalk-trzni--nad  { border-left: 4px solid var(--mk-green); }
.mkalk-trzni--okej { border-left: 4px solid var(--mk-green); }
.mkalk-trzni--pod  { border-left: 4px solid #e67e00; }

.mkalk-a-trzni-title {
    font-size: 15px;
    font-weight: 800;
    margin: 0 0 12px;
}
.mkalk-a-trzni-srov {
    display: flex;
    gap: 0;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 12px;
}
.mkalk-a-trzni-item {
    flex: 1;
    text-align: center;
    padding: 10px 8px;
    border-right: 1px solid var(--mk-border);
    font-size: 13px;
}
.mkalk-a-trzni-item:last-child { border-right: none; }
.mkalk-a-trzni-item--vas { background: var(--mk-green-l); }
.mkalk-a-trzni-item span { display: block; font-size: 11px; color: var(--mk-muted); margin-bottom: 3px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
.mkalk-a-trzni-item strong { font-size: 18px; font-weight: 900; }

.mkalk-a-trzni-hlavni {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 10px;
    line-height: 1.5;
}
.mkalk-a-trzni-tipy {
    margin: 0 0 10px;
    padding: 0 0 0 18px;
    font-size: 13px;
    color: #555;
    line-height: 1.7;
}
.mkalk-a-trzni-zdroj {
    font-size: 11px;
    color: #aaa;
    margin: 0;
}

/* ============================================================
   Ceník hero + opravy barev + subtitle
   ============================================================ */

/* Nadpisy v kroku 5 */
.mkalk-step-subtitle {
    font-size: 17px;
    font-weight: 700;
    color: var(--mk-text);
    margin: 0 0 8px;
}

/* Barvy karet rozcestníku */
.mkalk-rc-card--light strong,
.mkalk-rc-card--light p,
.mkalk-rc-card strong,
.mkalk-rc-card p { color: var(--mk-text) !important; }
.mkalk-rc-card:has(#rc-zacatecnik),
button#rc-zacatecnik strong,
button#rc-zacatecnik p { color: #fff !important; }

/* Ceník hero */
.mkalk-a-cenik-intro {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255,255,255,.85);
    margin: 0 0 14px;
}
.mkalk-a-cenik-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 12px;
    border-radius: 8px;
    overflow: hidden;
}
.mkalk-a-cenik-table th {
    background: rgba(255,255,255,.15);
    color: rgba(255,255,255,.7);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 8px 14px;
    text-align: left;
    font-weight: 700;
}
.mkalk-a-cenik-table td {
    padding: 10px 14px;
    font-size: 15px;
    color: rgba(255,255,255,.9);
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.mkalk-a-cenik-table strong { color: #fff; font-size: 18px; }
.mkalk-a-cenik-hlavni td { background: rgba(255,255,255,.12); }
.mkalk-a-cenik-hlavni strong { font-size: 22px !important; }
.mkalk-a-cenik-note {
    font-size: 12px;
    color: rgba(255,255,255,.6);
    margin: 0;
    line-height: 1.5;
}

/* Lišty – oprava barvy textu */
.mkalk-a-lista-nazev { color: var(--mk-text) !important; }
.mkalk-a-lista-castka { color: var(--mk-green) !important; font-weight: 700; }

/* Rozcestník – bílý text na zelené kartě */
button#rc-zacatecnik { background: var(--mk-green); }
button#rc-zacatecnik strong,
button#rc-zacatecnik p,
button#rc-zacatecnik .mkalk-rc-btn { color: #fff !important; }
button#rc-zacatecnik .mkalk-rc-btn { background: rgba(255,255,255,.2); }

/* ============================================================
   Ceník hero – Režim A výsledky
   ============================================================ */
.mkalk-a-cenik-hero {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    border-radius: var(--mk-radius);
    padding: 22px 22px 18px;
    margin-bottom: 12px;
    color: #fff;
}
.mkalk-a-cenik-intro {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255,255,255,.8);
    margin: 0 0 14px;
}
.mkalk-a-cenik-tbl {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 12px;
}
.mkalk-a-cenik-tbl th {
    background: rgba(255,255,255,.15);
    color: rgba(255,255,255,.7);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 7px 12px;
    text-align: left;
    font-weight: 700;
}
.mkalk-a-cenik-tbl td {
    padding: 9px 12px;
    font-size: 14px;
    color: rgba(255,255,255,.85);
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.mkalk-a-cenik-tbl strong { color: #fff; font-size: 17px; }
.mkalk-a-cenik-hlavni td { background: rgba(255,255,255,.12); }
.mkalk-a-cenik-hlavni strong { font-size: 22px !important; }
.mkalk-a-cenik-note {
    font-size: 12px;
    color: rgba(255,255,255,.6);
    margin: 0;
    line-height: 1.5;
}

/* 3 metriky */
.mkalk-a-metriky {
    display: flex;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    overflow: hidden;
    margin-bottom: 10px;
}
.mkalk-a-metrika {
    flex: 1;
    padding: 12px 10px;
    text-align: center;
    border-right: 1px solid var(--mk-border);
}
.mkalk-a-metrika:last-child { border-right: none; }
.mkalk-a-metrika--accent { background: var(--mk-green-l); }
.mkalk-a-m-label {
    display: block;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    font-weight: 700;
    margin-bottom: 4px;
}
.mkalk-a-m-val {
    display: block;
    font-size: 15px;
    font-weight: 800;
    color: var(--mk-text);
}
.mkalk-a-metrika--accent .mkalk-a-m-val { color: var(--mk-green); }

/* Sbalitelné lišty */
.mkalk-a-listy { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.mkalk-a-lista { border: 1.5px solid var(--mk-border); border-radius: var(--mk-radius); overflow: hidden; background: #fff; }
.mkalk-a-lista-header {
    width: 100%; display: flex; align-items: center; gap: 8px;
    padding: 12px 16px; background: none; border: none; cursor: pointer;
    text-align: left; font-size: 14px; font-weight: 600;
    transition: background .15s;
}
.mkalk-a-lista-header:hover { background: var(--mk-bg); }
.mkalk-a-lista-icon { font-size: 16px; flex-shrink: 0; }
.mkalk-a-lista-nazev { flex: 1; color: var(--mk-text); }
.mkalk-a-lista-castka { font-size: 13px; font-weight: 700; color: var(--mk-green); white-space: nowrap; }
.mkalk-a-lista-arrow { font-size: 11px; color: var(--mk-muted); flex-shrink: 0; }
.mkalk-a-lista-body { border-top: 1px solid var(--mk-border); }

/* Tabulka v liště */
.mkalk-a-lista-tabulka { padding: 4px 0; }
.mkalk-a-lt-row { display: flex; justify-content: space-between; align-items: center; padding: 7px 16px; font-size: 13px; gap: 8px; }
.mkalk-a-lt-row--alt { background: #fafafa; }
.mkalk-a-lt-row--header { background: #f0f0f0; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--mk-muted); }
.mkalk-a-lt-row--total { background: var(--mk-green-l); font-weight: 800; border-top: 1px solid var(--mk-border); }
.mkalk-a-lt-row--total strong { color: var(--mk-green); font-size: 14px; }

/* Co vám zůstane */
.mkalk-a-zustane { border: 1.5px solid var(--mk-border); border-radius: var(--mk-radius); padding: 16px 18px; margin: 10px 0; }
.mkalk-a-zustane-title { font-size: 15px; font-weight: 800; margin: 0 0 6px; }
.mkalk-a-zustane-desc { font-size: 13px; color: var(--mk-muted); margin: 0 0 12px; line-height: 1.5; }
.mkalk-a-zustane-grid { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.mkalk-a-zustane-item { flex: 1; min-width: 110px; background: #fff; border: 1.5px solid var(--mk-border); border-radius: 8px; padding: 10px 12px; display: flex; flex-direction: column; gap: 4px; }
.mkalk-a-zustane-item--best { border-color: var(--mk-green); background: var(--mk-green-l); }
.mkalk-a-zustane-forma { font-size: 11px; color: var(--mk-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .4px; }
.mkalk-a-zustane-castka { font-size: 20px; font-weight: 900; line-height: 1; }
.mkalk-a-zustane-best { font-size: 10px; font-weight: 700; color: var(--mk-green); text-transform: uppercase; }
.mkalk-a-zustane-cil { font-size: 13px; color: var(--mk-muted); margin: 0; }

/* RC karty – barvy nadpisů */
.mkalk-rc-card--green { background: var(--mk-green); }
.mkalk-rc-card--green strong,
.mkalk-rc-card--green p { color: #fff !important; }
.mkalk-rc-card--green .mkalk-rc-btn { background: rgba(255,255,255,.2); color: #fff; }
.mkalk-rc-card--white strong,
.mkalk-rc-card--white p { color: var(--mk-text) !important; }

/* Step subtitle H3 */
.mkalk-step-subtitle { font-size: 17px; font-weight: 700; color: var(--mk-text); margin: 16px 0 8px; }

@media (max-width: 520px) {
    .mkalk-a-metriky { flex-wrap: wrap; }
    .mkalk-a-metrika { flex: 0 0 50%; border-bottom: 1px solid var(--mk-border); }
    .mkalk-a-cenik-hlavni strong { font-size: 18px !important; }
}

/* ============================================================
   Nadpis ceníku
   ============================================================ */
.mkalk-a-cenik-nadpis {
    font-size: 20px;
    font-weight: 900;
    color: #fff;
    margin: 0 0 4px;
    letter-spacing: -.3px;
}

/* Tržní srovnání – Režim A */
.mkalk-a-trzni { border: 1.5px solid var(--mk-border); border-radius: var(--mk-radius); padding: 16px 18px; margin: 10px 0; }
.mkalk-trzni--nad  { border-left: 4px solid var(--mk-green); }
.mkalk-trzni--okej { border-left: 4px solid var(--mk-green); }
.mkalk-trzni--pod  { border-left: 4px solid #e67e00; }
.mkalk-a-trzni-title { font-size: 15px; font-weight: 800; margin: 0 0 12px; }
.mkalk-a-trzni-srov { display: flex; border: 1.5px solid var(--mk-border); border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
.mkalk-a-trzni-item { flex: 1; text-align: center; padding: 10px 8px; border-right: 1px solid var(--mk-border); font-size: 13px; }
.mkalk-a-trzni-item:last-child { border-right: none; }
.mkalk-a-trzni-item--vas { background: var(--mk-green-l); }
.mkalk-a-trzni-item span { display: block; font-size: 11px; color: var(--mk-muted); margin-bottom: 3px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
.mkalk-a-trzni-item strong { font-size: 18px; font-weight: 900; }
.mkalk-a-trzni-hlavni { font-size: 14px; font-weight: 600; margin: 0 0 10px; line-height: 1.5; }
.mkalk-a-trzni-tipy { margin: 0 0 10px; padding: 0 0 0 18px; font-size: 13px; color: #555; line-height: 1.7; }
.mkalk-a-trzni-zdroj { font-size: 11px; color: #aaa; margin: 0; }

/* Odeslat výsledky */
.mkalk-a-odeslat {
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin: 12px 0;
    background: var(--mk-bg);
}
.mkalk-a-odeslat-title { font-size: 16px; font-weight: 800; margin: 0 0 6px; }
.mkalk-a-odeslat-desc  { font-size: 13px; color: var(--mk-muted); margin: 0 0 14px; }
.mkalk-a-odeslat-tabs  { display: flex; gap: 8px; margin-bottom: 12px; }
.mkalk-a-tab {
    flex: 1; padding: 8px; border: 1.5px solid var(--mk-border); border-radius: 8px;
    background: #fff; cursor: pointer; font-size: 13px; font-weight: 600;
    color: var(--mk-muted); transition: all .15s;
}
.mkalk-a-tab.active { border-color: var(--mk-green); background: var(--mk-green-l); color: var(--mk-green); }
.mkalk-input {
    width: 100%; padding: 10px 14px; border: 1.5px solid var(--mk-border); border-radius: 8px;
    font-size: 15px; margin-bottom: 10px; box-sizing: border-box;
}
.mkalk-input:focus { outline: none; border-color: var(--mk-green); box-shadow: 0 0 0 3px rgba(44,122,75,.1); }
.mkalk-a-odeslat-sent { color: var(--mk-green); font-weight: 700; font-size: 15px; text-align: center; padding: 10px 0; }

/* Sekce nadpisy – jednotný styl pro výsledky Režimu A */
.mkalk-a-sekce-nadpis {
    font-size: 20px;
    font-weight: 900;
    color: var(--mk-text);
    margin: 20px 0 10px;
    letter-spacing: -.3px;
    border-bottom: 2px solid var(--mk-border);
    padding-bottom: 6px;
}
.mkalk-a-sekce-nadpis--dark {
    /* Nadpis tržního srovnání – uvnitř bloku, bez border-bottom */
    border-bottom: none;
    padding-bottom: 0;
    margin: 0 0 12px;
}
/* Odebrat starý styl ceník nadpisu uvnitř hero */
.mkalk-a-cenik-hero .mkalk-a-cenik-nadpis { display: none; }

/* ============================================================
   Režim B – nová výsledková stránka
   ============================================================ */
.mkalk-b-sekce { margin-bottom: 20px; }

.mkalk-b-nadpis {
    font-size: 20px;
    font-weight: 900;
    color: var(--mk-text);
    margin: 0 0 12px;
    padding-bottom: 6px;
    border-bottom: 2px solid var(--mk-border);
}

/* Sazba hero */
.mkalk-b-sazba-hero {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    border-radius: var(--mk-radius);
    padding: 20px 22px 16px;
    margin-bottom: 12px;
    color: #fff;
}
.mkalk-b-sazba-cislo {
    font-size: 42px;
    font-weight: 900;
    color: #fff;
    line-height: 1.1;
    margin-bottom: 4px;
}
.mkalk-b-sazba-sub { font-size: 14px; color: rgba(255,255,255,.8); }

/* Metriky */
.mkalk-b-metriky {
    display: flex;
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    overflow: hidden;
    margin-bottom: 10px;
}
.mkalk-b-metrika {
    flex: 1;
    padding: 12px 10px;
    text-align: center;
    border-right: 1px solid var(--mk-border);
}
.mkalk-b-metrika:last-child { border-right: none; }
.mkalk-b-metrika--accent { background: var(--mk-green-l); }
.mkalk-b-m-label {
    display: block;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--mk-muted);
    font-weight: 700;
    margin-bottom: 4px;
}
.mkalk-b-m-val {
    display: block;
    font-size: 16px;
    font-weight: 800;
    color: var(--mk-text);
}
.mkalk-b-metrika--accent .mkalk-b-m-val { color: var(--mk-green); }

/* Ceník tabulka pro Režim B */
.mkalk-b-cenik-tbl {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 8px;
    font-size: 14px;
}
.mkalk-b-cenik-tbl th {
    background: var(--mk-bg);
    padding: 8px 12px;
    text-align: left;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: var(--mk-muted);
    border-bottom: 2px solid var(--mk-border);
    font-weight: 700;
}
.mkalk-b-cenik-tbl td {
    padding: 9px 12px;
    border-bottom: 1px solid var(--mk-border);
}
.mkalk-b-cenik-tbl tr:hover td { background: #fafafa; }
.b-cenik-doplnena td { color: var(--mk-muted); background: #fafafa; }
.mkalk-b-cenik-note {
    font-size: 12px;
    color: var(--mk-muted);
    margin: 4px 0 0;
}

@media (max-width:520px) {
    .mkalk-b-metriky { flex-wrap: wrap; }
    .mkalk-b-metrika { flex: 0 0 50%; border-bottom: 1px solid var(--mk-border); }
    .mkalk-b-sazba-cislo { font-size: 32px; }
}

/* ============================================================
   Režim B – nová výsledková stránka (spec redesign)
   ============================================================ */

/* BLOK 1 – Hero situace */
.mkalk-b-hero-blok {
    background: linear-gradient(135deg, #1a5c38, #2c7a4b);
    border-radius: var(--mk-radius);
    padding: 24px 24px 18px;
    margin-bottom: 16px;
    color: #fff;
}
.mkalk-b-hero-hlavni {
    display: flex;
    align-items: flex-end;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.mkalk-b-hero-aktualni,
.mkalk-b-hero-doporucena { flex: 1; min-width: 140px; }
.mkalk-b-hero-sep {
    font-size: 28px;
    color: rgba(255,255,255,.5);
    padding-bottom: 8px;
    flex-shrink: 0;
}
.mkalk-b-hero-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: rgba(255,255,255,.65);
    font-weight: 700;
    margin-bottom: 4px;
}
.mkalk-b-hero-cislo {
    font-size: 42px;
    font-weight: 900;
    color: rgba(255,255,255,.7);
    line-height: 1;
}
.mkalk-b-hero-cislo--dop { color: #fff; }
.mkalk-b-hero-unit { font-size: 13px; color: rgba(255,255,255,.6); margin-top: 2px; }

.mkalk-b-hero-potencial {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    background: rgba(255,255,255,.1);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 16px;
}
.mkalk-b-hero-pot-item { flex: 1; }
.mkalk-b-hero-pot-label { font-size: 11px; color: rgba(255,255,255,.65); display: block; margin-bottom: 2px; }
.mkalk-b-hero-pot-item strong { font-size: 15px; font-weight: 800; }
.mkalk-b-hero-pot-item--accent strong { font-size: 18px; }

/* Zhodnocení uvnitř hero */
.mkalk-b-zhodnoceni {
    border-top: 1px solid rgba(255,255,255,.15);
    padding-top: 14px;
}
.mkalk-b-zh-ikona-text {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
    font-size: 15px;
}
.mkalk-b-zh-ikona-text strong { color: #fff; font-size: 15px; }
.mkalk-b-zhodnoceni p { font-size: 13px; color: rgba(255,255,255,.8); margin: 0; line-height: 1.6; }

/* BLOK 3 – Zhodnocení praxe (pásmo) */
.mkalk-b-pasmo {
    border: 2px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 16px 18px;
}
.mkalk-b-pasmo--red    { border-color: #e74c3c; background: #fdf2f2; }
.mkalk-b-pasmo--yellow { border-color: #f39c12; background: #fefdf0; }
.mkalk-b-pasmo--green  { border-color: var(--mk-green); background: var(--mk-green-l); }
.mkalk-b-pasmo--gold   { border-color: #f1c40f; background: #fefdf0; }
.mkalk-b-pasmo-header  { display: flex; align-items: center; gap: 8px; font-size: 17px; font-weight: 800; margin-bottom: 8px; }
.mkalk-b-pasmo p       { font-size: 13px; color: #555; margin: 0 0 12px; }
.mkalk-b-pasmo-metriky { display: flex; border: 1px solid var(--mk-border); border-radius: 8px; overflow: hidden; background: #fff; }
.mkalk-b-pasmo-metrika { flex: 1; padding: 10px 8px; text-align: center; border-right: 1px solid var(--mk-border); font-size: 13px; }
.mkalk-b-pasmo-metrika:last-child { border-right: none; }
.mkalk-b-pasmo-metrika--accent { background: var(--mk-green-l); }
.mkalk-b-pasmo-metrika span { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .4px; color: var(--mk-muted); margin-bottom: 3px; font-weight: 700; }
.mkalk-b-pasmo-metrika strong { font-size: 15px; font-weight: 800; }

/* BLOK 4 – Doporučení */
.mkalk-b-dop-karta {
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    padding: 14px 16px;
    margin-bottom: 10px;
    background: #fff;
}
.mkalk-b-dop-karta--hlavni { border-color: var(--mk-green); background: var(--mk-green-l); }
.mkalk-b-dop-karta--tip    { border-color: #e67e00; background: #fff8f0; }
.mkalk-b-dop-label { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: var(--mk-muted); margin-bottom: 6px; }
.mkalk-b-dop-karta--hlavni .mkalk-b-dop-label { color: var(--mk-green); }
.mkalk-b-dop-karta--tip    .mkalk-b-dop-label { color: #e67e00; }
.mkalk-b-dop-karta p { font-size: 13px; margin: 0 0 6px; line-height: 1.6; }
.mkalk-b-dop-karta p:last-child { margin-bottom: 0; }

/* BLOK 5 – Srovnání s trhem */
.mkalk-b-trh-grid {
    display: flex;
    border: 1.5px solid var(--mk-border);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 10px;
}
.mkalk-b-trh-item { flex: 1; padding: 12px 10px; text-align: center; border-right: 1px solid var(--mk-border); }
.mkalk-b-trh-item:last-child { border-right: none; }
.mkalk-b-trh-label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--mk-muted); font-weight: 700; margin-bottom: 4px; }
.mkalk-b-trh-item strong { font-size: 18px; font-weight: 900; }
.mkalk-b-trh-note { font-size: 13px; color: #555; margin: 0 0 4px; line-height: 1.5; }

/* BLOK 6 – Detail toggle */
.mkalk-b-detail-toggle {
    width: 100%;
    padding: 12px 16px;
    background: var(--mk-bg);
    border: 1.5px solid var(--mk-border);
    border-radius: var(--mk-radius);
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
    color: var(--mk-text);
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: background .15s;
}
.mkalk-b-detail-toggle:hover { background: #e8f5ee; }
.mkalk-b-detail-arrow { font-size: 12px; color: var(--mk-muted); }
.mkalk-b-detail-panel { border: 1.5px solid var(--mk-border); border-top: none; border-radius: 0 0 var(--mk-radius) var(--mk-radius); padding: 0 4px; }
.mkalk-b-detail-sekce { padding: 16px 12px; border-bottom: 1px solid var(--mk-border); }
.mkalk-b-detail-sekce:last-child { border-bottom: none; }
.mkalk-b-detail-nadpis { font-size: 15px; font-weight: 800; margin: 0 0 10px; }

/* CTA blok */
.mkalk-b-cta {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: #fff8e6;
    border: 2px solid #f1c40f;
    border-radius: var(--mk-radius);
    padding: 18px 20px;
    margin: 16px 0;
}
.mkalk-b-cta-ikona { font-size: 28px; flex-shrink: 0; }
.mkalk-b-cta-titulek { display: block; font-size: 16px; font-weight: 800; color: var(--mk-text); margin-bottom: 6px; }
.mkalk-b-cta-text { font-size: 13px; color: #555; margin: 0 0 12px; line-height: 1.6; }

@media (max-width: 520px) {
    .mkalk-b-hero-hlavni { flex-direction: column; gap: 10px; }
    .mkalk-b-hero-sep { display: none; }
    .mkalk-b-hero-cislo { font-size: 32px; }
    .mkalk-b-trh-grid { flex-wrap: wrap; }
    .mkalk-b-trh-item { flex: 0 0 50%; border-bottom: 1px solid var(--mk-border); }
    .mkalk-b-cta { flex-direction: column; }
}
