/* Sagitta Chat Widget - BuddyBoss Compatible Styles */
/* High specificity to override theme styles and prevent conflicts */

/* Reset any conflicting styles from other CSS files */
.chat-window:not(.chat-widget.sagitta-chat-widget .chat-window) {
    display: none !important;
}

/* Hide any generic chat widgets that don't have our specific class */
.chat-widget:not(.sagitta-chat-widget) {
    display: none !important;
}

/* Ensure only our widget is visible */
.chat-trigger:not(.chat-widget.sagitta-chat-widget .chat-trigger) {
    display: none !important;
}



/* Widget Container */
.chat-widget.sagitta-chat-widget {
    position: fixed !important;
    bottom: 20px !important;
    right: 20px !important;
    z-index: 9999 !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    color: #333 !important;
    box-sizing: border-box !important;
}

.chat-widget.sagitta-chat-widget * {
    box-sizing: border-box !important;
}

.chat-widget.sagitta-chat-widget.position-left {
    left: 20px !important;
}

/* UNIFIED CHAT TRIGGER CONTAINER - SINGLE ELEMENT */
.chat-widget.sagitta-chat-widget .chat-trigger-container {
    position: relative !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: flex-end !important;
    gap: 12px !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Main Chat Button - Part of unified element */
.chat-widget.sagitta-chat-widget .chat-trigger {
    width: 85px !important;
    height: 85px !important;
    background: linear-gradient(135deg, var(--sagitta-primary-color, #e91e63), var(--sagitta-secondary-color, #9c27b0)) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    box-shadow: 0 8px 25px rgba(233, 30, 99, 0.4) !important;
    transition: all 0.3s ease !important;
    border-top-style: none !important;
    border-right-style: none !important;
    border-bottom-style: none !important;
    border-left-style: none !important;
    position: relative !important;
    overflow: visible !important;
    font-size: 16px !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    outline: none !important;
    margin: 0 !important;
    padding: 0 !important;
    top: 5px !important;
}

.chat-widget.sagitta-chat-widget .chat-trigger-container:hover .chat-trigger {
    transform: scale(1.1) !important;
    box-shadow: 0 12px 35px rgba(233, 30, 99, 0.6) !important;
}

.chat-widget.sagitta-chat-widget .chat-trigger-container:active .chat-trigger {
    transform: scale(0.95) !important;
}

/* Chat Trigger Content */
.chat-widget.sagitta-chat-widget .chat-trigger-content {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Chat Trigger Image */
.chat-widget.sagitta-chat-widget .chat-trigger-content img {
    border-style: solid !important;
    border-width: 4px !important;
}

/* Status Indicator (Green Dot) */
.chat-widget.sagitta-chat-widget .status-indicator {
    position: absolute !important;
    bottom: 5px !important;
    right: 5px !important;
    width: 16px !important;
    height: 16px !important;
    background-color: #00C853 !important;
    border: 3px solid white !important;
    border-radius: 50% !important;
    z-index: 10 !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2) !important;
	overflow: visible !important;
}

.chat-widget.sagitta-chat-widget .chat-trigger::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: linear-gradient(45deg, rgba(255,255,255,0.1), transparent) !important;
    border-radius: 50% !important;
}

.chat-widget.sagitta-chat-widget .chat-icon {
    width: 35px !important;
    height: 35px !important;
    fill: white !important;
    z-index: 1 !important;
}

.chat-widget.sagitta-chat-widget .chat-trigger-avatar {
    width: 100% !important;
    height: 100% !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    z-index: 1 !important;
}

/* Notification Bubble - Integrated in unified element */
.chat-widget.sagitta-chat-widget .notification-bubble {
    position: relative !important;
    max-width: 320px !important;
    padding: 25px 25px 18px 25px !important;
    padding-top: 20px !important;
    background-color: #fff !important;
    color: #333 !important;
    border-radius: 14px !important;
    font-size: 19px !important;
    line-height: 1.4 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    font-weight: 500 !important;
    margin: 0 !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
    opacity: 1 !important;
    animation: slideInBubble 0.6s ease forwards !important;
    animation-delay: 1s !important;
}

/* Removed old notification-widget styles - now unified */

.chat-widget.sagitta-chat-widget .notification-bubble {
    position: relative !important;
    max-width: 294px !important
    padding: 14px 18px !important;
    background-color: #fff !important;
    color: #333 !important;
    font-size: 22px !important;
    line-height: 1.4 !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    font-weight: 500 !important;
    margin: 0 !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
}

.chat-widget.sagitta-chat-widget .notification-bubble strong {
    font-weight: 600 !important;
}

.chat-widget.sagitta-chat-widget .notification-emoji {
    margin-left: 4px !important;
}

.chat-widget.sagitta-chat-widget .notification-tail {
    position: absolute !important;
    right: -8px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    border-width: 8px 0 8px 8px !important;
    border-style: solid !important;
    border-color: transparent transparent transparent #fff !important;
    filter: drop-shadow(2px 0 2px rgba(0,0,0,0.08)) !important;
}

.chat-widget.sagitta-chat-widget.position-left .notification-tail {
    right: auto !important;
    left: -8px !important;
    border-width: 8px 8px 8px 0 !important;
    border-color: transparent #fff transparent transparent !important;
    filter: drop-shadow(-2px 0 2px rgba(0,0,0,0.08)) !important;
}

/* Chat Window */
.chat-widget.sagitta-chat-widget .chat-window {
    position: absolute !important;
    bottom: 105px !important;
    right: 0 !important;
    width: 650px !important;
    min-height: 200px !important;
    max-height: 650px !important;
    background: white !important;
    border-radius: 20px !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3) !important;
    opacity: 0 !important;
    transform: translateY(20px) scale(0.9) !important;
    transition: all 0.3s ease !important;
    overflow: hidden !important;
    display: none !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 0 !important;
}

.chat-widget.sagitta-chat-widget.position-left .chat-window {
    right: auto !important;
    left: 0 !important;
}

.chat-widget.sagitta-chat-widget .chat-window.active {
    opacity: 1 !important;
    transform: translateY(0) scale(1) !important;
    display: flex !important;
}



/* Chat Header */
.chat-widget.sagitta-chat-widget .chat-header {
    background: linear-gradient(135deg, #e91e63, #9c27b0) !important;
    padding: 20px !important;
    color: white !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
}

.chat-widget.sagitta-chat-widget .chat-header h3 {
    font-size: 18px !important;
    font-weight: 600 !important;
    margin: 0 !important;
    padding: 0 !important;
    color: white !important;
    font-family: inherit !important;
}

.chat-widget.sagitta-chat-widget .chat-header .status {
    font-size: 12px !important;
    opacity: 0.9 !important;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: white !important;
}

.chat-widget.sagitta-chat-widget .status-dot {
    width: 8px !important;
    height: 8px !important;
    background: #4caf50 !important;
    border-radius: 50% !important;
    animation: pulse 2s infinite !important;
    margin: 0 !important;
}

.chat-widget.sagitta-chat-widget .chat-info {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.chat-widget.sagitta-chat-widget .chat-avatar {
    width: 45px !important;
    height: 45px !important;
    background: rgba(255,255,255,0.2) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 20px !important;
    backdrop-filter: blur(10px) !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.chat-widget.sagitta-chat-widget .chat-avatar img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
}

.chat-widget.sagitta-chat-widget .close-btn {
    background: none !important;
    border: none !important;
    color: white !important;
    font-size: 24px !important;
    cursor: pointer !important;
    width: 30px !important;
    height: 30px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.2s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    outline: none !important;
}

.chat-widget.sagitta-chat-widget .close-btn:hover {
    background: rgba(255,255,255,0.2) !important;
}

/* Chat Messages */
.chat-widget.sagitta-chat-widget .chat-messages {
    flex: 1 !important;
    padding: 20px !important;
    overflow-y: auto !important;
    max-height: 400px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
    margin: 0 !important;
}

.chat-widget.sagitta-chat-widget .message {
    display: flex !important;
    background-color: white !important;
    align-items: flex-start !important;
    gap: 10px !important;
    animation: slideInMessage 0.4s ease !important;
    margin: 0 !important;
    padding: 0 !important;
}

.chat-widget.sagitta-chat-widget .message.user {
    flex-direction: row-reverse !important;
}

.chat-widget.sagitta-chat-widget .message-avatar {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, #e91e63, #9c27b0) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 14px !important;
    color: white !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.chat-widget.sagitta-chat-widget .message-avatar img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
}

.chat-widget.sagitta-chat-widget .message.user .message-avatar {
    background: linear-gradient(135deg, #2196f3, #21cbf3) !important;
}

.chat-widget.sagitta-chat-widget .message-content {
    background: #f5f5f5 !important;
    padding: 14px 18px !important;
    border-radius: 18px !important;
    max-width: 100% !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    position: relative !important;
    margin: 0 !important;
    color: #333 !important;
    font-family: inherit !important;
}

.chat-widget.sagitta-chat-widget .message.user .message-content {
    background: linear-gradient(135deg, #e91e63, #9c27b0) !important;
    color: white !important;
}

.chat-widget.sagitta-chat-widget .message-content::before {
    content: '' !important;
    position: absolute !important;
    top: 10px !important;
    left: -8px !important;
    width: 0 !important;
    height: 0 !important;
    border-top: 8px solid transparent !important;
    border-bottom: 8px solid transparent !important;
    border-right: 8px solid #f5f5f5 !important;
}

.chat-widget.sagitta-chat-widget .message.user .message-content::before {
    left: auto !important;
    right: -8px !important;
    border-left: 8px solid #e91e63 !important;
    border-right: none !important;
    border-top: 8px solid transparent !important;
    border-bottom: 8px solid transparent !important;
}

/* WhatsApp Phone Input */
.chat-widget.sagitta-chat-widget .whatsapp-input-container {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    margin: 10px 0 !important;
    padding: 0 !important;
}

.chat-widget.sagitta-chat-widget .country-select {
    background: white !important;
    border: 2px solid #eee !important;
    border-radius: 8px !important;
    padding: 8px !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color 0.2s ease !important;
    width: 80px !important;
    margin: 0 !important;
    font-family: inherit !important;
    color: #333 !important;
}

.chat-widget.sagitta-chat-widget .country-select:focus {
    border-color: #e91e63 !important;
}

.chat-widget.sagitta-chat-widget .phone-input {
    flex: 1 !important;
    border: 2px solid #eee !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color 0.2s ease !important;
    margin: 0 !important;
    font-family: inherit !important;
    color: #333 !important;
    background: white !important;
}

.chat-widget.sagitta-chat-widget .phone-input:focus {
    border-color: #e91e63 !important;
}

/* Email Input */
.chat-widget.sagitta-chat-widget .email-input {
    width: 100% !important;
    border: 2px solid #eee !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color 0.3s ease !important;
    font-family: inherit !important;
    color: #333 !important;
    background: white !important;
}

.chat-widget.sagitta-chat-widget .email-input:focus {
    border-color: #e91e63 !important;
}

/* Chat Input */
.chat-widget.sagitta-chat-widget .chat-input {
    padding: 20px !important;
    border-top: 1px solid #eee !important;
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    background: white !important;
}

.chat-widget.sagitta-chat-widget #messageInput {
    flex: 1 !important;
    border: 2px solid #eee !important;
    border-radius: 25px !important;
    padding: 12px 18px !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color 0.2s ease !important;
    margin: 0 !important;
    font-family: inherit !important;
    color: #333 !important;
    background: white !important;
}

.chat-widget.sagitta-chat-widget #messageInput:focus {
    border-color: #e91e63 !important;
}

#messageInput:disabled {
    background-color: #f5f5f5 !important;
    color: #999 !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
}

#messageInput:disabled::placeholder {
    color: #999 !important;
    font-style: italic !important;
}

.chat-widget.sagitta-chat-widget .send-btn {
    width: 45px !important;
    height: 45px !important;
    background: #e91e63 !important;
    border: none !important;
    border-radius: 50% !important;
    color: white !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    outline: none !important;
}

/* WhatsApp Input Send Button */
.chat-widget.sagitta-chat-widget #whatsappInputMessage .send-btn {
    width: 100% !important;
    border-radius: 20px !important;
    height: 40px !important;
}

.chat-widget.sagitta-chat-widget .send-btn:hover {
    background: #9c27b0 !important;
    transform: scale(1.05) !important;
}

.chat-widget.sagitta-chat-widget .send-btn:active {
    transform: scale(0.95) !important;
}

.chat-widget.sagitta-chat-widget .send-btn:disabled {
    background: #ccc !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
    transform: none !important;
}

.chat-widget.sagitta-chat-widget .send-btn:disabled:hover {
    background: #ccc !important;
    transform: none !important;
}

/* WhatsApp Button */
.chat-widget.sagitta-chat-widget .whatsapp-btn {
    background: linear-gradient(135deg, #25d366, #128c7e) !important;
    color: white !important;
    border: none !important;
    padding: 12px 24px !important;
    border-radius: 25px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 10px 0 !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
    font-family: inherit !important;
    outline: none !important;
    width: 100% !important;
    justify-content: center !important;
}

.chat-widget.sagitta-chat-widget .whatsapp-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(37, 211, 102, 0.4) !important;
    color: white !important;
    text-decoration: none !important;
}

/* Typing Indicator */
.chat-widget.sagitta-chat-widget .typing-indicator {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 12px 16px !important;
    background: #f5f5f5 !important;
    border-radius: 18px !important;
    margin-left: 42px !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    margin-right: 0 !important;
}

.chat-widget.sagitta-chat-widget .typing-dot {
    width: 8px !important;
    height: 8px !important;
    background: #999 !important;
    border-radius: 50% !important;
    animation: typing 1.4s infinite !important;
    margin: 0 !important;
}

.chat-widget.sagitta-chat-widget .typing-dot:nth-child(2) {
    animation-delay: 0.2s !important;
}

.chat-widget.sagitta-chat-widget .typing-dot:nth-child(3) {
    animation-delay: 0.4s !important;
}

/* Animations */
@keyframes slideInBubble {
    to {
        opacity: 1 !important;
        transform: translateY(0) scale(1) !important;
    }
}

@keyframes slideInMessage {
    from {
        opacity: 0 !important;
        transform: translateY(10px) !important;
    }
    to {
        opacity: 1 !important;
        transform: translateY(0) !important;
    }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1 !important;
    }
    50% {
        opacity: 0.5 !important;
    }
}

@keyframes typing {
    0%, 60%, 100% {
        transform: translateY(0) !important;
    }
    30% {
        transform: translateY(-10px) !important;
    }
}

/* Tablet responsive */
@media (min-width: 481px) and (max-width: 768px) {
    .chat-widget.sagitta-chat-widget .chat-window.active,
    .chat-widget.sagitta-chat-widget .chat-window {

        transform: none !important;
        margin: 0 !important;
    }

    .chat-widget.sagitta-chat-widget.position-left .chat-window.active,
    .chat-widget.sagitta-chat-widget.position-left .chat-window {
        left: 20px !important;
        right: auto !important;
    }
}

/* Mobile Responsive - Clean and Simple */
@media (max-width: 768px) {
    .chat-widget.sagitta-chat-widget .chat-window.active,
    .chat-widget.sagitta-chat-widget .chat-window {
        width: calc(100vw - 20px) !important;

        max-height: calc(100vh - 140px) !important;
        margin: 0 !important;
        margin-left: calc(-50vw + 10px) !important;
        transform: none !important;
        position: absolute !important;
    }

    .chat-widget.sagitta-chat-widget.position-left .chat-window.active,
    .chat-widget.sagitta-chat-widget.position-left .chat-window {
        margin-left: calc(-50vw + 10px) !important;
        transform: none !important;
    }

    /* Unified element - no separate notification-widget needed */

    .chat-widget.sagitta-chat-widget .notification-bubble {
        max-width: 220px !important;
        font-size: 15px !important;
        padding: 12px 16px !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }

    .chat-widget.sagitta-chat-widget .message-content {
        max-width: calc(100% - 60px) !important;
    }

    .chat-widget.sagitta-chat-widget .chat-messages {
        padding: 15px !important;
        max-height: calc(100vh - 300px) !important;
    }

    .chat-widget.sagitta-chat-widget .whatsapp-input-container {
        flex-direction: column !important;
        gap: 8px !important;
    }

    .chat-widget.sagitta-chat-widget .country-select {
        width: 100% !important;
    }
}

/* 765px and smaller screen sizes */
@media (max-width: 765px) {
    .chat-widget.sagitta-chat-widget .notification-bubble {
        font-size: 14px !important;
    }
}

/* Small mobile devices */
@media (max-width: 480px) {
    .chat-widget.sagitta-chat-widget {
        bottom: 15px !important;
        right: 15px !important;
    }

    .chat-widget.sagitta-chat-widget.position-left {
        left: 15px !important;
        right: auto !important;
    }

    .chat-widget.sagitta-chat-widget .chat-trigger {
        width: 70px !important;
        height: 70px !important;
    }

    .chat-widget.sagitta-chat-widget .notification-bubble {
        max-width: 200px !important;
        font-size: 12px !important;
        padding: 10px 14px !important;
    }

    .chat-widget.sagitta-chat-widget .chat-window.active,
    .chat-widget.sagitta-chat-widget .chat-window {
        width: calc(100vw - 15px) !important;
        max-width: none !important;
        margin-left: calc(-50vw + 7.5px) !important;
        bottom: 95px !important;
        max-height: calc(100vh - 120px) !important;
    }
}



/* Extra small screens - ensure chat never gets cut off */
@media (max-width: 360px) {


    .chat-widget.sagitta-chat-widget .chat-icon {
        width: 24px !important;
        height: 24px !important;
    }

    .chat-widget.sagitta-chat-widget .chat-trigger-avatar {
        width: 100% !important;
        height: 100% !important;
    }

    /* Unified element extra small - no separate notification-widget */

    .chat-widget.sagitta-chat-widget .notification-bubble {
        max-width: 150px !important;
        font-size: 10px !important;
        padding: 6px 10px !important;
        line-height: 1.3 !important;
    }

    .chat-widget.sagitta-chat-widget .chat-messages {
        padding: 10px !important;
        max-height: calc(100vh - 250px) !important;
    }

    .chat-widget.sagitta-chat-widget .chat-header {
        padding: 15px !important;
    }

    .chat-widget.sagitta-chat-widget .chat-input {
        padding: 15px !important;
    }

    .chat-widget.sagitta-chat-widget .chat-window.active,
    .chat-widget.sagitta-chat-widget .chat-window {
        width: calc(100vw - 10px) !important;
        margin-left: calc(-50vw + 5px) !important;
        bottom: 80px !important;
        max-height: calc(100vh - 110px) !important;
    }
}

/* Scrollbar Styling */
.chat-widget.sagitta-chat-widget .chat-messages::-webkit-scrollbar {
    width: 4px !important;
}

.chat-widget.sagitta-chat-widget .chat-messages::-webkit-scrollbar-track {
    background: transparent !important;
}

.chat-widget.sagitta-chat-widget .chat-messages::-webkit-scrollbar-thumb {
    background: #ddd !important;
    border-radius: 2px !important;
}

.chat-widget.sagitta-chat-widget .chat-messages::-webkit-scrollbar-thumb:hover {
    background: #bbb !important;
}

/* Send Button Styles for Email Input */
.sagitta-chat-widget #chatWindow #chatMessages #emailInputMessage .message-content .send-btn {
    width: 100% !important;
    margin-top: 10px !important;
}

#emailInputMessage .send-btn {
    border-top-left-radius: 10px !important;
    border-top-right-radius: 10px !important;
    border-bottom-left-radius: 10px !important;
    border-bottom-right-radius: 10px !important;
}
