/* =============================================
   Otvorsa Konfigurátor – konfigurator.css
   ============================================= */

.ok-wrap {
    max-width: 680px;
    margin: 2rem auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    position: relative;
    padding-bottom: 8px;
}

/* Progress bar */
.ok-progress {
    height: 5px;
    background: #e5e7eb;
    border-radius: 99px;
    overflow: hidden;
    margin-bottom: 1.5rem;
}
.ok-progress-bar {
    height: 100%;
    background: #2563eb;
    border-radius: 99px;
    transition: width 0.4s ease;
    width: 0%;
}

.ok-selection-summary {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin: -.6rem 0 1rem;
}

.ok-selection-item {
    font-size: .78rem;
    color: #4b5563;
    background: #f3f4f6;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    padding: .28rem .55rem;
}

/* Steps */
.ok-step {
    display: none;
}
.ok-step.active {
    display: block;
    animation: okFadeIn 0.3s ease;
}
@keyframes okFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Header */
.ok-step-num {
    font-size: 0.78rem;
    color: #6b7280;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.ok-title {
    font-size: 1.35rem;
    font-weight: 700;
    color: #111827;
    margin: .4rem 0 .3rem;
}
.ok-desc {
    color: #6b7280;
    font-size: 0.92rem;
    margin-bottom: 1.3rem;
}

/* Options grid */
.ok-options {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: .75rem;
    margin-bottom: 1.2rem;
}

.ok-btn {
    background: #fff;
    border: 2px solid #e5e7eb;
    border-radius: 12px;
    padding: 1rem .75rem;
    font-size: .95rem;
    font-weight: 600;
    color: #374151;
    cursor: pointer;
    text-align: center;
    line-height: 1.4;
    transition: border-color .2s, background .2s, transform .1s;
}
.ok-btn:hover {
    border-color: #2563eb;
    background: #eff6ff;
    color: #1d4ed8;
    transform: translateY(-2px);
}
.ok-btn small {
    display: block;
    font-weight: 400;
    font-size: .78rem;
    color: #9ca3af;
    margin-top: .2rem;
}
.ok-icon {
    font-size: 1.4rem;
    display: block;
    margin-bottom: .3rem;
}

/* Back button */
.ok-back {
    background: none;
    border: none;
    color: #6b7280;
    cursor: pointer;
    font-size: .9rem;
    padding: .3rem 0;
    margin-top: .5rem;
}
.ok-back:hover { color: #374151; }

/* Result */
.ok-result-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #111827;
    margin-bottom: 1rem;
}

.ok-product {
    background: #fff;
    border: 2px solid #e5e7eb;
    border-radius: 14px;
    padding: 1.1rem 1.2rem;
    margin-bottom: .9rem;
    position: relative;
    transition: border-color .2s;
}
.ok-product--top {
    border-color: #2563eb;
    background: #eff6ff;
}
.ok-product-name {
    font-size: 1.05rem;
    font-weight: 700;
    color: #111827;
    margin-bottom: .25rem;
}
.ok-product-desc {
    font-size: .88rem;
    color: #6b7280;
    margin-bottom: .5rem;
}
.ok-product-price {
    font-size: 1rem;
    font-weight: 700;
    color: #16a34a;
    margin-bottom: .75rem;
}

.ok-badge {
    display: inline-block;
    background: #2563eb;
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .2rem .55rem;
    border-radius: 99px;
    margin-bottom: .6rem;
}

.ok-cta {
    display: inline-block;
    background: #2563eb;
    color: #fff !important;
    padding: .55rem 1.2rem;
    border-radius: 8px;
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none !important;
    transition: background .2s;
}
.ok-cta:hover { background: #1d4ed8; }

.ok-result-note {
    font-size: .85rem;
    color: #9ca3af;
    margin-top: 1rem;
}
.ok-result-note a { color: #2563eb; }

.ok-result-actions {
    margin-top: .5rem;
}
.ok-restart {
    background: none;
    border: 2px solid #e5e7eb;
    border-radius: 8px;
    padding: .5rem 1rem;
    font-size: .88rem;
    cursor: pointer;
    color: #374151;
    font-weight: 600;
}
.ok-restart:hover { border-color: #9ca3af; }

.ok-no-result {
    text-align: center;
    padding: 2rem;
    color: #6b7280;
}
.ok-no-result p { margin-bottom: 1rem; }

/* Responsive */
@media (max-width: 480px) {
    .ok-options {
        grid-template-columns: 1fr 1fr;
    }
    .ok-title { font-size: 1.1rem; }

    .ok-selection-summary {
        gap: .4rem;
    }

    .ok-selection-item {
        font-size: .74rem;
    }
}
