/**
 * Oportuna Contact Widget Styles
 */

/* Background Textures */
.oportuna-contact .bg-noise {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='1'/%3E%3C/svg%3E");
    background-repeat: repeat;
}

.oportuna-contact .bg-grid-slate {
    background-size: 40px 40px;
    background-image: linear-gradient(to right, rgba(51, 65, 85, 0.1) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(51, 65, 85, 0.1) 1px, transparent 1px);
}

/* Animations */
@keyframes float-slow {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.1; }
    33% { transform: translate(50px, -30px) scale(1.2); opacity: 0.2; }
    66% { transform: translate(-20px, 20px) scale(0.9); opacity: 0.15; }
}

.oportuna-contact .animate-float-slow {
    animation: float-slow 10s ease-in-out infinite;
}

@keyframes spin-slow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.oportuna-contact .animate-spin-slow {
    animation: spin-slow 12s linear infinite;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.oportuna-contact .animate-fade-in-up {
    animation: fadeInUp 0.8s ease-out forwards;
}

@keyframes fadeInLeft {
    from { opacity: 0; transform: translateX(-20px); }
    to { opacity: 1; transform: translateX(0); }
}

.oportuna-contact .animate-fade-in-left {
    animation: fadeInLeft 0.8s ease-out forwards;
}

/* Glassmorphism & Utilities */
.oportuna-contact .backdrop-blur-xl {
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}

.oportuna-contact .oportuna-contact-items {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 1280px) {
    .oportuna-contact .oportuna-contact-items {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 2rem;
    }
}

.oportuna-contact .oportuna-contact-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.70);
    border: 1px solid rgba(255, 255, 255, 0.50);
    border-radius: 1.25rem;
    padding: 1.5rem;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: transform 300ms ease, box-shadow 300ms ease, background-color 300ms ease, border-color 300ms ease;
}

.oportuna-contact .oportuna-contact-card:hover {
    transform: translateY(-0.5rem);
}

@media (min-width: 640px) {
    .oportuna-contact .oportuna-contact-card {
        padding: 1.75rem;
        border-radius: 1.5rem;
    }
}

@media (min-width: 1280px) {
    .oportuna-contact .oportuna-contact-card {
        padding: 2rem;
        border-radius: 1.875rem;
        align-items: center;
        text-align: center;
    }
}

/* Custom Scrollbar for Textarea if needed */
.oportuna-contact textarea::-webkit-scrollbar {
    width: 8px;
}
.oportuna-contact textarea::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.05);
}
.oportuna-contact textarea::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 4px;
}
.oportuna-contact textarea::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3);
}

/* Form Elements Focus Ring Override (if Tailwind default isn't enough) */
.oportuna-contact input:focus,
.oportuna-contact select:focus,
.oportuna-contact textarea:focus {
    outline: none;
    border-color: #3b82f6; /* primary-500 */
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
}
