/* === MeetingCost by Elowenta — izolowany widżet === */

#elo-kks-widget {
    all: initial;
    display: block;
    box-sizing: border-box;
    font-family: inherit;
    --elo-kks-bg: #f8f9fb;
    --elo-kks-fg: #0f172a;
    --elo-kks-muted: #475569;
    --elo-kks-card: #ffffff;
    --elo-kks-border: #e2e8f0;
    --elo-kks-accent: #111827;
    --elo-kks-accent-2: #ff5232;
    --elo-kks-accent-2-hover: #d94d20;
    --elo-kks-secondary: #e1e8e9;
    --elo-kks-secondary-hover: #b3b3b3;
    max-width: 100%;
    overflow-x: hidden;
    background: var(--elo-kks-bg);
    color: var(--elo-kks-fg);
    line-height: 1.5;
    font-size: 16px;
    scroll-behavior: smooth;
}
#elo-kks-widget *, #elo-kks-widget *::before, #elo-kks-widget *::after { box-sizing: border-box; }

/* === Layout === */
#elo-kks-widget .elo-kks-container { max-width: 100%; margin: 32px auto; padding: 0 16px; }
#elo-kks-widget .elo-kks-grid { display: grid; gap: 16px; }
@media (min-width: 960px) { #elo-kks-widget .elo-kks-grid { grid-template-columns: 1.2fr 0.8fr; } }

/* === Karty === */
#elo-kks-widget .elo-kks-card { background: var(--elo-kks-card); border: 1px solid var(--elo-kks-border); border-radius: 14px; padding: 18px; }
#elo-kks-widget .elo-kks-card h2 { font-size: 18px; font-weight: 700; margin: 0 0 12px; color: var(--elo-kks-fg); }

/* === Kontrolki === */
#elo-kks-widget .elo-kks-row { display: block; margin: 14px 0; }
#elo-kks-widget .elo-kks-row label { display: block; font-weight: 700; font-size: 14px; margin-bottom: 8px; color: var(--elo-kks-fg); }
#elo-kks-widget .elo-kks-ctrl-wrap { display: grid; grid-template-columns: 96px 1fr; gap: 12px; align-items: center; }
#elo-kks-widget input[type="number"], #elo-kks-widget input[type="text"], #elo-kks-widget input[type="email"], #elo-kks-widget select {
    width: 100%; padding: 10px 12px; border: 1px solid var(--elo-kks-border); border-radius: 10px; background: #fff; font-size: 16px; color: var(--elo-kks-fg); font-family: inherit;
}
#elo-kks-widget input[type="range"] { width: 100%; }
#elo-kks-widget input:focus, #elo-kks-widget select:focus { outline: 2px solid #c7d2fe; border-color: #a5b4fc; }
#elo-kks-widget .elo-kks-freq-section { border-top: 1px solid var(--elo-kks-border); margin-top: 16px; padding-top: 16px; }

/* === Stawka domyślna === */
#elo-kks-widget .elo-kks-base-rate { display: grid; grid-template-columns: 200px 1fr; gap: 12px; align-items: center; }
@media (max-width: 480px) { #elo-kks-widget .elo-kks-base-rate { grid-template-columns: 1fr; } }

/* === Stawki uczestników === */
#elo-kks-widget .elo-kks-participants { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; margin-bottom: 8px; }
#elo-kks-widget .elo-kks-participant { display: flex; flex-direction: column; gap: 6px; padding-top: 10px; border-top: 1px solid var(--elo-kks-border); }
#elo-kks-widget .elo-kks-participant label { width: auto; }
#elo-kks-widget .elo-kks-participant input { flex: 1; }
@media (min-width: 481px) {
    #elo-kks-widget .elo-kks-participant { flex-direction: row; align-items: center; }
    #elo-kks-widget .elo-kks-participant label { width: 120px; flex-shrink: 0; }
    #elo-kks-widget .elo-kks-participant input { max-width: 150px; }
    #elo-kks-widget .elo-kks-quick { flex: 1; }
}

/* === Quick rate buttons === */
#elo-kks-widget .elo-kks-quick { display: flex; gap: 6px; flex-wrap: wrap; }
#elo-kks-widget .elo-kks-btn-rate { appearance: none; border: 1px solid var(--elo-kks-border); background: #e5e7eb; color: #111; padding: 6px 10px; border-radius: 8px; font-weight: 600; font-size: 13px; cursor: pointer; transition: background .2s, color .2s; font-family: inherit; }
#elo-kks-widget .elo-kks-btn-rate:hover { background: #d1d5db; }
@media (max-width: 480px) {
    #elo-kks-widget .elo-kks-quick { gap: 6px; }
    #elo-kks-widget .elo-kks-btn-rate { padding: 6px 8px; font-size: 12px; }
    #elo-kks-widget .elo-kks-btn-rate[data-val="50"] { display: none; }
}
@media (max-width: 360px) {
    #elo-kks-widget .elo-kks-btn-rate[data-val="300"] { display: none; }
    #elo-kks-widget .elo-kks-quick { gap: 4px; }
    #elo-kks-widget .elo-kks-btn-rate { padding: 5px 7px; font-size: 11px; }
}

/* === Przyciski === */
#elo-kks-widget .elo-kks-btn-main { display: block; width: 100%; text-align: center; margin: 6px 0; padding: 20px; font-size: 15px; font-weight: 600; border-radius: 50px; border: none; text-decoration: none; transition: background .2s ease-in-out; cursor: pointer; font-family: inherit; line-height: 1.4; }
#elo-kks-widget .elo-kks-btn-primary { background: var(--elo-kks-accent-2); color: #fff; text-decoration: none; }
#elo-kks-widget .elo-kks-btn-primary:hover { background: var(--elo-kks-accent-2-hover); }
#elo-kks-widget .elo-kks-btn-secondary { background: var(--elo-kks-secondary); color: #111; text-decoration: none; }
#elo-kks-widget .elo-kks-btn-secondary:hover { background: var(--elo-kks-secondary-hover); }
#elo-kks-widget .elo-kks-cta-spaced { margin: 10px 0 20px; display: block; }

/* === Wyniki === */
#elo-kks-widget .elo-kks-result { display: flex; flex-direction: column; gap: 10px; }
#elo-kks-widget .elo-kks-big { font-size: clamp(26px, 4vw, 40px); font-weight: 800; color: var(--elo-kks-fg); }
#elo-kks-widget .elo-kks-muted { color: var(--elo-kks-muted); font-size: 14px; }

/* === KPI grid === */
#elo-kks-widget .elo-kks-kpis { display: grid; grid-template-columns: 1fr; gap: 10px; margin-top: 4px; }
@media (min-width: 700px) { #elo-kks-widget .elo-kks-kpis { grid-template-columns: repeat(2, minmax(0,1fr)); } }
#elo-kks-widget .elo-kks-kpi { border: 1px solid var(--elo-kks-border); border-radius: 10px; padding: 10px; background: var(--elo-kks-card); }
#elo-kks-widget .elo-kks-kpi-label { font-size: 12px; color: var(--elo-kks-muted); }
#elo-kks-widget .elo-kks-kpi-value { font-weight: 700; color: var(--elo-kks-fg); }

/* === Alerty === */
#elo-kks-widget .elo-kks-alert { border: 1px solid var(--elo-kks-border); border-radius: 12px; padding: 12px; font-weight: 600; font-size: 14px; }
#elo-kks-widget .elo-kks-alert.good { background: #ecfdf5; border-color: #bbf7d0; }
#elo-kks-widget .elo-kks-alert.ok { background: #eff6ff; border-color: #bfdbfe; }
#elo-kks-widget .elo-kks-alert.warn { background: #fff7ed; border-color: #fed7aa; }
#elo-kks-widget .elo-kks-alert.high { background: #fff1f2; border-color: #fecdd3; }
#elo-kks-widget .elo-kks-alert.extreme { background: #fee2e2; border-color: #fecaca; }
#elo-kks-widget .elo-kks-alert.critical { background: #7f1d1d; border-color: #b91c1c; color: #fff; }

/* === Sekcja czasu === */
#elo-kks-widget .elo-kks-section-title { font-weight: 800; font-size: 15px; margin: 22px 0 10px; color: var(--elo-kks-fg); }
#elo-kks-widget .elo-kks-section-divider { height: 1px; background: var(--elo-kks-border); margin: 14px 0 0; border: 0; }
#elo-kks-widget .elo-kks-time-block { margin-top: 18px; padding-top: 6px; }

/* === Details/Summary === */
#elo-kks-widget details { border: 1px solid var(--elo-kks-border); border-radius: 12px; padding: 12px; background: #fff; }
#elo-kks-widget details > summary { cursor: pointer; font-weight: 700; list-style: none; outline: none; }
#elo-kks-widget details > summary::-webkit-details-marker { display: none; }
#elo-kks-widget .elo-kks-summary-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
@media (max-width: 540px) { #elo-kks-widget .elo-kks-summary-row { flex-direction: column; align-items: flex-start; gap: 6px; } }
#elo-kks-widget .elo-kks-chev { display: inline-block; width: 1em; height: 1em; transform: rotate(0); transition: transform .2s ease; }
#elo-kks-widget details[open] .elo-kks-chev { transform: rotate(180deg); }
#elo-kks-widget .elo-kks-badge { font-size: 12px; color: #fff; background: var(--elo-kks-accent); border-radius: 999px; padding: 2px 8px; }
#elo-kks-widget .elo-kks-hint { font-size: 12px; color: var(--elo-kks-muted); }

/* ═══════════════════════════════════════════
   WYKRES ROCZNY
   ═══════════════════════════════════════════ */
#elo-kks-widget .elo-kks-chart-section { margin-top: 16px; }
#elo-kks-widget .elo-kks-chart { width: 100%; min-height: 80px; }

/* ═══════════════════════════════════════════
   PORÓWNANIE SCENARIUSZY
   ═══════════════════════════════════════════ */
#elo-kks-widget .elo-kks-compare-section { margin-top: 16px; }
#elo-kks-widget .elo-kks-btn-compare {
    appearance: none; background: none; border: 1px dashed var(--elo-kks-border); border-radius: 10px;
    padding: 12px 16px; width: 100%; text-align: center; cursor: pointer; font-weight: 600; font-size: 14px;
    color: var(--elo-kks-muted); transition: border-color .2s, color .2s; font-family: inherit;
}
#elo-kks-widget .elo-kks-btn-compare:hover { border-color: var(--elo-kks-accent-2); color: var(--elo-kks-accent-2); }

#elo-kks-widget .elo-kks-compare-panel { margin-top: 12px; }
#elo-kks-widget .elo-kks-compare-heading { font-weight: 700; font-size: 14px; margin-bottom: 10px; color: var(--elo-kks-fg); }
#elo-kks-widget .elo-kks-compare-inputs {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 14px;
}
@media (min-width: 600px) { #elo-kks-widget .elo-kks-compare-inputs { grid-template-columns: repeat(4, 1fr); } }
#elo-kks-widget .elo-kks-compare-field label { display: block; font-size: 12px; font-weight: 600; color: var(--elo-kks-muted); margin-bottom: 4px; }
#elo-kks-widget .elo-kks-compare-field input { width: 100%; }

/* Wynik porównania */
#elo-kks-widget .elo-kks-compare-result { margin-top: 8px; }
#elo-kks-widget .elo-kks-cmp-row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
@media (max-width: 480px) { #elo-kks-widget .elo-kks-cmp-row { grid-template-columns: 1fr; } }
#elo-kks-widget .elo-kks-cmp-cell { border: 1px solid var(--elo-kks-border); border-radius: 10px; padding: 10px; text-align: center; }
#elo-kks-widget .elo-kks-cmp-label { font-size: 11px; color: var(--elo-kks-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
#elo-kks-widget .elo-kks-cmp-val { font-size: 16px; font-weight: 800; margin-top: 2px; }
#elo-kks-widget .elo-kks-cmp-sub { font-size: 11px; color: var(--elo-kks-muted); margin-top: 2px; }
#elo-kks-widget .elo-kks-cmp-savings { background: #ecfdf5; border-color: #bbf7d0; }
#elo-kks-widget .elo-kks-cmp-savings .elo-kks-cmp-val { color: #166534; }
#elo-kks-widget .elo-kks-cmp-more { background: #fff1f2; border-color: #fecdd3; }
#elo-kks-widget .elo-kks-cmp-more .elo-kks-cmp-val { color: #9f1239; }
#elo-kks-widget .elo-kks-cmp-same { background: #f8fafc; }
#elo-kks-widget .elo-kks-cmp-summary { margin-top: 10px; font-size: 13px; color: var(--elo-kks-fg); line-height: 1.5; }
#elo-kks-widget .elo-kks-cmp-summary strong { font-weight: 800; }
#elo-kks-widget .elo-kks-cmp-empty { text-align: center; color: var(--elo-kks-muted); font-size: 13px; padding: 10px; }

/* ═══════════════════════════════════════════
   GATE — overlay z blur
   ═══════════════════════════════════════════ */
#elo-kks-widget .elo-kks-gated-wrap { position: relative; }
#elo-kks-widget .elo-kks-gated-locked > *:not(.elo-kks-gate-overlay) {
    filter: blur(6px);
    pointer-events: none;
    user-select: none;
    opacity: 0.5;
    transition: filter .3s, opacity .3s;
}
#elo-kks-widget .elo-kks-gate-overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    display: none; align-items: center; justify-content: center;
    z-index: 10;
    background: rgba(248, 249, 251, 0.2);
    backdrop-filter: blur(2px);
    border-radius: 14px;
}
#elo-kks-widget .elo-kks-gate-overlay.elo-kks-gate-active {
    display: flex;
}
#elo-kks-widget .elo-kks-gate-box {
    background: var(--elo-kks-card);
    border: 2px solid var(--elo-kks-accent-2);
    border-radius: 16px;
    padding: 28px 24px;
    max-width: 380px;
    width: 90%;
    text-align: center;
    box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}
#elo-kks-widget .elo-kks-gate-heading { font-size: 18px; font-weight: 800; margin-bottom: 8px; color: var(--elo-kks-fg); }
#elo-kks-widget .elo-kks-gate-desc { font-size: 13px; color: var(--elo-kks-muted); margin-bottom: 16px; }
#elo-kks-widget .elo-kks-gate-form { display: flex; flex-direction: column; gap: 10px; }
#elo-kks-widget .elo-kks-gate-input { text-align: center; }
#elo-kks-widget .elo-kks-gate-consent-label {
    display: flex; gap: 8px; align-items: flex-start; text-align: left;
    font-size: 11px; line-height: 1.4; color: var(--elo-kks-muted); cursor: pointer;
    margin-top: 2px;
}
#elo-kks-widget .elo-kks-gate-consent-checkbox {
    flex-shrink: 0; width: 16px; height: 16px; margin-top: 1px;
    accent-color: var(--elo-kks-accent-2); cursor: pointer;
}
#elo-kks-widget .elo-kks-gate-consent-text { flex: 1; }
#elo-kks-widget .elo-kks-gate-consent-text a { color: var(--elo-kks-accent-2); text-decoration: underline; }
#elo-kks-widget .elo-kks-gate-error { color: #dc2626; font-size: 13px; margin-top: 6px; }
#elo-kks-widget .elo-kks-gate-success {
    background: #ecfdf5; border: 1px solid #bbf7d0; border-radius: 10px; padding: 12px; text-align: center;
    font-weight: 600; font-size: 14px; margin-bottom: 12px; animation: elo-kks-fade-out 4s ease-out forwards;
}
@keyframes elo-kks-fade-out { 0%,70% { opacity: 1; } 100% { opacity: 0; } }

/* ═══ Tooltip ═══════════════════════════════════════════ */
#elo-kks-widget .elo-kks-tooltip {
    position: relative; cursor: help; font-size: 14px;
    color: var(--elo-kks-accent-2); margin-left: 4px; vertical-align: middle;
}
#elo-kks-widget .elo-kks-tooltip-text {
    display: none; position: absolute; bottom: 130%; left: 50%; transform: translateX(-50%);
    background: var(--elo-kks-fg); color: #fff; padding: 8px 12px; border-radius: 8px;
    font-size: 12px; font-weight: 400; line-height: 1.5; width: 240px; text-align: left;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15); z-index: 20; pointer-events: none;
}
#elo-kks-widget .elo-kks-tooltip-text::after {
    content: ""; position: absolute; top: 100%; left: 50%; margin-left: -5px;
    border: 5px solid transparent; border-top-color: var(--elo-kks-fg);
}
#elo-kks-widget .elo-kks-tooltip:hover .elo-kks-tooltip-text,
#elo-kks-widget .elo-kks-tooltip:focus .elo-kks-tooltip-text { display: block; }

/* ═══ Unlock CTA ════════════════════════════════════════ */
#elo-kks-widget .elo-kks-unlock-cta {
    display: block; text-align: center; margin: 16px 0; padding: 14px 24px;
    font-size: 15px; font-weight: 700; border-radius: 10px;
    animation: elo-kks-fade-in 0.4s ease-out;
}
#elo-kks-widget .elo-kks-unlock-cta[hidden] { display: none; }
@keyframes elo-kks-fade-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
