/* 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;
}
#buttonrebel.buttonrebel-bottom-left { align-items: flex-start; }
#buttonrebel * { box-sizing: border-box; }

/* ----- 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 — zawsze widoczny, bez marginesu i kółka */
#buttonrebel.buttonrebel-single .buttonrebel-items {
    opacity: 1;
    visibility: visible;
    transform: none;
    margin-bottom: 0;
}

#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;
    pointer-events: 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; }
}
@media (min-width: 769px) {
    #buttonrebel .buttonrebel-dev-mobile { display: none !important; }
}
