/* ====================================================================
   Página: Contato
   ==================================================================== */

/* ----- Section: Hero Contato ----- */
.ct-hero {
    background-color: var(--semantics-colors-fill-background-primary);
    padding: var(--semantics-padding-bigger) 0;
}

.ct-hero__inner {
    width: 100%;
    max-width: var(--semantics-container-max);
    margin: 0 auto;
    padding: 0 var(--semantics-spacing-large);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--semantics-spacing-small);
}

.ct-hero__title {
    font-family: var(--semantics-typography-family-poppins);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-xx-large);
    line-height: var(--semantics-typography-baseline-tight);
    letter-spacing: var(--semantics-typography-tracking-tight-2);
    color: var(--semantics-colors-text-heading-default);
    margin: 0;
}

.ct-hero__desc {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 400;
    font-size: var(--semantics-typography-body-16);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-secondary);
    margin: 0;
    max-width: 808px;
}

/* ----- Section: Formulário e Contatos ----- */
.ct-form-section {
    background-color: var(--semantics-colors-fill-background-primary);
    padding: var(--semantics-padding-broad) 0;
}

.ct-form-section__inner {
    width: 100%;
    max-width: var(--semantics-container-max);
    margin: 0 auto;
    padding: 0 var(--semantics-spacing-large);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--semantics-spacing-bigger);
    align-items: start;
}

.ct-form,
.ct-contacts {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-larger);
    min-width: 0;
}

.ct-form__title,
.ct-contacts__title {
    font-family: var(--semantics-typography-family-poppins);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-small);
    line-height: var(--semantics-typography-baseline-tight);
    letter-spacing: var(--semantics-typography-tracking-tight-1);
    color: var(--semantics-colors-text-heading-default);
    margin: 0;
}

/* ----- Form ----- */
.ct-form__form {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--semantics-spacing-larger);
}

.ct-field {
    display: block;
    width: 100%;
}

.ct-field__label {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.ct-field__input {
    width: 100%;
    padding: var(--semantics-spacing-large);
    background-color: var(--semantics-colors-fill-neutral-subtle);
    border: 1px solid var(--semantics-colors-stroke-primary);
    border-radius: var(--semantics-radius-medium);
    font-family: var(--semantics-typography-family-inter);
    font-weight: 400;
    font-size: var(--semantics-typography-body-14);
    line-height: 1.5;
    color: var(--semantics-colors-text-heading-default);
    transition: border-color var(--semantics-motion-duration-fast) var(--semantics-motion-easing-standard);
}

.ct-field__input::placeholder {
    color: var(--semantics-colors-text-tertiary);
}

.ct-field__input:focus {
    outline: none;
    border-color: var(--semantics-colors-stroke-accent-purpura);
}

.ct-field__input--textarea {
    min-height: 120px;
    resize: vertical;
}

/* ----- Contact cards ----- */
.ct-contact-card {
    background-color: var(--semantics-colors-fill-neutral-subtle);
    border-radius: var(--semantics-radius-larger);
    padding: var(--semantics-spacing-bigger);
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-large);
}

.ct-contact-card__header {
    display: flex;
    align-items: center;
    gap: var(--semantics-spacing-large);
}

.ct-contact-card__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--semantics-radius-big);
    color: var(--semantics-colors-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}

.ct-contact-card__icon--purpura {
    background-color: var(--semantics-colors-fill-accent-purpura);
}

.ct-contact-card__icon--pistache {
    background-color: var(--semantics-colors-fill-accent-pistache);
}

.ct-contact-card__icon--ponkan {
    background-color: var(--semantics-colors-fill-accent-ponkan);
}

.ct-contact-card__icon--petunia {
    background-color: var(--semantics-colors-fill-accent-petunia);
    border-radius: var(--semantics-radius-full);
}

.ct-contact-card__heading {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-micro);
    min-width: 0;
}

.ct-contact-card__name {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 600;
    font-size: var(--semantics-typography-body-16);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-heading-default);
    margin: 0;
}

.ct-contact-card__desc {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 400;
    font-size: var(--semantics-typography-body-14);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-secondary);
    margin: 0;
}

.ct-contact-card__divider {
    width: 100%;
    height: 1px;
    border: 0;
    background-color: var(--semantics-colors-stroke-primary);
    margin: 0;
}

.ct-contact-card__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-tiny);
    font-family: var(--semantics-typography-family-inter);
    font-weight: 400;
    font-size: var(--semantics-typography-body-14);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-heading-default);
}

.ct-contact-card__email {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 600;
    font-size: var(--semantics-typography-body-14);
    line-height: var(--semantics-typography-baseline-normal);
    text-decoration: none;
    transition: color var(--semantics-motion-duration-fast) var(--semantics-motion-easing-standard);
}

.ct-contact-card__email--purpura {
    color: var(--semantics-colors-text-accent-purpura);
}

.ct-contact-card__email--pistache {
    color: var(--semantics-colors-text-accent-pistache);
}

.ct-contact-card__email--ponkan {
    color: var(--semantics-colors-text-accent-ponkan);
}

/* ----- Section: Onde Estamos ----- */
.ct-onde {
    background-color: var(--semantics-colors-fill-neutral-subtle);
    padding-top: var(--semantics-spacing-broad);
}

.ct-onde__inner {
    width: 100%;
    max-width: var(--semantics-container-max);
    margin: 0 auto;
    padding: 0 var(--semantics-spacing-large);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.ct-onde__header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--semantics-spacing-large);
    padding-bottom: var(--semantics-padding-bigger);
    text-align: center;
}

.ct-onde__title {
    font-family: var(--semantics-typography-family-poppins);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-large);
    line-height: var(--semantics-typography-baseline-tight);
    letter-spacing: var(--semantics-typography-tracking-tight-1);
    color: var(--semantics-colors-text-heading-default);
    margin: 0;
}

.ct-onde__pills {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--semantics-spacing-small);
    justify-content: center;
}

.ct-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--semantics-spacing-small);
    padding: var(--semantics-spacing-tiny) var(--semantics-spacing-medium);
    border: 1px solid transparent;
    border-radius: var(--semantics-radius-larger);
    font-family: var(--semantics-typography-family-inter);
    font-weight: 600;
    font-size: var(--semantics-typography-label-12);
    line-height: 1.5;
    cursor: pointer;
    transition: border-color var(--semantics-motion-duration-fast) var(--semantics-motion-easing-standard),
        transform var(--semantics-motion-duration-fast) var(--semantics-motion-easing-standard);
}

.ct-pill:hover {
    transform: translateY(-1px);
}

.ct-pill.is-active {
    border-color: currentColor;
}

.ct-pill__dot {
    width: 6px;
    height: 6px;
    border-radius: var(--semantics-radius-full);
    flex-shrink: 0;
}

.ct-pill--purpura {
    background-color: var(--semantics-colors-fill-primary-subtle);
    color: var(--semantics-colors-text-accent-purpura);
}

.ct-pill--purpura .ct-pill__dot {
    background-color: var(--semantics-colors-fill-accent-purpura);
}

.ct-pill--pitaya {
    background-color: var(--semantics-colors-fill-accent-pitaya-subtle);
    color: var(--semantics-colors-text-accent-pitaya);
}

.ct-pill--pitaya .ct-pill__dot {
    background-color: var(--semantics-colors-fill-accent-pitaya);
}

.ct-pill--pistache {
    background-color: var(--semantics-colors-fill-accent-pistache-subtle);
    color: var(--semantics-colors-text-accent-pistache);
}

.ct-pill--pistache .ct-pill__dot {
    background-color: var(--semantics-colors-fill-accent-pistache);
}

.ct-pill--ponkan {
    background-color: var(--semantics-colors-fill-secondary-subtle);
    color: var(--semantics-colors-text-accent-ponkan);
}

.ct-pill--ponkan .ct-pill__dot {
    background-color: var(--semantics-colors-fill-accent-ponkan);
}

.ct-pill--petunia {
    background-color: var(--semantics-colors-fill-accent-petunia-subtle);
    color: var(--semantics-colors-text-accent-petunia);
}

.ct-pill--petunia .ct-pill__dot {
    background-color: var(--semantics-colors-fill-accent-petunia);
}

/* ----- Map (Google Maps embed) ----- */
.ct-onde__map {
    width: 100%;
    height: 420px;
    background-color: var(--semantics-colors-fill-neutral-subtle);
    overflow: hidden;
}

.ct-onde__map iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
    opacity: 1;
    transition: opacity var(--semantics-motion-duration-slow) var(--semantics-motion-easing-standard);
}

.ct-onde__map.is-loading iframe {
    opacity: 0;
}

/* ----- Section: Redes Sociais ----- */
.ct-social {
    background-color: var(--semantics-colors-fill-background-primary);
    padding: var(--semantics-spacing-broad) 0;
}

.ct-social__inner {
    width: 100%;
    max-width: var(--semantics-container-max);
    margin: 0 auto;
    padding: 0 var(--semantics-spacing-large);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--semantics-spacing-small);
}

.ct-social__handle {
    font-family: var(--semantics-typography-family-poppins);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-small);
    line-height: var(--semantics-typography-baseline-tight);
    letter-spacing: var(--semantics-typography-tracking-tight-1);
    color: var(--semantics-colors-text-heading-default);
    margin: 0;
}

.ct-social__list {
    list-style: none;
    margin: var(--semantics-spacing-small) 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--semantics-spacing-large);
    justify-content: center;
}

.ct-social__link {
    display: inline-flex;
    align-items: center;
    gap: var(--semantics-spacing-small);
    padding: var(--semantics-spacing-small) var(--semantics-spacing-bigger);
    border: 1px solid var(--semantics-colors-stroke-primary);
    border-radius: var(--semantics-radius-full);
    font-family: var(--semantics-typography-family-inter);
    font-weight: 600;
    font-size: var(--semantics-typography-body-14);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-heading-default);
    text-decoration: none;
    transition: border-color var(--semantics-motion-duration-fast) var(--semantics-motion-easing-standard);
}

.ct-social__link:hover {
    border-color: var(--semantics-colors-stroke-accent-purpura);
}

.ct-social__dot {
    width: 8px;
    height: 8px;
    border-radius: var(--semantics-radius-full);
    flex-shrink: 0;
}

.ct-social__dot--instagram {
    background-color: var(--semantics-colors-fill-accent-pitaya);
}

.ct-social__dot--linkedin {
    background-color: var(--semantics-colors-fill-accent-purpura);
}

.ct-social__dot--facebook {
    background-color: var(--semantics-colors-fill-accent-pistache);
}

.ct-social__dot--youtube {
    background-color: var(--semantics-colors-fill-accent-ponkan);
}

.ct-social__dot--tiktok {
    background-color: var(--semantics-colors-fill-accent-petunia);
}

/* ----- Section: Trabalhe Conosco ----- */
.ct-trabalhe {
    background-color: var(--semantics-colors-fill-primary-subtle);
    padding: var(--semantics-spacing-wide) 0;
}

.ct-trabalhe__inner {
    width: 100%;
    max-width: var(--semantics-container-max);
    margin: 0 auto;
    padding: 0 var(--semantics-spacing-large);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--semantics-spacing-bigger);
    align-items: center;
}

.ct-trabalhe__text {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-large);
    align-items: flex-start;
    min-width: 0;
}

.ct-trabalhe__title {
    font-family: var(--semantics-typography-family-poppins);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-large);
    line-height: var(--semantics-typography-baseline-tight);
    letter-spacing: var(--semantics-typography-tracking-tight-1);
    color: var(--semantics-colors-text-heading-default);
    margin: 0;
}

.ct-trabalhe__desc {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 400;
    font-size: var(--semantics-typography-body-16);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-secondary);
    margin: 0;
}

.ct-trabalhe__action {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-larger);
    align-items: center;
}

.ct-trabalhe__card {
    background-color: var(--semantics-colors-fill-background-primary);
    border: 1px solid var(--semantics-colors-stroke-primary);
    border-radius: var(--semantics-radius-larger);
    padding: var(--semantics-spacing-big);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--semantics-spacing-medium);
    text-align: center;
    min-width: 280px;
}

.ct-trabalhe__card-label {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 400;
    font-size: var(--semantics-typography-body-14);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-secondary);
    margin: 0;
}

.ct-trabalhe__card-email {
    font-family: var(--semantics-typography-family-poppins);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-small);
    line-height: var(--semantics-typography-baseline-tight);
    letter-spacing: var(--semantics-typography-tracking-tight-1);
    color: var(--semantics-colors-text-accent-purpura);
    text-decoration: none;
    overflow-wrap: anywhere;
    max-width: 100%;
}

.ct-trabalhe__card-foot {
    font-family: var(--semantics-typography-family-inter);
    font-weight: 600;
    font-size: var(--semantics-typography-body-14);
    line-height: var(--semantics-typography-baseline-normal);
    color: var(--semantics-colors-text-secondary);
    margin: 0;
}

/* ====================================================================
   Responsivo (576/768/1024)
   ==================================================================== */
@media (max-width: 1024px) {
    .ct-form-section__inner {
        grid-template-columns: 1fr;
        gap: var(--semantics-spacing-broad);
    }

    .ct-trabalhe__inner {
        grid-template-columns: 1fr;
    }

    .ct-trabalhe__action {
        align-items: flex-start;
    }

    .ct-trabalhe__card {
        min-width: 0;
        width: 100%;
    }

    .ct-trabalhe__card-email {
        font-size: var(--semantics-typography-body-18);
    }
}

@media (max-width: 768px) {
    .ct-hero__title {
        font-size: var(--semantics-typography-heading-large);
    }

    .ct-hero__title br,
    .ct-hero__desc br {
        display: none;
    }

    .ct-onde__title {
        font-size: var(--semantics-typography-heading-small);
    }

    .ct-trabalhe__title {
        font-size: var(--semantics-typography-heading-small);
    }
}

@media (max-width: 576px) {
    .ct-hero {
        padding: var(--semantics-spacing-bigger) 0;
    }

    .ct-form-section {
        padding: var(--semantics-padding-bigger) 0;
    }

    .ct-onde {
        padding-top: var(--semantics-padding-bigger);
    }

    .ct-onde__map {
        height: 320px;
    }

    .ct-social {
        padding: var(--semantics-padding-bigger) 0;
    }

    .ct-trabalhe {
        padding: var(--semantics-padding-bigger) 0;
    }

    .ct-hero__title {
        font-size: var(--semantics-typography-heading-small);
    }
}

/* ====================================================================
   Contact Form 7 - Toast Notifications
   ==================================================================== */

.cf7-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: #fff;
    padding: 20px 24px;
    border-radius: 16px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2), 0 4px 12px rgba(0, 0, 0, 0.1);
    z-index: 9999;
    opacity: 0;
    transform: translateY(20px) scale(0.95);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    max-width: 420px;
    min-width: 320px;
    pointer-events: all;
    cursor: pointer;
    border-left: 5px solid;
}

.cf7-toast--show {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.cf7-toast__content {
    display: flex;
    align-items: center;
    gap: 14px;
    font-family: var(--semantics-typography-family-inter);
    font-size: 15px;
    font-weight: 500;
    line-height: 1.5;
    color: var(--semantics-colors-text-primary);
}

.cf7-toast__content i {
    font-size: 24px;
    flex-shrink: 0;
}

.cf7-toast--success {
    border-left-color: #10b981;
}

.cf7-toast--success .cf7-toast__content i {
    color: #10b981;
}

.cf7-toast--error {
    border-left-color: #ef4444;
}

.cf7-toast--error .cf7-toast__content i {
    color: #ef4444;
}

.cf7-toast--warning {
    border-left-color: #f59e0b;
}

.cf7-toast--warning .cf7-toast__content i {
    color: #f59e0b;
}

.ct-form__form .wpcf7 {
    width: 100%;
}

.ct-form__form .wpcf7 p br {
    display: none; 
}

.ct-form__form .wpcf7 form p {
    margin-bottom: 15px;
}

@media (max-width: 640px) {
    .cf7-toast {
        bottom: 16px;
        right: 16px;
        left: 16px;
        max-width: none;
        min-width: auto;
    }
}

/* Esconder mensagens padrão do CF7 em todos os estados */
.wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.sent .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output {
    display: none !important;
}

/* Loading state for submit button */
.wpcf7-submit.cf7-loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
    opacity: 0.7;
}

.wpcf7-submit.cf7-loading::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
    border: 2px solid #fff;
    border-radius: 50%;
    border-top-color: transparent;
    animation: cf7-spinner 0.6s linear infinite;
}

@keyframes cf7-spinner {
    to {
        transform: rotate(360deg);
    }
}
