/* ============================================
   Pretpot Icon Group Widget
   ============================================ */

.pretpot-icon-group {
    display: flex;
    flex-wrap: wrap;
    position: relative;
}

/* Alignment */
.pretpot-icon-group-align-left { justify-content: flex-start; }
.pretpot-icon-group-align-center { justify-content: center; }
.pretpot-icon-group-align-right { justify-content: flex-end; }
.pretpot-icon-group-align-space-between { justify-content: space-between; }
.pretpot-icon-group-align-space-around { justify-content: space-around; }
.pretpot-icon-group-align-space-evenly { justify-content: space-evenly; }

/* Heading */
.pretpot-icon-group-heading {
    width: 100%;
    margin-bottom: 20px;
}

.pretpot-icon-group-heading-align-left { text-align: left; }
.pretpot-icon-group-heading-align-center { text-align: center; }
.pretpot-icon-group-heading-align-right { text-align: right; }

/* Icon Item */
.pretpot-icon-group-item {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateY(20px);
}

.pretpot-icon-group-item.pretpot-icon-visible {
    opacity: 1;
    transform: translateY(0);
}

.pretpot-icon-group-item-inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

/* Icon SVG / i */
.pretpot-icon-group-item i,
.pretpot-icon-group-item svg {
    position: relative;
    z-index: 2;
    transition: all 0.3s ease;
}

/* ============================================
   STYLE: NO BORDER (Icons Only)
   ============================================ */
.pretpot-icon-group-style-none .pretpot-icon-group-item {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

/* ============================================
   STYLE: NORMAL BACKGROUND
   ============================================ */
.pretpot-icon-group-style-normal .pretpot-icon-group-item {
    background: var(--pretpot-icon-bg, rgba(0,0,0,0.05));
    border: var(--pretpot-border-width, 0px) solid var(--pretpot-icon-border-color, transparent);
}

/* ============================================
   STYLE: MINIMAL (Inset Border)
   ============================================ */
.pretpot-icon-group-style-minimal .pretpot-icon-group-item {
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    -webkit-backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    border: var(--pretpot-border-width, 1px) solid rgba(255,255,255,0.15);
    box-shadow:
        inset 0 1px 1px rgba(255,255,255,0.1),
        0 8px 32px rgba(0,0,0,0.2);
}

.pretpot-icon-group-style-minimal .pretpot-icon-group-item::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(135deg, rgba(255,255,255,0.2), rgba(255,255,255,0.05));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    border-radius: inherit;
}

/* ============================================
   STYLE: SOFT (Frosted + Warm Glow)
   ============================================ */
.pretpot-icon-group-style-soft .pretpot-icon-group-item {
    background: rgba(255,255,255,0.03);
    backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    -webkit-backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    border: var(--pretpot-border-width, 2px) solid rgba(255,255,255,0.25);
    box-shadow:
        0 0 0 var(--pretpot-border-width, 2px) rgba(255,255,255,0.05),
        0 0 var(--pretpot-glow-spread, 40px) var(--pretpot-glow-color, rgba(255,154,158,0.3)),
        0 0 var(--pretpot-glow-spread-2, 80px) var(--pretpot-glow-color, rgba(250,208,196,0.2));
}

/* ============================================
   STYLE: BOLD (Neon Border + Cyan Glow)
   ============================================ */
.pretpot-icon-group-style-bold .pretpot-icon-group-item {
    background: rgba(255,255,255,0.05);
    backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    -webkit-backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    border: var(--pretpot-border-width, 1px) solid var(--pretpot-glow-color, rgba(0,242,254,0.5));
    box-shadow:
        0 0 var(--pretpot-glow-spread, 20px) var(--pretpot-glow-color, rgba(0,242,254,0.2)),
        0 0 var(--pretpot-glow-spread-2, 50px) var(--pretpot-glow-color, rgba(0,242,254,0.3)),
        0 0 var(--pretpot-glow-spread-3, 100px) var(--pretpot-glow-color, rgba(0,242,254,0.1));
}

/* ============================================
   STYLE: PREMIUM (Gradient Border + Aura Glow)
   ============================================ */
.pretpot-icon-group-style-premium .pretpot-icon-group-item {
    background: rgba(255,255,255,0.05);
    backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    -webkit-backdrop-filter: blur(var(--pretpot-blur-intensity, 20px));
    position: relative;
    border: none;
}

.pretpot-icon-group-style-premium .pretpot-icon-group-item::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: var(--pretpot-border-width, 1.5px);
    background: linear-gradient(135deg, rgba(255,255,255,0.6), rgba(255,255,255,0.1));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    border-radius: inherit;
}

.pretpot-icon-group-style-premium .pretpot-icon-group-item {
    box-shadow:
        0 0 var(--pretpot-glow-spread, 40px) var(--pretpot-glow-color, rgba(102,126,234,0.35)),
        0 0 var(--pretpot-glow-spread-2, 80px) var(--pretpot-glow-color, rgba(102,126,234,0.15));
}

/* ============================================
   GLOW LOCATION
   ============================================ */
.pretpot-glow-behind .pretpot-icon-group-item {
    z-index: 1;
}

.pretpot-glow-behind .pretpot-icon-group-item::after {
    content: '';
    position: absolute;
    inset: -10px;
    border-radius: inherit;
    background: radial-gradient(ellipse at center, var(--pretpot-glow-color, rgba(102,126,234,0.4)) 0%, transparent 70%);
    opacity: var(--pretpot-glow-intensity, 0.5);
    z-index: -1;
    pointer-events: none;
    filter: blur(var(--pretpot-glow-spread, 20px));
}

.pretpot-glow-center .pretpot-icon-group-item::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(ellipse at center, var(--pretpot-glow-color, rgba(102,126,234,0.3)) 0%, transparent 60%);
    opacity: var(--pretpot-glow-intensity, 0.5);
    z-index: 0;
    pointer-events: none;
}

.pretpot-glow-bottom .pretpot-icon-group-item::after {
    content: '';
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 30px;
    border-radius: 50%;
    background: radial-gradient(ellipse at center, var(--pretpot-glow-color, rgba(102,126,234,0.4)) 0%, transparent 70%);
    opacity: var(--pretpot-glow-intensity, 0.5);
    z-index: -1;
    pointer-events: none;
    filter: blur(var(--pretpot-glow-spread, 15px));
}

.pretpot-glow-top .pretpot-icon-group-item::after {
    content: '';
    position: absolute;
    top: -15px;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 30px;
    border-radius: 50%;
    background: radial-gradient(ellipse at center, var(--pretpot-glow-color, rgba(102,126,234,0.4)) 0%, transparent 70%);
    opacity: var(--pretpot-glow-intensity, 0.5);
    z-index: -1;
    pointer-events: none;
    filter: blur(var(--pretpot-glow-spread, 15px));
}

/* ============================================
   HOVER EFFECTS
   ============================================ */
.pretpot-icon-group-item:hover {
    transform: translateY(-5px) scale(1.05);
}

.pretpot-icon-group-style-none .pretpot-icon-group-item:hover {
    transform: scale(1.15);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 767px) {
    .pretpot-icon-group-heading {
        margin-bottom: 15px;
    }
}