.elementor-153 .elementor-element.elementor-element-83d32c1{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-d208a5e *//* ==========================================================================
       CSS VARIABLES & BASE SETTINGS
       ========================================================================== */
    :root {
        --primary: #531278;
        --tertiary: #6e0039;
        --accent-gold: #c5a059;
        --surface: #fdfcfb;
        --on-surface: #1a1c1b;
        --on-surface-variant: #5c555f;
        --surface-container-low: #f7f5f2;
        --outline-variant: #d0c2d2;
        --outline: #7e7381;
        --font-display: 'Newsreader', serif;
        --font-body: 'Manrope', sans-serif;
        --font-label: 'Manrope', sans-serif;
    }

    * { box-sizing: border-box; }

    .material-symbols-outlined {
        font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    /* ==========================================================================
       GLOBAL LAYOUT
       ========================================================================== */
    .contact-main-container {
        padding-top: 3rem;
        padding-bottom: 6rem;
        position: relative;
        font-family: var(--font-body);
        color: var(--on-surface);
        overflow-x: hidden;
        background-color: var(--surface);
    }

    .bg-pattern {
        position: absolute;
        top: 0;
        right: 0;
        width: 50vw;
        height: 100%;
        background: radial-gradient(circle at top right, rgba(197,160,89,0.05), transparent 70%);
        z-index: 0;
        pointer-events: none;
    }

    .section-wrapper {
        padding-left: 2rem;
        padding-right: 2rem;
        max-width: 1536px;
        margin-left: auto;
        margin-right: auto;
        position: relative;
        z-index: 10;
    }

    @media (min-width: 768px) {
        .section-wrapper { padding-left: 4rem; padding-right: 4rem; }
    }

    /* ==========================================================================
       HERO SECTION
       ========================================================================== */
    .hero-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 3rem;
        align-items: flex-end;
        margin-bottom: 6rem;
        margin-top: 2rem;
    }

    @media (min-width: 1024px) {
        .hero-grid { grid-template-columns: repeat(12, 1fr); }
    }

    .hero-text-col {
        grid-column: span 12;
    }

    @media (min-width: 1024px) {
        .hero-text-col { grid-column: span 7; }
    }

    .hero-label {
        font-family: var(--font-label);
        font-size: 0.8rem;
        text-transform: uppercase;
        letter-spacing: 0.4em;
        color: var(--accent-gold);
        margin-bottom: 1.5rem;
        display: flex;
        align-items: center;
        gap: 1rem;
    }

    .hero-label-line {
        width: 2rem;
        height: 1px;
        background-color: var(--accent-gold);
    }

    .hero-title {
        font-family: var(--font-display);
        font-size: 3rem;
        color: var(--primary);
        line-height: 0.9;
        margin-bottom: 2rem;
        letter-spacing: -0.02em;
    }

    @media (min-width: 768px) { .hero-title { font-size: 4.5rem; } }
    @media (min-width: 1024px) { .hero-title { font-size: 5.5rem; } }

    .hero-title-italic {
        font-style: italic;
        font-weight: 300;
        color: var(--tertiary);
        margin-left: 10%;
        display: block;
        margin-top: 0.5rem;
    }

    .hero-desc {
        font-size: 1.125rem;
        color: var(--on-surface-variant);
        max-width: 28rem;
        line-height: 1.8;
        font-weight: 300;
    }

    .hero-img-col {
        display: none;
        grid-column: span 5;
    }

    @media (min-width: 1024px) {
        .hero-img-col { display: block; }
    }

    .hero-img-wrapper {
        aspect-ratio: 4 / 3;
        background-color: var(--surface-container-low);
        border-radius: 0.75rem;
        overflow: hidden;
        position: relative;
        box-shadow: 0 20px 40px rgba(83,18,120,0.08);
    }

    .hero-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        animation: slowZoom 20s linear infinite alternate;
    }

    /* ==========================================================================
       BENTO GRID (FORM & CARDS)
       ========================================================================== */
    .bento-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    @media (min-width: 1024px) {
        .bento-grid { grid-template-columns: repeat(12, 1fr); }
    }

    /* Form Section */
    .form-wrapper {
        grid-column: span 12;
        background-color: var(--surface);
        padding: 2rem;
        border-radius: 1rem;
        box-shadow: 0 20px 40px rgba(83,18,120,0.05);
        border: 1px solid rgba(208,194,210,0.3);
    }

    @media (min-width: 768px) {
        .form-wrapper { padding: 3.5rem; }
    }

    @media (min-width: 1024px) {
        .form-wrapper { grid-column: span 7; }
    }

    .form-title {
        font-family: var(--font-display);
        font-size: 2.25rem;
        margin-bottom: 3rem;
        color: var(--primary);
    }

    .form-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 2.5rem;
        margin-bottom: 3rem;
    }

    @media (min-width: 768px) {
        .form-row { grid-template-columns: 1fr 1fr; }
    }

    .form-group {
        position: relative;
    }

    .form-group.full-width {
        margin-bottom: 3rem;
    }

    .form-label {
        display: block;
        font-family: var(--font-label);
        font-size: 0.7rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.15em;
        color: var(--outline);
        margin-bottom: 0.75rem;
    }

    .form-input {
        width: 100%;
        background: transparent;
        border: none;
        border-bottom: 1px solid var(--outline-variant);
        padding: 0.5rem 0;
        font-family: var(--font-body);
        color: var(--on-surface);
        font-size: 1rem;
        transition: border-color 0.4s ease, background-color 0.4s ease;
        appearance: none;
    }

    .form-input::placeholder {
        color: rgba(92, 85, 95, 0.5);
    }

    .form-input:focus {
        outline: none;
        border-bottom-color: var(--accent-gold);
        background-color: rgba(197, 160, 89, 0.02);
    }

    .select-icon {
        position: absolute;
        right: 0;
        top: 2.25rem;
        color: var(--outline-variant);
        pointer-events: none;
    }

    .btn-submit {
        width: 100%;
        background-color: var(--primary);
        color: #ffffff;
        padding: 1rem 3.5rem;
        border: none;
        border-radius: 9999px;
        font-family: var(--font-body);
        font-weight: 600;
        font-size: 0.8rem;
        letter-spacing: 0.15em;
        text-transform: uppercase;
        cursor: pointer;
        transition: all 0.3s ease;
        box-shadow: 0 10px 20px rgba(83,18,120,0.2);
    }

    @media (min-width: 768px) {
        .btn-submit { width: auto; }
    }

    .btn-submit:hover {
        background-color: var(--tertiary);
        box-shadow: 0 15px 30px rgba(83,18,120,0.3);
        transform: translateY(-2px);
    }

    /* Cards Section */
    .cards-wrapper {
        grid-column: span 12;
        display: flex;
        flex-direction: column;
        gap: 2rem;
    }

    @media (min-width: 1024px) {
        .cards-wrapper { grid-column: span 5; }
    }

    .whatsapp-card {
        background: linear-gradient(to bottom right, var(--primary), var(--tertiary));
        padding: 2.5rem;
        border-radius: 1rem;
        color: #ffffff;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        position: relative;
        overflow: hidden;
        box-shadow: 0 20px 40px rgba(83,18,120,0.2);
        cursor: pointer;
        transition: transform 0.5s ease;
        flex-grow: 1;
    }

    .whatsapp-card:hover {
        transform: translateY(-8px);
    }

    .glow-blob {
        position: absolute;
        top: -5rem;
        right: -5rem;
        width: 16rem;
        height: 16rem;
        background-color: rgba(255,255,255,0.1);
        filter: blur(40px);
        border-radius: 50%;
        transition: transform 0.7s ease;
    }

    .whatsapp-card:hover .glow-blob {
        transform: scale(1.5);
    }

    .whatsapp-card-content {
        position: relative;
        z-index: 10;
    }

    .whatsapp-icon {
        font-size: 3rem;
        margin-bottom: 1.5rem;
        color: var(--accent-gold);
        font-weight: 300;
    }

    .whatsapp-title {
        font-family: var(--font-display);
        font-size: 1.875rem;
        margin-bottom: 1rem;
        font-style: italic;
    }

    .whatsapp-desc {
        color: rgba(255,255,255,0.8);
        line-height: 1.7;
        margin-bottom: 2rem;
        font-weight: 300;
    }

    .whatsapp-btn {
        position: relative;
        z-index: 10;
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: linear-gradient(to bottom, rgba(255,255,255,0.2), rgba(255,255,255,0.05));
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border: 1px solid rgba(255,255,255,0.3);
        border-bottom-color: rgba(255,255,255,0.05);
        padding: 1rem 1.5rem;
        border-radius: 1rem;
        box-shadow: 0 8px 32px rgba(0,0,0,0.15);
        text-decoration: none;
        transition: all 0.3s ease;
        margin-bottom: 1rem;
    }

    .whatsapp-btn:hover {
        background: linear-gradient(to bottom, rgba(255,255,255,0.3), rgba(255,255,255,0.1));
    }

    .whatsapp-btn-text {
        font-family: var(--font-body);
        font-weight: 700;
        font-size: 0.75rem;
        text-transform: uppercase;
        letter-spacing: 0.15em;
        color: var(--accent-gold);
    }

    .whatsapp-btn-icon {
        color: #ffffff;
        font-size: 1.25rem;
        transition: transform 0.3s ease;
    }

    .whatsapp-card:hover .whatsapp-btn-icon {
        transform: translateX(8px);
    }

    /* Small Cards Row */
    .info-cards-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    @media (min-width: 768px) {
        .info-cards-row { grid-template-columns: 1fr 1fr; }
    }

    .info-card {
        background-color: var(--surface-container-low);
        padding: 2rem;
        border-radius: 1rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
        border: 1px solid rgba(208,194,210,0.2);
        transition: border-color 0.3s ease;
    }

    .info-card:hover {
        border-color: rgba(197, 160, 89, 0.5);
    }

    .info-card-label {
        font-family: var(--font-label);
        font-size: 0.7rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.15em;
        color: var(--accent-gold);
        margin-bottom: 0.75rem;
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }

    .info-card-label .material-symbols-outlined {
        font-size: 1rem;
    }

    .info-card-link {
        font-family: var(--font-display);
        font-size: 1.5rem;
        color: var(--primary);
        text-decoration: none;
        transition: color 0.3s ease;
    }

    .info-card-link:hover {
        color: var(--tertiary);
    }

    .info-card-text {
        font-size: 0.9rem;
        color: var(--primary);
        line-height: 1.6;
    }

    .info-card-subtext {
        font-size: 0.8rem;
        color: var(--on-surface-variant);
        font-weight: 300;
        margin-top: 0.75rem;
        display: block;
        line-height: 1.6;
    }

    /* ==========================================================================
       MAP SECTION
       ========================================================================== */
    .map-section {
        margin-top: 6rem;
        margin-bottom: 2.5rem;
    }

    .map-wrapper {
        position: relative;
        width: 100%;
        height: 500px;
        border-radius: 1rem;
        overflow: hidden;
        box-shadow: 0 30px 60px rgba(0,0,0,0.08);
        background-color: var(--surface-container-low);
        border: 1px solid rgba(208,194,210,0.2);
    }

    .map-overlay-shadow {
        position: absolute;
        inset: 0;
        z-index: 10;
        pointer-events: none;
        box-shadow: inset 0 0 100px rgba(83,18,120,0.05);
    }

    .map-iframe-container {
        width: 100%;
        height: 100%;
        background-color: #e5e5e5;
        position: relative;
        pointer-events: none;
    }

    .map-iframe {
        width: 100%;
        height: 100%;
        border: 0;
        filter: grayscale(40%);
        transition: filter 1s ease;
    }

    .map-wrapper:hover .map-iframe {
        filter: grayscale(0%);
    }

    .map-pin-container {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -60%);
        display: flex;
        flex-direction: column;
        align-items: center;
        z-index: 20;
    }

    .map-tooltip {
        background-color: rgba(255,255,255,0.95);
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
        padding: 0.75rem 1.25rem;
        border-radius: 0.75rem;
        box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25);
        margin-bottom: 1rem;
        border: 1px solid rgba(197, 160, 89, 0.2);
        opacity: 0;
        transform: translateY(1rem);
        transition: all 0.5s ease;
        text-align: center;
    }

    .map-wrapper:hover .map-tooltip {
        opacity: 1;
        transform: translateY(0);
    }

    .map-tooltip-title {
        font-family: var(--font-body);
        font-weight: 700;
        font-size: 0.7rem;
        text-transform: uppercase;
        letter-spacing: 0.15em;
        color: var(--primary);
        display: block;
    }

    .map-tooltip-desc {
        font-size: 0.65rem;
        color: var(--on-surface-variant);
        font-weight: 300;
        letter-spacing: 0.025em;
        margin-top: 0.25rem;
        display: block;
    }

    .map-pin-relative {
        position: relative;
    }

    .map-pin-pulse {
        position: absolute;
        top: -1rem;
        right: -1rem;
        bottom: -1rem;
        left: -1rem;
        background-color: rgba(197, 160, 89, 0.2);
        border-radius: 50%;
        animation: pinPulse 2s cubic-bezier(0, 0, 0.2, 1) infinite;
    }

    .map-pin-dot {
        width: 3.5rem;
        height: 3.5rem;
        background-color: #ffffff; /* White background to make dark logo visible */
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
        position: relative;
        z-index: 10;
        border: 2px solid var(--primary); /* Purple outline */
        transition: transform 0.3s ease;
    }

    .map-pin-dot:hover {
        transform: scale(1.05); /* Gentle pop effect on hover */
    }

    /* Custom Logo Image styling for the map pin */
    .map-pin-custom-logo {
        width: 65%; /* Scales the image perfectly inside the circle */
        height: auto;
        object-fit: contain;
        transition: transform 0.3s ease;
    }

    /* ==========================================================================
       ANIMATIONS
       ========================================================================== */
    @keyframes slowZoom {
        from { transform: scale(1); }
        to { transform: scale(1.08); }
    }

    @keyframes pinPulse {
        75%, 100% { transform: scale(2); opacity: 0; }
    }

    .reveal { 
        opacity: 0; 
        transform: translateY(40px);
        transition: all 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
    }
    
    .reveal.is-active {
        opacity: 1;
        transform: translateY(0);
    }

    .delay-1 { transition-delay: 0.15s; }
    .delay-2 { transition-delay: 0.3s; }/* End custom CSS */