:root {
    --wa-color: #25D366;
    --wa-blue-gradient: linear-gradient(135deg, rgba(0,85,255,0.92) 0%, rgba(0,161,255,0.85) 100%);
    --shadow: 0 10px 40px rgba(0,0,0,0.1);
    --shadow-trigger: 0 4px 15px rgba(0,0,0,0.2);
    --transition-main: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    --transition-pop: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#gf-wa-app, #gf-wa-app * { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; line-height: normal !important; letter-spacing: normal !important; outline: none !important; }

#gf-wa-app { position: fixed !important; bottom: 30px !important; right: 30px !important; z-index: 999999 !important; }

#gf-wa-app .gf-wa-modal {
    position: absolute !important; bottom: 85px !important; right: 0 !important; width: 380px !important; height: 600px !important; max-height: 80vh !important;
    background: #fff !important; border-radius: 20px !important; box-shadow: var(--shadow) !important; opacity: 0 !important; pointer-events: none !important;
    transform: translateY(20px) scale(0.95) !important; transform-origin: bottom right !important; transition: var(--transition-pop) !important;
    overflow: hidden !important; display: flex !important; flex-direction: column !important; border: none !important;
}
#gf-wa-app.active .gf-wa-modal { opacity: 1 !important; pointer-events: auto !important; transform: translateY(0) scale(1) !important; }

#gf-wa-app .gf-wa-header-ui {
    background-color: var(--wa-blue-main) !important; background-size: cover !important; background-position: center !important;
    min-height: 240px !important; display: flex !important; flex-direction: column !important; justify-content: flex-end !important; 
    padding: 25px !important; color: white !important; position: relative !important; overflow: hidden !important; border: none !important;
}
#gf-wa-app .gf-wa-header-overlay { position: absolute !important; top: 0 !important; left: 0 !important; width: 100% !important; height: 100% !important; background: var(--wa-blue-gradient) !important; z-index: 1 !important; }
#gf-wa-app .gf-wa-top-icon { position: absolute !important; top: 25px !important; left: 25px !important; z-index: 2 !important; opacity: 0.9 !important; display: block !important; width: 28px !important; height: 28px !important; }
#gf-wa-app .gf-wa-close-mobile {
    position: absolute !important; top: 15px !important; right: 15px !important; background: rgba(255,255,255,0.1) !important; border: none !important; color: white !important;
    width: 32px !important; height: 32px !important; border-radius: 50% !important; cursor: pointer !important; display: none !important; align-items: center !important; justify-content: center !important;
    transition: var(--transition-main) !important; z-index: 10 !important; font-size: 18px !important;
}
#gf-wa-app .gf-wa-close-mobile:hover { background: rgba(255,255,255,0.2) !important; }

#gf-wa-app .gf-wa-header-content { position: relative !important; z-index: 2 !important; }
#gf-wa-app .gf-wa-header-content h3 { margin: 0 !important; font-size: 26px !important; font-weight: 700 !important; line-height: 1.2 !important; color: white !important; border: none !important; }
#gf-wa-app .gf-wa-header-content p { margin: 8px 0 0 !important; font-size: 15px !important; opacity: 0.9 !important; color: white !important; border: none !important; }

#gf-wa-app .gf-wa-body { padding: 25px 20px !important; background: #f8f9fa !important; flex: 1 !important; overflow-y: auto !important; display: block !important; }
#gf-wa-app .gf-wa-chat-view, #gf-wa-app .gf-wa-agents-list { width: 100% !important; flex-direction: column !important; }

#gf-wa-app .gf-wa-agent-item {
    display: flex !important; align-items: center !important; background: white !important; padding: 18px 15px !important; border-radius: 14px !important; margin-bottom: 12px !important;
    cursor: pointer !important; transition: var(--transition-main) !important; border: 1px solid #eee !important; box-shadow: 0 2px 5px rgba(0,0,0,0.02) !important; text-align: left !important; flex-direction: row !important;
}
#gf-wa-app .gf-wa-agent-item:hover { transform: translateX(5px) !important; border-color: #ddd !important; box-shadow: 0 4px 10px rgba(0,0,0,0.05) !important; }
#gf-wa-app .gf-wa-agent-item img { width: 50px !important; height: 50px !important; border-radius: 50% !important; object-fit: cover !important; margin: 0 18px 0 0 !important; border: none !important; display: block !important; }
#gf-wa-app .gf-wa-agent-item div { display: block !important; margin: 0 !important; padding: 0 !important; }
#gf-wa-app .gf-wa-agent-item strong { display: block !important; color: #1d2327 !important; font-size: 16px !important; font-weight: 600 !important; margin: 0 !important; }
#gf-wa-app .gf-wa-agent-item p { margin: 3px 0 0 !important; font-size: 13px !important; color: #646970 !important; }

#gf-wa-app .gf-wa-chat-bubble {
    background: white !important; padding: 18px !important; border-radius: 14px 14px 14px 0 !important; box-shadow: 0 2px 10px rgba(0,0,0,0.03) !important; 
    margin: 0 0 25px 0 !important; font-size: 15px !important; color: #1d2327 !important; line-height: 1.5 !important; align-self: flex-start !important; max-width: 85% !important; border: none !important; text-align: left !important; display: block !important;
}
#gf-wa-app .gf-wa-input-area {
    background: white !important; border-radius: 25px !important; padding: 6px 6px 6px 18px !important; display: flex !important; align-items: center !important; 
    border: 1px solid #ddd !important; box-shadow: 0 2px 5px rgba(0,0,0,0.03) !important; margin-top: auto !important; width: 100% !important; flex-direction: row !important;
}
#gf-wa-app .gf-wa-input-area textarea { 
    flex: 1 !important; border: none !important; resize: none !important; font-family: inherit !important; font-size: 14px !important; height: 38px !important; min-height: 0 !important; max-height: 38px !important;
    padding: 8px 0 0 0 !important; color: #1d2327 !important; background: transparent !important; margin: 0 !important; box-shadow: none !important; overflow: hidden !important; appearance: none !important; display: block !important;
}
#gf-wa-app .gf-wa-input-area button {
    background: var(--wa-blue-main) !important; border: none !important; width: 40px !important; height: 40px !important; min-width: 40px !important; min-height: 40px !important; max-width: 40px !important; max-height: 40px !important;
    border-radius: 50% !important; color: white !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: var(--transition-main) !important;
    margin: 0 !important; padding: 0 !important; flex-shrink: 0 !important; appearance: none !important; box-shadow: none !important;
}
#gf-wa-app .gf-wa-input-area button:hover { transform: scale(1.08) rotate(-10deg) !important; background: #0044cc !important; }
#gf-wa-app .gf-wa-input-area button svg { margin: 0 !important; padding: 0 !important; width: 22px !important; height: 22px !important; display: block !important; }

/* Botón Trigger Blindado */
#gf-wa-app .gf-wa-trigger {
    background-color: var(--wa-color) !important; border-radius: 50px !important; box-shadow: var(--shadow-trigger) !important; cursor: pointer !important; display: flex !important; 
    align-items: center !important; justify-content: center !important; height: 60px !important; min-height: 60px !important; max-height: 60px !important; transition: var(--transition-main) !important; position: relative !important; min-width: 60px !important; overflow: hidden !important; border: none !important; margin: 0 !important; padding: 0 22px !important; width: auto !important; flex-direction: row !important;
}
#gf-wa-app .gf-wa-trigger:hover { transform: scale(1.05) !important; box-shadow: 0 6px 20px rgba(37, 211, 102, 0.4) !important; }
#gf-wa-app .gf-wa-trigger .gf-wa-icon-wa { width: 28px !important; height: 28px !important; min-width: 28px !important; margin: 0 !important; padding: 0 !important; display: block !important;}
#gf-wa-app .gf-wa-trigger .gf-wa-text { opacity: 1 !important; transition: var(--transition-main) !important; transform: translateY(0) !important; display: block !important; margin: 0 0 0 8px !important; padding: 0 !important; font-size: 16px !important; font-weight: 600 !important; color: white !important; white-space: nowrap !important; }
#gf-wa-app .gf-wa-trigger .gf-wa-close-wrapper {
    position: absolute !important; top: 50% !important; left: 50% !important; transform: translate(-50%, -50%) translateY(20px) rotate(-45deg) !important;
    opacity: 0 !important; transition: var(--transition-main) !important; display: flex !important; align-items: center !important; justify-content: center !important; margin: 0 !important; padding: 0 !important;
}

#gf-wa-app.active .gf-wa-trigger { background-color: #f1f1f1 !important; width: 60px !important; min-width: 60px !important; max-width: 60px !important; padding: 0 !important; border: 1px solid #ddd !important; }
#gf-wa-app.active .gf-wa-trigger .gf-wa-icon-wa, #gf-wa-app.active .gf-wa-trigger .gf-wa-text { opacity: 0 !important; transform: translateY(-20px) !important; pointer-events: none !important; }
#gf-wa-app.active .gf-wa-trigger .gf-wa-close-wrapper { opacity: 1 !important; transform: translate(-50%, -50%) translateY(0) rotate(0deg) !important; color: #1d2327 !important; }

/* Responsive Móvil */
@media (max-width: 480px) {
    #gf-wa-app { bottom: 20px !important; right: 20px !important; }
    #gf-wa-app.active { bottom: 0 !important; right: 0 !important; left: 0 !important; top: 0 !important; width: 100% !important; height: 100% !important; }
    #gf-wa-app .gf-wa-modal {
        position: fixed !important; top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important; width: 100% !important; height: 100% !important; max-height: 100% !important;
        border-radius: 0 !important; transform: translateY(100vh) !important; opacity: 0 !important; transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1) !important; margin: 0 !important;
    }
    #gf-wa-app.active .gf-wa-modal { transform: translateY(0) scale(1) !important; opacity: 1 !important; }
    #gf-wa-app .gf-wa-close-mobile { display: flex !important; top: 20px !important; right: 20px !important; } 
    #gf-wa-app.active .gf-wa-trigger { display: none !important; } 
}