/* Servercim SVG icon system */
.svg-sprite {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
}

.icon {
    display: inline-block;
    width: 1em;
    height: 1em;
    flex-shrink: 0;
    vertical-align: -0.125em;
    overflow: visible;
    color: inherit;
}

/* Sabit kare içindeki ikonlar — flex/grid ile ortalı kalsın */
.icon-cell {
    display: grid;
    place-items: center;
    line-height: 0;
}

.icon-cell > .icon,
.icon-cell > svg.icon {
    display: block;
    margin: 0;
    vertical-align: top;
}

.icon--fill {
    fill: currentColor;
    stroke: none;
}

.icon-xs { width: 0.625rem; height: 0.625rem; }
.icon-sm { width: 0.875rem; height: 0.875rem; }
.icon-md { width: 1rem; height: 1rem; }
.icon-lg { width: 1.25rem; height: 1.25rem; }
.icon-xl { width: 1.5rem; height: 1.5rem; }
.icon-2xl { width: 1.875rem; height: 1.875rem; }
.icon-3xl { width: 3rem; height: 3rem; }

.icon-box .icon,
.dropdown-item-complex .icon-box .icon {
    width: 1.15rem;
    height: 1.15rem;
}

.drawer-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.drawer-link .icon {
    width: 1rem;
    height: 1rem;
    padding: 8px;
    box-sizing: content-box;
    background: rgba(255, 255, 255, 0.02);
    border-radius: 8px;
    margin-right: 0;
}

.drawer-link:hover .icon {
    background: #ff8c00;
    color: #fff;
}

.social-icon-hybrid .icon {
    width: 1.125rem;
    height: 1.125rem;
}

.whatsapp-float {
    display: flex;
    align-items: center;
    justify-content: center;
}

.whatsapp-float .icon {
    width: 1.75rem;
    height: 1.75rem;
    color: #fff;
}

.campaign-card > .icon.bg-icon,
.campaign-card > .icon.icon-bg {
    position: absolute;
    right: -0.9375rem;
    bottom: -0.9375rem;
    width: 5rem;
    height: 5rem;
    opacity: 0.15;
    transform: rotate(-15deg);
    color: #fff;
}

.icon-decor {
    position: absolute;
    right: -2.5rem;
    bottom: -2.5rem;
    width: 12.5rem;
    height: 12.5rem;
    opacity: 0.05;
    color: currentColor;
}

.dropdown-item:hover .icon-box .icon {
    color: #fff;
}

.logo-mark {
    width: 2rem;
    height: 2rem;
    color: #ff8c00;
    flex-shrink: 0;
}

.btn-sepete-ekle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
}

.btn-sepete-ekle .icon {
    width: 0.875rem;
    height: 0.875rem;
}

/* Payment logos */
.payment-logos-final {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.payment-logo {
    display: block;
    height: 1.25rem;
    width: auto;
    color: #94a3b8;
    opacity: 0.8;
    transition: opacity 0.3s, color 0.3s;
    flex-shrink: 0;
}

.payment-logo--mc {
    width: 2.75rem;
    height: 1.75rem;
}

.payment-logo--iyz {
    width: 3.5rem;
    height: 1.25rem;
}

.payment-logo[aria-label="Visa"] {
    width: 3.5rem;
    height: 1.25rem;
}

.payment-logo[aria-label="Stripe"] {
    width: 3.25rem;
}

.payment-logo:hover {
    opacity: 1;
    color: #fff;
}

.payment-logo--mc:hover circle {
    opacity: 1;
}
