@charset "UTF-8";

/* =============================================
   ESTIMATION IMMO LOCAL - FORM STYLES
   Form elements, validation, states
============================================= */

/* ===========================================
   FORM BASICS
============================================= */
.form-row {
    margin-bottom: 1.5rem;
}

.form-row:last-child {
    margin-bottom: 0;
}

.form-row--half {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.form-row--third {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

@media (max-width: 768px) {
    .form-row--half,
    .form-row--third {
        grid-template-columns: 1fr;
    }
}

/* ===========================================
   LABELS
============================================= */
.form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.5rem;
}

.form-label--required::after {
    content: " *";
    color: var(--color-error);
}

.form-label-hint {
    display: block;
    font-size: 0.8125rem;
    color: var(--color-muted);
    font-weight: 400;
    margin-top: 0.25rem;
}

/* ===========================================
   INPUT FIELDS
============================================= */
.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--color-text);
    background-color: var(--color-white);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
    outline: none;
}

.form-input:hover,
.form-select:hover,
.form-textarea:hover {
    border-color: var(--color-primary-light);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(26, 60, 94, 0.1);
}

/* Placeholder */
.form-input::placeholder,
.form-textarea::placeholder {
    color: var(--color-muted);
    opacity: 1;
}

/* Select Styling */
.form-select {
    appearance: none;
    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='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.875rem center;
    background-size: 16px;
    padding-right: 2.5rem;
    cursor: pointer;
}

.form-select:focus {
    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='%231a3c5e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
}

/* Textarea */
.form-textarea {
    min-height: 150px;
    resize: vertical;
}

/* ===========================================
   VALIDATION STATES
============================================= */
.form-input--error,
.form-select--error,
.form-textarea--error {
    border-color: var(--color-error);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'%3E%3C/line%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2.5rem;
}

.form-input--error:focus,
.form-select--error:focus,
.form-textarea--error:focus {
    border-color: var(--color-error);
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1);
}

.form-input--success,
.form-select--success,
.form-textarea--success {
    border-color: var(--color-success);
}

/* Error Message */
.form-error {
    display: block;
    font-size: 0.8125rem;
    color: var(--color-error);
    margin-top: 0.375rem;
}

.form-error::before {
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'%3E%3C/line%3E%3C/svg%3E");
    display: inline-block;
    margin-right: 0.25rem;
    vertical-align: middle;
}

/* Success Message */
.form-success {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    background-color: rgba(5, 150, 105, 0.1);
    border: 1px solid var(--color-success);
    border-radius: var(--radius-md);
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
}

.form-success__icon {
    color: var(--color-success);
    font-size: 1.25rem;
    flex-shrink: 0;
}

.form-success__message {
    font-size: 0.9375rem;
    color: var(--color-success);
}

.form-success__message h4 {
    font-size: 1rem;
    color: var(--color-success);
    margin-bottom: 0.25rem;
}

.form-success__message p {
    margin: 0;
    color: var(--color-text-light);
}

/* ===========================================
   CHECKBOX & RADIO
============================================= */
.form-check {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
}

.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    position: relative;
    width: 20px;
    height: 20px;
    appearance: none;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.form-check input[type="radio"] {
    border-radius: 50%;
}

.form-check input[type="checkbox"]:hover,
.form-check input[type="radio"]:hover {
    border-color: var(--color-primary);
}

.form-check input[type="checkbox"]:checked,
.form-check input[type="radio"]:checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

.form-check input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 2px;
    width: 5px;
    height: 10px;
    border: solid var(--color-white);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.form-check input[type="radio"]:checked::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    background-color: var(--color-white);
    border-radius: 50%;
}

.form-check input[type="checkbox"]:focus,
.form-check input[type="radio"]:focus {
    box-shadow: 0 0 0 3px rgba(26, 60, 94, 0.1);
}

.form-check__label {
    font-size: 0.9375rem;
    color: var(--color-text);
    line-height: 1.5;
}

.form-check__label a {
    color: var(--color-primary);
    text-decoration: underline;
}

/* ===========================================
   FILE INPUT
============================================= */
.form-file {
    position: relative;
}

.form-file__input {
    position: absolute;
    width: 0;
    height: 0;
    opacity: 0;
    overflow: hidden;
}

.form-file__label {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 2rem;
    border: 2px dashed var(--color-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    background-color: var(--color-bg-alt);
}

.form-file__label:hover {
    border-color: var(--color-primary);
    background-color: var(--color-white);
}

.form-file__icon {
    font-size: 2rem;
    color: var(--color-muted);
}

.form-file__text {
    font-size: 0.9375rem;
    color: var(--color-text);
}

.form-file__hint {
    font-size: 0.8125rem;
    color: var(--color-muted);
}

/* ===========================================
   BUTTON GROUPS
============================================= */
.form-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.form-actions--center {
    justify-content: center;
}

.form-actions--right {
    justify-content: flex-end;
}

@media (max-width: 480px) {
    .form-actions {
        flex-direction: column;
    }

    .form-actions .btn {
        width: 100%;
    }
}

/* ===========================================
   CONSENT / GDPR
============================================= */
.form-consent {
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    margin-top: 1.5rem;
}

.form-consent__title {
    font-size: 0.9375rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
}

.form-consent__text {
    font-size: 0.8125rem;
    color: var(--color-muted);
    line-height: 1.6;
}

.form-consent__text a {
    color: var(--color-primary);
    text-decoration: underline;
}

/* ===========================================
   INLINE FORM (Hero)
============================================= */
.form-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    box-shadow: var(--shadow-xl);
}

.form-inline__field {
    flex: 1;
    min-width: 200px;
}

.form-inline__submit {
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .form-inline {
        flex-direction: column;
    }

    .form-inline__field {
        min-width: 100%;
    }
}

/* ===========================================
   LOADING STATE
============================================= */
.btn--loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.btn--loading::after {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    border: 2px solid var(--color-white);
    border-top-color: transparent;
    border-radius: 50%;
    animation: form-spin 0.6s linear infinite;
}

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

/* ===========================================
   GENERAL NOTICE
============================================= */
.form-notice {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-radius: var(--radius-md);
    font-size: 0.9375rem;
    margin-bottom: 1.5rem;
}

.form-notice--info {
    background-color: rgba(26, 60, 94, 0.08);
    border: 1px solid var(--color-primary-light);
}

.form-notice--warning {
    background-color: rgba(217, 119, 6, 0.1);
    border: 1px solid var(--color-warning);
}

.form-notice__icon {
    flex-shrink: 0;
    font-size: 1.25rem;
}

.form-notice--info .form-notice__icon {
    color: var(--color-primary);
}

.form-notice--warning .form-notice__icon {
    color: var(--color-warning);
}

/* ===========================================
   RECAPTCHA
============================================= */
.form-recaptcha {
    margin-top: 1rem;
}

/* ===========================================
   CONTACT FORM 7 SUPPORT (if used)
============================================= */
.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;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--color-text);
    background-color: var(--color-white);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
    outline: none;
}

.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(26, 60, 94, 0.1);
}

.wpcf7-not-valid {
    border-color: var(--color-error) !important;
}

.wpcf7-not-valid-tip {
    font-size: 0.8125rem;
    color: var(--color-error);
    margin-top: 0.375rem;
}

.wpcf7-response-output {
    margin: 1.5rem 0 0;
    padding: 1rem 1.25rem;
    border-radius: var(--radius-md);
    font-size: 0.9375rem;
}

.wpcf7-mail-sent-ok {
    background-color: rgba(5, 150, 105, 0.1);
    border-color: var(--color-success);
    color: var(--color-success);
}

.wpcf7-validation-errors {
    background-color: rgba(220, 38, 38, 0.1);
    border-color: var(--color-error);
    color: var(--color-error);
}

.screen-reader-response {
    position: absolute;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    width: 1px;
}
