/* assets/css/components/_radial-menu.css */

/* Base style: hidden by default */
.radial-menu {
    display: none;
    position: fixed;
    bottom: 6rem; /* 96px - Aumentado para não sobrepor o botão do WhatsApp */
    right: 1.5rem;  /* 24px */
    z-index: 30;
}

/* Show on mobile screens */
@media (max-width: 767px) {
    .radial-menu {
        display: block !important; /* Usado para garantir a sobreposição de outros estilos */
    }
}

/* Botão principal (FAB) */
#radial-menu-btn {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, #A367FF, #CB99FF);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3), 0 0 20px rgba(179, 117, 255, 0.7);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    position: relative;
    z-index: 31; /* Acima dos itens do menu */
}

#radial-menu-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.4), 0 0 30px rgba(179, 117, 255, 0.9);
}

/* Ícone dentro do botão principal (será um + e um X) */
#radial-menu-icon {
    width: 24px;
    height: 24px;
    position: relative;
}

#radial-menu-icon .icon-bar {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 3px;
    background-color: #040308;
    border-radius: 2px;
    transition: transform 0.3s ease;
    transform-origin: center;
}

#radial-menu-icon .icon-bar.horizontal {
    transform: translate(-50%, -50%) rotate(0deg);
}

#radial-menu-icon .icon-bar.vertical {
    transform: translate(-50%, -50%) rotate(90deg);
}

/* Animação do ícone para 'X' quando o menu está ativo */
.radial-menu.active #radial-menu-icon .icon-bar.horizontal {
    transform: translate(-50%, -50%) rotate(135deg);
}

.radial-menu.active #radial-menu-icon .icon-bar.vertical {
    transform: translate(-50%, -50%) rotate(45deg);
}


/* Container para os itens do menu */
.radial-menu-items {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 56px;
    height: 56px;
    pointer-events: none; /* Não interfere com o botão principal quando fechado */
    transition: transform 0.3s ease;
    transform-origin: bottom right;
}

/* Item individual do menu */
.radial-menu-item {
    position: absolute;
    bottom: 0;
    right: 0;
    width: auto; /* Largura automática */
    height: 44px; /* Aumenta a altura */
    padding: 0 16px 0 12px; /* Espaçamento interno */
    border-radius: 22px; /* Borda arredondada */
    background-color: #F9F6F2;
    color: #040308;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px; /* Espaço entre ícone e texto */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease;
    opacity: 0;
    transform: translate(0, 0);
    pointer-events: none;
    white-space: nowrap; /* Impede que o texto quebre a linha */
}

/* Texto do item */
.radial-menu-item-text {
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
}

/* Item destacado ("Assinar") */
.radial-menu-item.highlighted {
    background: linear-gradient(135deg, #A367FF, #CB99FF);
    color: #040308;
}

/* Quando o menu está ativo, torna os itens clicáveis e visíveis */
.radial-menu.active .radial-menu-items {
    pointer-events: auto;
}

.radial-menu.active .radial-menu-item {
    opacity: 1;
    pointer-events: auto;
}

/* Posições dos itens quando o menu está aberto (agora vertical) */
.radial-menu.active .radial-menu-item:nth-child(1) { /* Assinar */
    transform: translateY(-60px);
    transition-delay: 0.15s;
}

.radial-menu.active .radial-menu-item:nth-child(2) { /* Plano */
    transform: translateY(-115px);
    transition-delay: 0.1s;
}

.radial-menu.active .radial-menu-item:nth-child(3) { /* Login */
    transform: translateY(-170px);
    transition-delay: 0.05s;
}

/* Estilo para o ícone SVG dentro dos itens */
.radial-menu-item svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0; /* Impede que o ícone encolha */
}
