/* ==========================================================================
   Forms — SANTANA & MARTINS ADVOGADAS
   Unit 4: COMP-09 ContactFormComponent / COMP-10 SchedulingFormComponent
   ========================================================================== */

/* --------------------------------------------------------------------------
   Form Container
   -------------------------------------------------------------------------- */

.sm-form-wrapper {
    max-width: 640px;
}

.sm-cf7-form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

/* --------------------------------------------------------------------------
   Form Groups & Labels
   -------------------------------------------------------------------------- */

.sm-cf7-form p {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.sm-cf7-form label {
    font-size: 0.85rem;
    font-weight: 600;
    color: #222;
    letter-spacing: 0.02em;
}

.sm-cf7-form label .required-mark {
    color: #c0392b;
    margin-left: 2px;
}

/* --------------------------------------------------------------------------
   Input, Textarea, Select
   -------------------------------------------------------------------------- */

.sm-cf7-form input[type="text"],
.sm-cf7-form input[type="email"],
.sm-cf7-form input[type="tel"],
.sm-cf7-form textarea,
.sm-cf7-form select,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea,
.wpcf7-form select {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1.5px solid #ddd;
    border-radius: 4px;
    font-size: 0.95rem;
    color: #222;
    background: #fff;
    transition: border-color 0.2s, box-shadow 0.2s;
    appearance: none;
    -webkit-appearance: none;
    box-sizing: border-box;
    font-family: inherit;
}

.sm-cf7-form input[type="text"]:focus,
.sm-cf7-form input[type="email"]:focus,
.sm-cf7-form input[type="tel"]:focus,
.sm-cf7-form textarea:focus,
.sm-cf7-form select:focus,
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
    outline: none;
    border-color: #f0c040;
    box-shadow: 0 0 0 3px rgba(240, 192, 64, 0.2);
}

.sm-cf7-form input[type="text"]:hover,
.sm-cf7-form input[type="email"]:hover,
.sm-cf7-form input[type="tel"]:hover,
.sm-cf7-form textarea:hover,
.sm-cf7-form select:hover {
    border-color: #bbb;
}

.sm-cf7-form textarea,
.wpcf7-form textarea {
    min-height: 140px;
    resize: vertical;
    line-height: 1.6;
}

/* Select arrow */
.sm-cf7-form select,
.wpcf7-form select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.85rem center;
    padding-right: 2.5rem;
    cursor: pointer;
}

/* --------------------------------------------------------------------------
   Validation States
   -------------------------------------------------------------------------- */

.wpcf7-form input.wpcf7-not-valid,
.wpcf7-form textarea.wpcf7-not-valid,
.wpcf7-form select.wpcf7-not-valid {
    border-color: #c0392b;
    box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.12);
}

.wpcf7-not-valid-tip {
    color: #c0392b;
    font-size: 0.78rem;
    font-weight: 500;
    margin-top: 0.25rem;
    display: block;
}

/* --------------------------------------------------------------------------
   Submit Button
   -------------------------------------------------------------------------- */

.sm-cf7-form input[type="submit"],
.wpcf7-form input[type="submit"] {
    background: #f0c040;
    color: #111;
    border: none;
    border-radius: 4px;
    padding: 0.85rem 2rem;
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    cursor: pointer;
    width: 100%;
    transition: background 0.2s, transform 0.15s;
    font-family: inherit;
}

.sm-cf7-form input[type="submit"]:hover,
.wpcf7-form input[type="submit"]:hover {
    background: #d4a820;
}

.sm-cf7-form input[type="submit"]:active,
.wpcf7-form input[type="submit"]:active {
    transform: translateY(1px);
}

.sm-cf7-form input[type="submit"]:disabled,
.wpcf7-form input[type="submit"]:disabled {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
}

/* --------------------------------------------------------------------------
   Response Messages
   -------------------------------------------------------------------------- */

.wpcf7-response-output {
    border-radius: 4px;
    padding: 0.85rem 1rem;
    font-size: 0.9rem;
    font-weight: 600;
    margin-top: 0.5rem;
    border: none !important;
}

/* Success */
.wpcf7-form.sent .wpcf7-response-output {
    background: #eafaf1;
    color: #1a7a42;
    border-left: 4px solid #2ecc71 !important;
}

/* Error */
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output {
    background: #fdf2f2;
    color: #922b21;
    border-left: 4px solid #e74c3c !important;
}

/* Spam / invalid */
.wpcf7-form.spam .wpcf7-response-output {
    background: #fef9e7;
    color: #7d6608;
    border-left: 4px solid #f0c040 !important;
}

/* --------------------------------------------------------------------------
   Spinner (loading)
   -------------------------------------------------------------------------- */

.wpcf7-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid #ddd;
    border-top-color: #f0c040;
    border-radius: 50%;
    animation: sm-spin 0.7s linear infinite;
    margin-left: 0.5rem;
    vertical-align: middle;
}

@keyframes sm-spin {
    to { transform: rotate(360deg); }
}

/* --------------------------------------------------------------------------
   Honeypot (anti-spam — campo oculto)
   -------------------------------------------------------------------------- */

.wpcf7-form p:has(input[name="_wpcf7_ak_hp_textarea"]),
.sm-honeypot-field {
    display: none !important;
    visibility: hidden !important;
    position: absolute !important;
    left: -9999px !important;
}

/* --------------------------------------------------------------------------
   Contact Page Layout
   -------------------------------------------------------------------------- */

.sm-contact-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: start;
}

/* --------------------------------------------------------------------------
   Scheduling Page Form Block
   -------------------------------------------------------------------------- */

.sm-scheduling-form-block {
    max-width: 640px;
    margin: 2.5rem auto 0;
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    padding: 2rem;
}

.sm-scheduling-form-block__title {
    font-size: 1.15rem;
    font-weight: 700;
    color: #111;
    margin: 0 0 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid #f0c040;
}

/* --------------------------------------------------------------------------
   Fallback (CF7 não ativo)
   -------------------------------------------------------------------------- */

.sm-form-fallback {
    background: #fafafa;
    border: 1.5px dashed #ddd;
    border-radius: 6px;
    padding: 2rem;
    text-align: center;
    color: #555;
}

.sm-form-fallback__title {
    font-size: 1rem;
    font-weight: 700;
    color: #111;
    margin: 0 0 0.75rem;
}

.sm-form-fallback__link {
    display: inline-block;
    margin-top: 0.75rem;
    color: #f0c040;
    font-weight: 700;
    text-decoration: underline;
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */

@media (max-width: 768px) {
    .sm-contact-layout {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .sm-scheduling-form-block {
        padding: 1.5rem 1.25rem;
    }

    .sm-cf7-form input[type="submit"],
    .wpcf7-form input[type="submit"] {
        padding: 0.85rem 1.25rem;
    }
}

@media (max-width: 480px) {
    .sm-form-wrapper {
        max-width: 100%;
    }
}
