/* =====================================================================
   CMP cookie-banner + beállítás-modal + iframe-placeholder + újranyitó gomb (228)
   A színek a banner inline CSS-változóiból jönnek (--cmp-bg/--cmp-fg/...), így
   a megjelenés adminból állítható és témafüggetlen (saját felület, nem a shop-téma).
   Reszponzív, mobilbarát, kulturált (nem ugráló) megjelenés.
   ===================================================================== */

.cmp-root { position: fixed; inset: 0; z-index: 12000; pointer-events: none; }
.cmp-root[hidden] { display: none; }

/* ---- Alap banner ---- */
.cmp-banner {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    width: min(1100px, calc(100% - 24px));
    background: var(--cmp-bg, #0b2e4f);
    color: var(--cmp-fg, #fff);
    border-radius: 14px;
    box-shadow: 0 12px 40px rgba(0,0,0,.28);
    padding: 18px 20px;
    display: flex;
    gap: 18px;
    align-items: center;
    pointer-events: auto;
}
.cmp-poz-lent .cmp-banner { bottom: 16px; }
.cmp-poz-fent .cmp-banner { top: 16px; }
.cmp-poz-bal_sarok .cmp-banner { left: 16px; transform: none; bottom: 16px; width: min(420px, calc(100% - 24px)); flex-direction: column; align-items: stretch; }
.cmp-poz-jobb_sarok .cmp-banner { left: auto; right: 16px; transform: none; bottom: 16px; width: min(420px, calc(100% - 24px)); flex-direction: column; align-items: stretch; }
.cmp-poz-kozepen_modal .cmp-banner { top: 50%; bottom: auto; transform: translate(-50%, -50%); width: min(560px, calc(100% - 24px)); flex-direction: column; align-items: stretch; }

.cmp-banner-szoveg { flex: 1 1 auto; min-width: 0; }
.cmp-banner-cim { font-size: 17px; font-weight: 700; margin: 0 0 4px; color: var(--cmp-fg, #fff); }
.cmp-banner-leiras { font-size: 13.5px; line-height: 1.5; margin: 0; opacity: .95; }
.cmp-banner-link, .cmp-modal-adatvedelem a { color: var(--cmp-fg, #fff); text-decoration: underline; font-weight: 600; }

.cmp-banner-gombok { display: flex; gap: 8px; flex-wrap: wrap; flex: 0 0 auto; }
.cmp-poz-bal_sarok .cmp-banner-gombok,
.cmp-poz-jobb_sarok .cmp-banner-gombok,
.cmp-poz-kozepen_modal .cmp-banner-gombok { margin-top: 12px; }

/* ---- Gombok ---- */
.cmp-gomb {
    border: 0; border-radius: 9px; padding: 10px 16px; font-size: 14px; font-weight: 600;
    cursor: pointer; line-height: 1.2; min-height: 42px; color: #fff; transition: filter .15s ease;
}
.cmp-gomb:hover { filter: brightness(1.08); }
.cmp-gomb-elfogad { background: var(--cmp-accept, #1e9e5a); }
.cmp-gomb-elutasit { background: var(--cmp-reject, #6c757d); }
.cmp-gomb-beallit { background: var(--cmp-settings, #0d6efd); }

/* ---- Modal ---- */
.cmp-modal { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: auto; z-index: 12010; }
.cmp-modal[hidden] { display: none; }
.cmp-modal-hatter { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.cmp-modal-doboz {
    position: relative; z-index: 1; background: #fff; color: #1f2937;
    width: min(680px, calc(100% - 24px)); max-height: calc(100vh - 48px);
    border-radius: 14px; display: flex; flex-direction: column; overflow: hidden;
    box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.cmp-modal-fejlec { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid #e5e7eb; }
.cmp-modal-cim { font-size: 18px; font-weight: 700; margin: 0; }
.cmp-modal-bezar { background: none; border: 0; font-size: 26px; line-height: 1; cursor: pointer; color: #6b7280; }
.cmp-modal-torzs { padding: 8px 20px; overflow-y: auto; }
.cmp-modal-lablec { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; padding: 14px 20px; border-top: 1px solid #e5e7eb; }
.cmp-modal-adatvedelem { margin: 8px 0 4px; }
.cmp-modal-adatvedelem a { color: #0d6efd; }

/* ---- Kategória sor + kapcsoló ---- */
.cmp-kategoria { padding: 14px 0; border-bottom: 1px solid #eef0f3; }
.cmp-kategoria:last-of-type { border-bottom: 0; }
.cmp-kategoria-fejlec { display: flex; gap: 12px; align-items: flex-start; }
.cmp-kategoria-cim { flex: 1 1 auto; }
.cmp-kategoria-cim strong { font-size: 15px; }
.cmp-kategoria-leiras { font-size: 13px; color: #4b5563; margin: 4px 0 0; }
.cmp-jelzo { display: inline-block; font-size: 11px; background: #e5e7eb; color: #374151; border-radius: 20px; padding: 1px 8px; margin-left: 6px; vertical-align: middle; }

.cmp-kapcsolo { position: relative; display: inline-block; width: 44px; height: 26px; flex: 0 0 auto; cursor: pointer; }
.cmp-kapcsolo input { position: absolute; opacity: 0; width: 0; height: 0; }
.cmp-kapcsolo-sin { position: absolute; inset: 0; background: #cbd5e1; border-radius: 26px; transition: background .15s ease; }
.cmp-kapcsolo-sin::before { content: ""; position: absolute; width: 20px; height: 20px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: transform .15s ease; }
.cmp-kapcsolo input:checked + .cmp-kapcsolo-sin { background: var(--cmp-accept, #1e9e5a); }
.cmp-kapcsolo input:checked + .cmp-kapcsolo-sin::before { transform: translateX(18px); }
.cmp-kapcsolo input:disabled + .cmp-kapcsolo-sin { opacity: .65; }

/* ---- Részletek (sütik) ---- */
.cmp-reszletek { margin: 10px 0 0 56px; }
.cmp-reszletek summary { cursor: pointer; font-size: 13px; color: #0d6efd; }
.cmp-szolg { margin: 8px 0; }
.cmp-szolg-nev { font-size: 13.5px; font-weight: 600; }
.cmp-szolg-szolgaltato { font-weight: 400; color: #6b7280; }
.cmp-suti-tabla { width: 100%; border-collapse: collapse; margin-top: 4px; font-size: 12px; }
.cmp-suti-tabla th, .cmp-suti-tabla td { border: 1px solid #e5e7eb; padding: 4px 6px; text-align: left; vertical-align: top; }
.cmp-suti-tabla th { background: #f8fafc; }
.cmp-suti-tabla code { font-size: 11.5px; }

/* ---- iframe placeholder ---- */
.cmp-embed-placeholder {
    display: flex; align-items: center; justify-content: center;
    background: #eef2f7; border: 1px dashed #b6c2d2; border-radius: 10px;
    width: 100%; min-height: 220px; padding: 18px; text-align: center; color: #334155;
}
.cmp-embed-inner { max-width: 420px; }
.cmp-embed-ikon { font-size: 30px; line-height: 1; margin-bottom: 8px; color: #64748b; }
.cmp-embed-cim { font-weight: 700; margin: 0 0 4px; }
.cmp-embed-szoveg { font-size: 13.5px; margin: 0 0 12px; color: #475569; }
.cmp-embed-gomb { border: 0; border-radius: 9px; padding: 9px 16px; font-weight: 600; cursor: pointer; background: #0d6efd; color: #fff; min-height: 40px; }
.cmp-embed-gomb:hover { filter: brightness(1.08); }

/* ---- Footer újranyitó gomb ---- */
.ship-cmp-ujranyit {
    background: transparent; border: 1px solid currentColor; border-radius: 20px;
    padding: 5px 14px; font-size: 13px; cursor: pointer; opacity: .85;
    display: inline-flex; align-items: center; gap: 6px; color: inherit;
}
.ship-cmp-ujranyit:hover { opacity: 1; }

/* ---- Reszponzív ---- */
@media (max-width: 640px) {
    .cmp-banner { flex-direction: column; align-items: stretch; padding: 16px; }
    .cmp-banner-gombok { margin-top: 12px; }
    .cmp-banner-gombok .cmp-gomb { flex: 1 1 auto; }
    .cmp-reszletek { margin-left: 0; }
    .cmp-modal-lablec { justify-content: stretch; }
    .cmp-modal-lablec .cmp-gomb { flex: 1 1 auto; }
}
