/* ButtonRebel — front-end (układ/animacje; kolory i rozmiary dokłada generowany CSS) */

#buttonrebel {
    position: fixed;
    z-index: 99990;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    /* Sam kontener jest przezroczysty i wysoki (ukryta lista nadal zajmuje miejsce).
       Wyłączamy na nim klikalność, by puste pole nad przyciskiem nie łapało dotknięć
       (i nie rozwijało listy na mobile). Klikalność włączamy tylko na realnych elementach. */
    pointer-events: none;
}
#buttonrebel.buttonrebel-bottom-left { align-items: flex-start; }
#buttonrebel * { box-sizing: border-box; }

/* Klikalne tylko faktyczne elementy interaktywne */
#buttonrebel .buttonrebel-main-wrap,
#buttonrebel.is-open .buttonrebel-items,
#buttonrebel .buttonrebel-panel.is-open { pointer-events: auto; }
/* Tryb hover tylko na urządzeniach z prawdziwym kursorem: kontener musi łapać
   kursor, by „mostek" najazdu między przyciskiem a listą nie zwijał menu po drodze.
   Na dotyku (hover: none) kontener zostaje nieklikalny — puste pole nie otwiera listy. */
@media (hover: hover) {
    #buttonrebel.buttonrebel-trigger-hover { pointer-events: auto; }
}

/* ----- Lista przycisków akcji ----- */
#buttonrebel .buttonrebel-items {
    list-style: none;
    margin: 0 0 12px 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: inherit;
    gap: 12px;
    order: 1;

    /* domyślnie schowane (tryb wielu przycisków) */
    opacity: 0;
    visibility: hidden;
    transform: translateY(16px);
    transition: opacity .25s ease, transform .25s ease, visibility .25s;
}
#buttonrebel.is-open .buttonrebel-items {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
/* Tryb pojedynczego przycisku (per urządzenie) — lista zawsze widoczna, bez kółka.
   Reguły rozstrzygane są w media queries na dole pliku (buttonrebel-desktop-single
   / buttonrebel-mobile-single), bo „pojedynczy" zależy od urządzenia. */

#buttonrebel .buttonrebel-item {
    position: relative;
    display: flex;
}

/* ----- Klikalny przycisk (ikona + opis jako jeden element) ----- */
#buttonrebel .buttonrebel-link {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    cursor: pointer;
    border: none;
    background: transparent;
    padding: 0;
    margin: 0;
    font: inherit;
}
/* Strona opisu względem ikony */
#buttonrebel.buttonrebel-label-left  .buttonrebel-link { flex-direction: row-reverse; }
#buttonrebel.buttonrebel-label-right .buttonrebel-link { flex-direction: row; }

#buttonrebel .buttonrebel-icon {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 3px 10px rgba(0, 0, 0, .22);
    transition: transform .15s ease, background-color .15s ease, color .15s ease;
}
#buttonrebel .buttonrebel-icon svg {
    width: 1em;
    height: 1em;
    fill: currentColor;
    display: block;
}
/* Hover: pauzujemy animację całego przycisku; ikona delikatnie się powiększa */
#buttonrebel .buttonrebel-link:hover {
    animation-play-state: paused;
}
#buttonrebel .buttonrebel-link:hover .buttonrebel-icon {
    transform: scale(1.1);
}

/* ----- Animacje (opcjonalne, per-przycisk) — mocny ruch + długa przerwa (rzadko) ----- */
@keyframes br-pulse {
    0%, 24%, 100% { transform: scale(1); }
    12% { transform: scale(1.2); }
}
@keyframes br-shake {
    0%, 26%, 100% { transform: translateX(0) rotate(0); }
    3%  { transform: translateX(-6px) rotate(-7deg); }
    6%  { transform: translateX(6px) rotate(7deg); }
    9%  { transform: translateX(-6px) rotate(-6deg); }
    12% { transform: translateX(6px) rotate(6deg); }
    15% { transform: translateX(-5px) rotate(-4deg); }
    18% { transform: translateX(5px) rotate(4deg); }
    21% { transform: translateX(-3px); }
    24% { transform: translateX(2px); }
}
@keyframes br-bounce {
    0%, 30%, 100% { transform: translateY(0); }
    8%  { transform: translateY(-18px); }
    16% { transform: translateY(0); }
    22% { transform: translateY(-9px); }
}
@keyframes br-swing {
    0%, 34%, 100% { transform: rotate(0); }
    7%  { transform: rotate(16deg); }
    14% { transform: rotate(-14deg); }
    21% { transform: rotate(10deg); }
    28% { transform: rotate(-5deg); }
}
@keyframes br-heartbeat {
    0%, 28%, 100% { transform: scale(1); }
    7%  { transform: scale(1.25); }
    14% { transform: scale(1); }
    21% { transform: scale(1.25); }
}
#buttonrebel .buttonrebel-anim-pulse     { animation: br-pulse 3s ease-in-out infinite; }
#buttonrebel .buttonrebel-anim-shake     { animation: br-shake 3.4s ease-in-out infinite; }
#buttonrebel .buttonrebel-anim-bounce    { animation: br-bounce 3.2s ease-in-out infinite; }
#buttonrebel .buttonrebel-anim-swing     { animation: br-swing 3.4s ease-in-out infinite; transform-origin: center top; }
#buttonrebel .buttonrebel-anim-heartbeat { animation: br-heartbeat 3.2s ease-in-out infinite; }

@media (prefers-reduced-motion: reduce) {
    #buttonrebel [class*="buttonrebel-anim-"] { animation: none !important; }
}

#buttonrebel .buttonrebel-label {
    padding: 5px 11px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .18);
    transition: background-color .15s ease, color .15s ease;
}

/* ----- Główny przycisk (tryb wielu) ----- */
/* Kontener głównego przycisku + jego opis — opis po stronie wg ustawienia */
#buttonrebel .buttonrebel-main-wrap {
    order: 2;
    display: flex;
    align-items: center;
    gap: 10px;
}
#buttonrebel.buttonrebel-label-left  .buttonrebel-main-wrap { flex-direction: row-reverse; }
#buttonrebel.buttonrebel-label-right .buttonrebel-main-wrap { flex-direction: row; }

#buttonrebel .buttonrebel-main {
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    padding: 0;
    position: relative;
    flex: 0 0 auto;
    box-shadow: 0 4px 14px rgba(0, 0, 0, .25);
    transition: transform .2s ease, box-shadow .2s ease;
}
#buttonrebel .buttonrebel-main:hover {
    transform: scale(1.06);
    box-shadow: 0 6px 18px rgba(0, 0, 0, .3);
}
#buttonrebel .buttonrebel-main svg { width: 1em; height: 1em; fill: currentColor; display: block; }

#buttonrebel .buttonrebel-main-icon,
#buttonrebel .buttonrebel-main-close { transition: opacity .2s ease, transform .2s ease; }
#buttonrebel .buttonrebel-main-close {
    position: absolute;
    opacity: 0;
    transform: rotate(-90deg);
    font-size: 20px;
}
#buttonrebel.is-open .buttonrebel-main-icon { opacity: 0; transform: rotate(90deg); }
#buttonrebel.is-open .buttonrebel-main-close { opacity: 1; transform: rotate(0deg); }

#buttonrebel .buttonrebel-main-label {
    background: rgba(0, 0, 0, .75);
    color: #fff;
    padding: 5px 11px;
    border-radius: 6px;
    font-size: 13px;
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
}

/* ----- Panel z dowolną treścią ----- */
#buttonrebel .buttonrebel-panel {
    position: absolute;
    bottom: 0;
    width: 300px;
    max-width: 80vw;
    background: #fff;
    color: #222;
    border-radius: 10px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, .28);
    padding: 18px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity .2s ease, transform .2s ease, visibility .2s;
}
#buttonrebel.buttonrebel-bottom-right .buttonrebel-panel { right: calc(100% + 14px); }
#buttonrebel.buttonrebel-bottom-left  .buttonrebel-panel { left: calc(100% + 14px); }
#buttonrebel .buttonrebel-panel.is-open { opacity: 1; visibility: visible; transform: translateY(0); }

#buttonrebel .buttonrebel-panel-close {
    position: absolute;
    top: 6px; right: 8px;
    border: none; background: transparent;
    font-size: 16px; cursor: pointer; color: #888; line-height: 1;
}
#buttonrebel .buttonrebel-panel-content { font-size: 14px; line-height: 1.55; }
#buttonrebel .buttonrebel-panel-content :first-child { margin-top: 0; }
#buttonrebel .buttonrebel-panel-content :last-child { margin-bottom: 0; }

@media (max-width: 600px) {
    #buttonrebel .buttonrebel-panel {
        position: fixed;
        left: 12px; right: 12px; bottom: 90px;
        width: auto; max-width: none;
    }
}

/* ----- Widoczność wg urządzenia (próg 768px) ----- */
@media (max-width: 768px) {
    #buttonrebel .buttonrebel-dev-desktop { display: none !important; }

    /* Mobile: pojedynczy przycisk — lista zawsze widoczna, bez głównego kółka */
    #buttonrebel.buttonrebel-mobile-single .buttonrebel-items {
        opacity: 1;
        visibility: visible;
        transform: none;
        margin-bottom: 0;
        pointer-events: auto;
    }
    #buttonrebel.buttonrebel-mobile-single .buttonrebel-main-wrap { display: none; }

    /* Mobile: brak przycisków na tym urządzeniu — nie pokazuj nic */
    #buttonrebel.buttonrebel-mobile-empty .buttonrebel-items,
    #buttonrebel.buttonrebel-mobile-empty .buttonrebel-main-wrap { display: none; }
}
@media (min-width: 769px) {
    #buttonrebel .buttonrebel-dev-mobile { display: none !important; }

    /* Desktop: pojedynczy przycisk — lista zawsze widoczna, bez głównego kółka */
    #buttonrebel.buttonrebel-desktop-single .buttonrebel-items {
        opacity: 1;
        visibility: visible;
        transform: none;
        margin-bottom: 0;
        pointer-events: auto;
    }
    #buttonrebel.buttonrebel-desktop-single .buttonrebel-main-wrap { display: none; }

    /* Desktop: brak przycisków na tym urządzeniu — nie pokazuj nic */
    #buttonrebel.buttonrebel-desktop-empty .buttonrebel-items,
    #buttonrebel.buttonrebel-desktop-empty .buttonrebel-main-wrap { display: none; }
}

/* =====================================================================
 *  Pływające social media (dodatek, niezależny od FAB)
 * ===================================================================== */
#buttonrebel-social {
    position: fixed;
    z-index: 99989;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
#buttonrebel-social.buttonrebel-social-left  { left: 0; }
#buttonrebel-social.buttonrebel-social-right { right: 0; }
#buttonrebel-social * { box-sizing: border-box; }

/* Lista ikon — osobny kontener, by można ją było zwinąć strzałką */
#buttonrebel-social .buttonrebel-social-items {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    max-height: 85vh;
    opacity: 1;
    transition: max-height .3s ease, opacity .2s ease;
}
#buttonrebel-social.is-collapsed .buttonrebel-social-items {
    max-height: 0;
    opacity: 0;
    pointer-events: none;
}

/* Strzałka zwijająca/rozwijająca — nad listą ikon */
#buttonrebel-social .buttonrebel-social-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    padding: 0;
    border: 0;
    line-height: 1;
    cursor: pointer;
    color: #fff;
    background: #3a3a3a;
    transition: filter .15s ease;
}
#buttonrebel-social .buttonrebel-social-toggle .buttonrebel-social-icon { display: flex; }
#buttonrebel-social .buttonrebel-social-toggle svg {
    width: 1em; height: 1em;
    fill: currentColor;
    display: block;
}
#buttonrebel-social .buttonrebel-social-toggle:hover { filter: brightness(1.15); }
/* Otwarty panel → „X" (ukryj); zwinięty → „+" (pokaż).
   Selektory zawierają .buttonrebel-social-toggle, by przebić regułę display:flex powyżej. */
#buttonrebel-social .buttonrebel-social-toggle .buttonrebel-social-ico-open  { display: none; }
#buttonrebel-social.is-collapsed .buttonrebel-social-toggle .buttonrebel-social-ico-close { display: none; }
#buttonrebel-social.is-collapsed .buttonrebel-social-toggle .buttonrebel-social-ico-open  { display: flex; }

#buttonrebel-social .buttonrebel-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    text-decoration: none;
    color: #fff;
    background: #555;
    transition: transform .15s ease, filter .15s ease;
}
#buttonrebel-social .buttonrebel-social-icon { display: flex; }
#buttonrebel-social .buttonrebel-social-icon svg { width: 1em; height: 1em; fill: currentColor; display: block; }
#buttonrebel-social .buttonrebel-social-link:hover { filter: brightness(1.12); z-index: 1; }

/* Kwadraty / zaokrąglone — przyklejone do krawędzi, bez odstępów */
#buttonrebel-social.buttonrebel-social-shape-square  .buttonrebel-social-link,
#buttonrebel-social.buttonrebel-social-shape-square  .buttonrebel-social-toggle,
#buttonrebel-social.buttonrebel-social-shape-rounded .buttonrebel-social-link,
#buttonrebel-social.buttonrebel-social-shape-rounded .buttonrebel-social-toggle {
    box-shadow: -2px 0 8px rgba(0, 0, 0, .12);
}
#buttonrebel-social.buttonrebel-social-left.buttonrebel-social-shape-square  .buttonrebel-social-link,
#buttonrebel-social.buttonrebel-social-left.buttonrebel-social-shape-square  .buttonrebel-social-toggle,
#buttonrebel-social.buttonrebel-social-left.buttonrebel-social-shape-rounded .buttonrebel-social-link,
#buttonrebel-social.buttonrebel-social-left.buttonrebel-social-shape-rounded .buttonrebel-social-toggle {
    box-shadow: 2px 0 8px rgba(0, 0, 0, .12);
}
/* Zaokrąglenie narożników od strony wnętrza ekranu — góra na strzałce, dół na ostatniej ikonie */
#buttonrebel-social.buttonrebel-social-shape-rounded.buttonrebel-social-right .buttonrebel-social-toggle               { border-top-left-radius: 10px; }
#buttonrebel-social.buttonrebel-social-shape-rounded.buttonrebel-social-right .buttonrebel-social-link:last-child      { border-bottom-left-radius: 10px; }
#buttonrebel-social.buttonrebel-social-shape-rounded.buttonrebel-social-left  .buttonrebel-social-toggle               { border-top-right-radius: 10px; }
#buttonrebel-social.buttonrebel-social-shape-rounded.buttonrebel-social-left  .buttonrebel-social-link:last-child      { border-bottom-right-radius: 10px; }
/* Po zwinięciu strzałka jest jedynym widocznym kafelkiem — zaokrąglamy też jej dół */
#buttonrebel-social.is-collapsed.buttonrebel-social-shape-rounded.buttonrebel-social-right .buttonrebel-social-toggle { border-bottom-left-radius: 10px; }
#buttonrebel-social.is-collapsed.buttonrebel-social-shape-rounded.buttonrebel-social-left  .buttonrebel-social-toggle { border-bottom-right-radius: 10px; }

/* Kółka — z odstępem, lekko odsunięte od krawędzi */
#buttonrebel-social.buttonrebel-social-shape-circle { gap: 8px; }
#buttonrebel-social.buttonrebel-social-shape-circle .buttonrebel-social-items { gap: 8px; }
#buttonrebel-social.buttonrebel-social-shape-circle.buttonrebel-social-right { right: 10px; }
#buttonrebel-social.buttonrebel-social-shape-circle.buttonrebel-social-left  { left: 10px; }
#buttonrebel-social.buttonrebel-social-shape-circle .buttonrebel-social-link,
#buttonrebel-social.buttonrebel-social-shape-circle .buttonrebel-social-toggle {
    border-radius: 50%;
    box-shadow: 0 3px 10px rgba(0, 0, 0, .25);
}
#buttonrebel-social.buttonrebel-social-shape-circle .buttonrebel-social-link:hover { transform: scale(1.1); }
/* Po zwinięciu (kółka) usuwamy odstęp pod strzałką, by nie zostawała pusta przerwa */
#buttonrebel-social.is-collapsed.buttonrebel-social-shape-circle { gap: 0; }

/* Widoczność wg urządzenia (próg 768px) */
@media (max-width: 768px) {
    #buttonrebel-social.buttonrebel-dev-desktop { display: none !important; }
}
@media (min-width: 769px) {
    #buttonrebel-social.buttonrebel-dev-mobile { display: none !important; }
}
