/* ============================
   AABB Cadastro - Form Styles
   High specificity to override WP themes
   ============================ */

#aabb-form-wrapper {
    --aabb-primary: #1a1a5e;
    --aabb-primary-light: #2a2a7e;
    --aabb-primary-bg: #f0f1f8;
    --aabb-primary-border: #c5c6e0;
    --aabb-accent: #d4a843;
    --aabb-accent-light: #e6c36a;
    --aabb-success: #10b981;
    --aabb-danger: #ef4444;
    --aabb-text: #1a1a3e;
    --aabb-text-light: #6b7280;
    --aabb-bg: #ffffff;
    --aabb-border: #e5e7eb;
    --aabb-radius: 12px;
    --aabb-shadow: 0 4px 24px rgba(26, 26, 94, 0.08);

    max-width: 720px !important;
    margin: 30px auto !important;
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif !important;
    color: var(--aabb-text) !important;
    box-sizing: border-box !important;
    line-height: 1.5 !important;
}

#aabb-form-wrapper *,
#aabb-form-wrapper *::before,
#aabb-form-wrapper *::after {
    box-sizing: border-box !important;
}

/* Progress Bar */
#aabb-form-wrapper .aabb-progress {
    margin-bottom: 32px !important;
    padding: 0 !important;
}

#aabb-form-wrapper .aabb-progress-bar {
    height: 6px !important;
    background: var(--aabb-border) !important;
    border-radius: 3px !important;
    overflow: hidden !important;
    margin-bottom: 16px !important;
    border: none !important;
}

#aabb-form-wrapper .aabb-progress-fill {
    height: 100% !important;
    background: linear-gradient(90deg, var(--aabb-primary), var(--aabb-primary-light)) !important;
    border-radius: 3px !important;
    transition: width 0.4s ease !important;
    width: 14.28%;
}

#aabb-form-wrapper .aabb-steps {
    display: flex !important;
    justify-content: space-between !important;
    margin-bottom: 6px !important;
    list-style: none !important;
    padding: 0 !important;
}

#aabb-form-wrapper .aabb-step {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    background: var(--aabb-border) !important;
    color: var(--aabb-text-light) !important;
    transition: all 0.3s ease !important;
    border: none !important;
    line-height: 1 !important;
}

#aabb-form-wrapper .aabb-step.active {
    background: var(--aabb-primary) !important;
    color: #fff !important;
    box-shadow: 0 2px 12px rgba(26, 26, 94, 0.35) !important;
}

#aabb-form-wrapper .aabb-step.done {
    background: var(--aabb-success) !important;
    color: #fff !important;
}

#aabb-form-wrapper .aabb-step.clickable {
    cursor: pointer !important;
}

#aabb-form-wrapper .aabb-step.clickable:hover {
    transform: scale(1.15) !important;
    box-shadow: 0 2px 8px rgba(26, 26, 94, 0.25) !important;
}

#aabb-form-wrapper .aabb-step-labels {
    display: flex !important;
    justify-content: space-between !important;
    font-size: 11px !important;
    color: var(--aabb-text-light) !important;
    text-align: center !important;
    padding: 0 !important;
    margin: 0 !important;
}

#aabb-form-wrapper .aabb-step-labels span {
    width: 36px !important;
    text-align: center !important;
    white-space: nowrap !important;
    font-size: 11px !important;
}

/* Section Header */
#aabb-form-wrapper .aabb-section-header {
    background: linear-gradient(135deg, var(--aabb-primary), var(--aabb-primary-light)) !important;
    color: #fff !important;
    padding: 18px 24px !important;
    border-radius: var(--aabb-radius) var(--aabb-radius) 0 0 !important;
    margin: -24px -24px 24px -24px !important;
    border: none !important;
}

#aabb-form-wrapper .aabb-section-header h2 {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    letter-spacing: 0.3px !important;
    color: #fff !important;
    line-height: 1.3 !important;
    border: none !important;
    background: none !important;
}

/* Form Steps */
#aabb-form-wrapper .aabb-form-step {
    display: none !important;
    background: var(--aabb-bg) !important;
    border-radius: var(--aabb-radius) !important;
    padding: 24px !important;
    box-shadow: var(--aabb-shadow) !important;
    border: 1px solid var(--aabb-border) !important;
    animation: aabbFadeIn 0.35s ease !important;
}

#aabb-form-wrapper .aabb-form-step.active {
    display: block !important;
}

@keyframes aabbFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Fields */
#aabb-form-wrapper .aabb-field {
    margin-bottom: 20px !important;
    padding: 0 !important;
}

#aabb-form-wrapper .aabb-field > label {
    display: block !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    color: var(--aabb-text) !important;
    line-height: 1.4 !important;
}

#aabb-form-wrapper .aabb-field input[type="text"],
#aabb-form-wrapper .aabb-field input[type="email"],
#aabb-form-wrapper .aabb-field input[type="date"],
#aabb-form-wrapper .aabb-field input[type="tel"],
#aabb-form-wrapper .aabb-field input[type="number"],
#aabb-form-wrapper .aabb-field select,
#aabb-form-wrapper .aabb-field textarea {
    width: 100% !important;
    padding: 12px 16px !important;
    border: 2px solid var(--aabb-border) !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    color: var(--aabb-text) !important;
    background: #fff !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    box-sizing: border-box !important;
    font-family: inherit !important;
    height: auto !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    outline: none !important;
}

#aabb-form-wrapper .aabb-field select {
    -webkit-appearance: menulist !important;
    appearance: menulist !important;
    cursor: pointer !important;
}

#aabb-form-wrapper .aabb-field input:focus,
#aabb-form-wrapper .aabb-field select:focus,
#aabb-form-wrapper .aabb-field textarea:focus {
    outline: none !important;
    border-color: var(--aabb-primary) !important;
    box-shadow: 0 0 0 3px rgba(26, 26, 94, 0.12) !important;
}

#aabb-form-wrapper .aabb-field input.error,
#aabb-form-wrapper .aabb-field select.error {
    border-color: var(--aabb-danger) !important;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}

#aabb-form-wrapper .aabb-field input::placeholder {
    color: #9ca3af !important;
    opacity: 1 !important;
}

#aabb-form-wrapper .req {
    color: var(--aabb-danger) !important;
    font-weight: 700 !important;
}

#aabb-form-wrapper .aabb-error {
    display: none !important;
    color: var(--aabb-danger) !important;
    font-size: 12px !important;
    margin-top: 4px !important;
    font-weight: 500 !important;
}

#aabb-form-wrapper .aabb-error.show {
    display: block !important;
}

#aabb-form-wrapper .aabb-hint {
    display: block !important;
    font-size: 12px !important;
    color: var(--aabb-text-light) !important;
    margin-top: 4px !important;
}

/* Radio and Checkbox */
#aabb-form-wrapper .aabb-radio-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

#aabb-form-wrapper .aabb-radio,
#aabb-form-wrapper .aabb-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 16px !important;
    border: 2px solid var(--aabb-border) !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    background: #fff !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}

#aabb-form-wrapper .aabb-radio:hover,
#aabb-form-wrapper .aabb-checkbox:hover {
    border-color: var(--aabb-primary-border) !important;
    background: var(--aabb-primary-bg) !important;
}

#aabb-form-wrapper .aabb-radio:has(input:checked),
#aabb-form-wrapper .aabb-checkbox:has(input:checked) {
    border-color: var(--aabb-primary) !important;
    background: var(--aabb-primary-bg) !important;
}

#aabb-form-wrapper .aabb-radio input[type="radio"],
#aabb-form-wrapper .aabb-checkbox input[type="checkbox"] {
    accent-color: var(--aabb-primary) !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
    -webkit-appearance: auto !important;
    appearance: auto !important;
    padding: 0 !important;
    border: none !important;
}

#aabb-form-wrapper .aabb-checkbox span {
    line-height: 1.4 !important;
    color: var(--aabb-text) !important;
}

#aabb-form-wrapper .aabb-section-subtitle {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--aabb-text) !important;
    margin-bottom: 12px !important;
}

/* Row Layout */
#aabb-form-wrapper .aabb-row {
    display: flex !important;
    gap: 16px !important;
}

#aabb-form-wrapper .aabb-col-sm {
    flex: 0 0 35% !important;
}

#aabb-form-wrapper .aabb-col-lg {
    flex: 1 !important;
}

/* Dependents */
#aabb-form-wrapper .aabb-dependent-card {
    background: var(--aabb-primary-bg) !important;
    border: 2px solid var(--aabb-primary-border) !important;
    border-radius: var(--aabb-radius) !important;
    padding: 20px !important;
    margin-bottom: 16px !important;
    position: relative !important;
}

#aabb-form-wrapper .aabb-dependent-card h3 {
    margin: 0 0 16px 0 !important;
    padding: 0 !important;
    font-size: 15px !important;
    color: var(--aabb-primary) !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    border: none !important;
    background: none !important;
}

#aabb-form-wrapper .aabb-dependent-card h3 .dep-number {
    background: var(--aabb-primary) !important;
    color: #fff !important;
    width: 24px !important;
    height: 24px !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 12px !important;
    line-height: 1 !important;
}

#aabb-form-wrapper .aabb-dep-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
}

#aabb-form-wrapper .aabb-dep-row .aabb-field {
    margin-bottom: 12px !important;
}

#aabb-form-wrapper .aabb-dep-row .aabb-field.full-width {
    grid-column: 1 / -1 !important;
}

#aabb-form-wrapper .aabb-dep-row .aabb-field label {
    font-size: 13px !important;
    font-weight: 500 !important;
}

#aabb-form-wrapper .aabb-dep-row .aabb-field input,
#aabb-form-wrapper .aabb-dep-row .aabb-field select {
    padding: 10px 12px !important;
    font-size: 14px !important;
}

/* Navigation Buttons */
#aabb-form-wrapper .aabb-nav {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-top: 24px !important;
    gap: 12px !important;
}

#aabb-form-wrapper .aabb-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 28px !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    border: none !important;
    transition: all 0.2s !important;
    font-family: inherit !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

#aabb-form-wrapper .aabb-btn svg {
    flex-shrink: 0 !important;
}

#aabb-form-wrapper .aabb-btn-primary {
    background: linear-gradient(135deg, var(--aabb-accent), var(--aabb-accent-light)) !important;
    color: #1a1a3e !important;
    margin-left: auto !important;
}

#aabb-form-wrapper .aabb-btn-primary:hover {
    box-shadow: 0 4px 16px rgba(212, 168, 67, 0.45) !important;
    transform: translateY(-1px) !important;
    color: #1a1a3e !important;
}

#aabb-form-wrapper .aabb-btn-outline {
    background: transparent !important;
    color: var(--aabb-primary) !important;
    border: 2px solid var(--aabb-primary-border) !important;
}

#aabb-form-wrapper .aabb-btn-outline:hover {
    background: var(--aabb-primary-bg) !important;
    border-color: var(--aabb-primary) !important;
    color: var(--aabb-primary) !important;
}

#aabb-form-wrapper .aabb-btn-success {
    background: linear-gradient(135deg, var(--aabb-primary), var(--aabb-primary-light)) !important;
    color: #fff !important;
    margin-left: auto !important;
}

#aabb-form-wrapper .aabb-btn-success:hover {
    box-shadow: 0 4px 16px rgba(26, 26, 94, 0.45) !important;
    transform: translateY(-1px) !important;
    color: #fff !important;
}

#aabb-form-wrapper .aabb-btn:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* Success Screen */
#aabb-form-wrapper .aabb-success {
    text-align: center !important;
    padding: 48px 24px !important;
    background: var(--aabb-bg) !important;
    border-radius: var(--aabb-radius) !important;
    box-shadow: var(--aabb-shadow) !important;
    border: 1px solid var(--aabb-border) !important;
}

#aabb-form-wrapper .aabb-success-icon {
    margin-bottom: 20px !important;
    animation: aabbScaleIn 0.5s ease !important;
}

@keyframes aabbScaleIn {
    from { transform: scale(0); }
    to { transform: scale(1); }
}

#aabb-form-wrapper .aabb-success h2 {
    margin: 0 0 8px 0 !important;
    color: var(--aabb-success) !important;
    font-size: 22px !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

#aabb-form-wrapper .aabb-success p {
    color: var(--aabb-text-light) !important;
    margin: 0 0 24px 0 !important;
    font-size: 15px !important;
}

/* Loading Spinner */
#aabb-form-wrapper .aabb-spinner {
    display: inline-block !important;
    width: 18px !important;
    height: 18px !important;
    border: 2px solid rgba(255,255,255,0.3) !important;
    border-radius: 50% !important;
    border-top-color: #fff !important;
    animation: aabbSpin 0.6s linear infinite !important;
}

@keyframes aabbSpin {
    to { transform: rotate(360deg); }
}

/* Responsive */
@media (max-width: 640px) {
    #aabb-form-wrapper {
        margin: 16px !important;
    }

    #aabb-form-wrapper .aabb-row {
        flex-direction: column !important;
        gap: 0 !important;
    }

    #aabb-form-wrapper .aabb-col-sm,
    #aabb-form-wrapper .aabb-col-lg {
        flex: 1 !important;
    }

    #aabb-form-wrapper .aabb-dep-row {
        grid-template-columns: 1fr !important;
    }

    #aabb-form-wrapper .aabb-step-labels {
        display: none !important;
    }

    #aabb-form-wrapper .aabb-btn {
        padding: 10px 20px !important;
        font-size: 14px !important;
    }

    #aabb-form-wrapper .aabb-section-header {
        padding: 14px 18px !important;
        margin: -24px -24px 20px -24px !important;
    }
}
