/* ============================================================
   CONTATO — estilos específicos da página
   Depende de: python.css (service-hero) e home.css (base)
   ============================================================ */

/* ===== HERO ===== */
.contato-hero .service-hero__inner {
    position: relative;
    display: block;
    width: 100%;
    min-height: calc(100svh - 72px);
    margin: 0;
    padding: 0;
}

.contato-hero .service-hero__copy {
    position: relative;
    z-index: 2;
    display: flex;
    width: min(70vw, 860px);
    min-height: calc(100svh - 72px);
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    margin-left: max(var(--space-3), calc((100vw - var(--container-xl)) / 2 - var(--space-20)));
    padding-block: var(--space-20);
}

.contato-hero .service-hero__copy .section-title {
    max-width: 26ch;
}

.contato-hero__media {
    position: absolute;
    top: 50%;
    right: max(var(--space-6), calc((100vw - var(--container-xl)) / 2 - var(--space-20)));
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(40vw, 860px);
    min-width: 0;
    min-height: 0;
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
    pointer-events: none;
    transform: translate(132px, -50%);
}

.contato-hero__media::before,
.contato-hero__media::after {
    display: none;
    content: none;
}

.contato-hero__image {
    display: block;
    width: min(122%, 880px);
    height: auto;
    max-height: min(84svh, 780px);
    margin: 0 auto;
    padding: 0;
    object-fit: contain;
    object-position: center;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    filter: none;
    mix-blend-mode: normal;
}

.contato-hero__image--dark {
    display: none;
}

.contato-hero__image--light {
    transform: translateX(60px);
}

html.theme-dark .contato-hero__image--light {
    display: none;
}

html.theme-dark .contato-hero__image--dark {
    display: block;
    transform: translateX(60px);
}

.contato-hero__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-3);
    margin: var(--space-6) 0 0;
    padding: 0;
    list-style: none;
}

.contato-hero__tags li {
    display: inline-flex;
    align-items: center;
    padding: var(--space-2) var(--space-3);
    color: var(--color-accent);
    font-size: var(--font-size-eyebrow);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--letter-spacing-eyebrow);
    text-transform: uppercase;
    background: color-mix(in srgb, var(--color-accent) 10%, transparent);
    border: 1px solid color-mix(in srgb, var(--color-accent) 24%, transparent);
    border-radius: var(--radius-sm);
}

/* ===== SEÇÃO PRINCIPAL ===== */
.contato-section {
    padding: var(--space-20) clamp(var(--space-4), 4vw, var(--space-8));
    background:
        radial-gradient(circle at 88% 12%, color-mix(in srgb, var(--color-accent) 8%, transparent), transparent 30%),
        linear-gradient(180deg, var(--color-bg-soft) 0%, var(--color-bg) 100%);
}

.contato-section__inner {
    width: min(100%, var(--container-xl));
    margin-inline: auto;
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: var(--space-16);
    align-items: start;
}

/* ===== INFO ===== */
.contato-info {
    position: sticky;
    top: calc(72px + var(--space-8));
}

.contato-info .eyebrow {
    margin-bottom: var(--space-3);
}

.contato-info .section-title {
    max-width: 520px;
    margin-bottom: var(--space-8);
    font-size: clamp(2rem, 3vw, 2.75rem);
}

.contato-info__text {
    color: var(--color-text-body);
    font-size: clamp(1rem, 1.2vw, 1.0625rem);
    line-height: 1.7;
    margin: 0 0 var(--space-5);
    max-width: 520px;
}

.contato-info__text:last-of-type {
    margin-bottom: var(--space-10);
}

/* Canais de contato */
.contato-canais {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.contato-canal {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    padding: var(--space-4) var(--space-6);
    background:
        linear-gradient(180deg,
            color-mix(in srgb, var(--color-surface) 84%, transparent),
            color-mix(in srgb, var(--color-surface) 66%, transparent));
    border: 1px solid color-mix(in srgb, var(--color-border-strong) 40%, transparent);
    border-left: 3px solid var(--color-accent);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(12px) saturate(1.16);
    transition: transform 160ms ease, box-shadow 160ms ease;
}

.contato-canal:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-card);
}

.contato-canal__label {
    color: var(--color-text-muted);
    font-size: var(--font-size-eyebrow);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--letter-spacing-eyebrow);
    text-transform: uppercase;
}

.contato-canal__link {
    color: var(--color-text);
    font-size: var(--font-size-body);
    font-weight: var(--font-weight-medium);
    text-decoration: none;
    transition: color 140ms ease;
}

.contato-canal__link:hover {
    color: var(--color-accent);
    text-decoration: underline;
    text-underline-offset: 4px;
}

/* ===== FORM WRAPPER ===== */
.contato-form-wrapper {
    position: relative;
}

/* ===== FORMULÁRIO ===== */
.contato-form {
    padding: var(--space-10);
    background:
        linear-gradient(180deg,
            color-mix(in srgb, var(--color-surface) 84%, transparent),
            color-mix(in srgb, var(--color-surface) 66%, transparent));
    border: 1px solid color-mix(in srgb, var(--color-border-strong) 42%, transparent);
    border-radius: var(--radius-lg);
    box-shadow:
        var(--shadow-card),
        inset 0 1px 0 color-mix(in srgb, var(--color-text) 8%, transparent);
    backdrop-filter: blur(12px) saturate(1.16);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

/* Honeypot — completamente invisível para usuários */
.contato-form__honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

.contato-form__group {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.contato-form__label {
    color: var(--color-text);
    font-size: var(--font-size-caption);
    font-weight: var(--font-weight-medium);
    letter-spacing: 0.02em;
}

.contato-form__required {
    color: var(--color-accent);
    margin-left: var(--space-1);
}

.contato-form__input,
.contato-form__select,
.contato-form__textarea {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    color: var(--color-text);
    font-family: var(--font-base);
    font-size: var(--font-size-body);
    line-height: 1.5;
    background: color-mix(in srgb, var(--color-bg) 60%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-border-strong) 70%, transparent);
    border-radius: var(--radius-md);
    outline: none;
    transition: border-color 140ms ease, box-shadow 140ms ease;
    appearance: none;
    -webkit-appearance: none;
}

.contato-form__input::placeholder,
.contato-form__textarea::placeholder {
    color: var(--color-text-muted);
}

.contato-form__input:focus,
.contato-form__select:focus,
.contato-form__textarea:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 16%, transparent);
}

.contato-form__select {
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23717A76' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-4) center;
    padding-right: var(--space-10);
}

html.theme-dark .contato-form__select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A9BAA' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
}

.contato-form__select option {
    color: var(--color-text);
    background: var(--color-surface);
}

.contato-form__textarea {
    resize: vertical;
    min-height: 120px;
}

.contato-form__submit {
    align-self: flex-start;
    margin-top: var(--space-2);
}

.contato-form__submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ===== ESTADOS ===== */
.contato-estado {
    padding: var(--space-8) var(--space-10);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.contato-estado[hidden] {
    display: none;
}

.contato-estado__title {
    margin: 0;
    color: var(--color-text);
    font-size: var(--font-size-h3);
    font-weight: var(--font-weight-medium);
    line-height: 1.3;
}

.contato-estado__text {
    margin: 0;
    color: var(--color-text-body);
    font-size: var(--font-size-body);
    line-height: 1.65;
}

.contato-estado__text a {
    color: var(--color-accent);
    text-underline-offset: 3px;
}

.contato-estado__text a:hover {
    text-decoration: none;
}

.contato-estado--pendente {
    background: color-mix(in srgb, var(--color-warning) 10%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-warning) 30%, transparent);
}

.contato-estado--sucesso {
    background: color-mix(in srgb, var(--color-success) 10%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-success) 30%, transparent);
}

.contato-estado--erro {
    background: color-mix(in srgb, var(--color-danger) 10%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--color-danger) 30%, transparent);
}

/* ===== RESPONSIVIDADE ===== */
@media (max-width: 900px) {
    .contato-hero .service-hero__inner {
        width: min(100% - var(--space-6), var(--container-xl));
        min-height: calc(100svh - 96px);
        margin-inline: auto;
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-8);
        padding-block: var(--space-16);
    }

    .contato-hero .service-hero__copy {
        width: 100%;
        min-height: auto;
        margin-left: 0;
        padding-block: 0;
    }

    .contato-hero .contato-hero__media {
        position: relative;
        top: auto;
        right: auto;
        width: 100%;
        transform: none;
    }

    .contato-hero__image {
        width: min(108%, 700px);
        max-height: min(62svh, 580px);
    }

    .contato-section__inner {
        grid-template-columns: 1fr;
        gap: var(--space-12);
    }

    .contato-info {
        position: static;
    }

    .contato-info .section-title {
        max-width: 100%;
    }

    .contato-info__text {
        max-width: 100%;
    }
}

@media (max-width: 640px) {
    .contato-hero .service-hero__inner {
        width: min(100% - var(--space-4), var(--container-xl));
        padding-block: var(--space-12);
    }

    .contato-hero__media {
        padding: 0;
    }

    .contato-hero__image {
        width: 112%;
        max-width: none;
        max-height: min(56svh, 460px);
    }

    .contato-section {
        padding-block: var(--space-12);
    }

    .contato-form {
        padding: var(--space-8) var(--space-6);
    }

    .contato-estado {
        padding: var(--space-6);
    }
}
