/**
 * Fluent Forms & Fluent Support Overrides
 * Matches CloveTheme design system
 *
 * @package CloveTheme
 * @since 1.0.0
 */

/* ==========================================================================
   FLUENT FORMS
   Structure: .fluentform > .ff-el-group
   ========================================================================== */

/* Form container */
.fluentform {
    max-width: 640px;
}

/* Field groups */
.fluentform .ff-el-group {
    margin-block-end: var(--space-5);
}

/* Labels */
.fluentform .ff-el-input--label label {
    display: block;
    margin-block-end: var(--space-2);
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--color-text-secondary);
}

/* Required indicator */
.fluentform .ff-el-is-required .ff-el-required {
    color: var(--color-error);
    margin-inline-start: var(--space-1);
}

/* Text inputs */
.fluentform input[type="text"],
.fluentform input[type="email"],
.fluentform input[type="tel"],
.fluentform input[type="url"],
.fluentform input[type="password"],
.fluentform input[type="number"],
.fluentform textarea,
.fluentform select {
    width: 100%;
    padding: var(--input-padding-y) var(--input-padding-x);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    color: var(--color-text-primary);
    background: var(--input-bg);
    border: var(--input-border);
    border-radius: var(--input-radius);
    box-shadow: var(--shadow-inner);
    transition:
        border-color var(--duration-200) var(--ease-out),
        box-shadow var(--duration-200) var(--ease-out),
        background-color var(--duration-200) var(--ease-out);
}

.fluentform input:focus,
.fluentform textarea:focus,
.fluentform select:focus {
    outline: none;
    background: var(--color-surface-primary);
    border-color: var(--color-brand-primary);
    box-shadow:
        0 0 0 4px rgba(99, 102, 241, 0.1),
        inset 0 1px 2px rgba(0, 0, 0, 0.02);
}

.fluentform input::placeholder,
.fluentform textarea::placeholder {
    color: var(--color-text-tertiary);
}

/* Select dropdown */
.fluentform 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='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    padding-inline-end: var(--space-10);
}

/* Textarea */
.fluentform textarea {
    min-height: 150px;
    resize: vertical;
    line-height: var(--leading-relaxed);
}

/* ==========================================================================
   SUBMIT BUTTON
   ========================================================================== */

.fluentform .ff-btn-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-8);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-text-inverse);
    background: var(--gradient-brand);
    border: none;
    border-radius: var(--radius-xl);
    cursor: pointer;
    box-shadow: var(--shadow-brand);
    transition:
        transform var(--duration-300) var(--ease-out),
        box-shadow var(--duration-300) var(--ease-out);
}

.fluentform .ff-btn-submit:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-brand-hover);
}

.fluentform .ff-btn-submit:focus-visible {
    outline: 2px solid var(--color-brand-primary);
    outline-offset: 2px;
}

.fluentform .ff-btn-submit:disabled,
.fluentform .ff-btn-submit.ff-working {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

/* Loading spinner */
.fluentform .ff-btn-submit.ff-working::after {
    content: '';
    width: 1rem;
    height: 1rem;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-radius: 50%;
    animation: ff-spin 0.6s linear infinite;
}

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

/* ==========================================================================
   CHECKBOX & RADIO
   ========================================================================== */

.fluentform .ff-el-form-check {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    margin-block-end: var(--space-2);
}

.fluentform .ff-el-form-check input[type="checkbox"],
.fluentform .ff-el-form-check input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    flex-shrink: 0;
    width: 1.25rem;
    height: 1.25rem;
    margin: 0;
    margin-block-start: 2px;
    border: 2px solid var(--color-border-strong);
    background: var(--color-surface-primary);
    cursor: pointer;
    position: relative;
    transition: all var(--duration-200) var(--ease-out);
}

.fluentform .ff-el-form-check input[type="checkbox"] {
    border-radius: var(--radius-sm);
}

.fluentform .ff-el-form-check input[type="radio"] {
    border-radius: var(--radius-full);
}

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

/* Checkbox checkmark */
.fluentform .ff-el-form-check input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    inset-block-start: 2px;
    inset-inline-start: 5px;
    width: 5px;
    height: 9px;
    border: solid var(--color-surface-primary);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Radio dot */
.fluentform .ff-el-form-check input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    inset: 3px;
    background: var(--color-surface-primary);
    border-radius: var(--radius-full);
}

.fluentform .ff-el-form-check label {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: var(--leading-relaxed);
    cursor: pointer;
}

/* ==========================================================================
   GDPR CONSENT FIELD
   ========================================================================== */

.fluentform .ff_gdpr_field {
    padding: var(--space-4);
    background: var(--color-surface-secondary);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-subtle);
}

.fluentform .ff_gdpr_field .ff-el-form-check {
    margin-block-end: 0;
}

.fluentform .ff_gdpr_field a {
    color: var(--color-brand-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.fluentform .ff_gdpr_field a:hover {
    color: var(--color-brand-dark);
}

/* ==========================================================================
   SUCCESS & ERROR MESSAGES
   ========================================================================== */

/* Success message */
.fluentform .ff-message-success {
    padding: var(--space-5);
    background: var(--color-success-light);
    color: var(--color-success);
    border-radius: var(--radius-lg);
    font-weight: var(--weight-medium);
    text-align: center;
}

/* Field error messages */
.fluentform .error.text-danger,
.fluentform .ff-el-is-error .error {
    display: block;
    margin-block-start: var(--space-1);
    font-size: var(--text-sm);
    color: var(--color-error);
}

/* Error state on inputs */
.fluentform .ff-el-is-error input,
.fluentform .ff-el-is-error textarea,
.fluentform .ff-el-is-error select {
    border-color: var(--color-error);
}

.fluentform .ff-el-is-error input:focus,
.fluentform .ff-el-is-error textarea:focus,
.fluentform .ff-el-is-error select:focus {
    box-shadow:
        0 0 0 4px rgba(239, 68, 68, 0.1),
        inset 0 1px 2px rgba(0, 0, 0, 0.02);
}

/* ==========================================================================
   TWO COLUMN LAYOUT (Name Fields)
   ========================================================================== */

.fluentform .ff-t-container {
    display: flex;
    gap: var(--space-4);
}

.fluentform .ff-t-cell {
    flex: 1;
}

/* Stack on mobile */
@media (max-width: 640px) {
    .fluentform .ff-t-container {
        flex-direction: column;
        gap: var(--space-5);
    }
}

/* ==========================================================================
   FLUENT SUPPORT PORTAL
   Structure: .fluent_support_* and .fs-*
   ========================================================================== */

/* Ticket list container */
.fs-portal-tickets,
.fluent_support_portal {
    background: var(--color-surface-primary);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

/* Create ticket button */
.fs-portal-header .fs-btn-primary,
.fluent_support_portal .fs-create-ticket-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--color-text-inverse);
    background: var(--gradient-brand);
    border: none;
    border-radius: var(--radius-lg);
    cursor: pointer;
    text-decoration: none;
    box-shadow: var(--shadow-brand);
    transition: all var(--duration-200) var(--ease-out);
}

.fs-portal-header .fs-btn-primary:hover,
.fluent_support_portal .fs-create-ticket-btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-brand-hover);
}

/* Ticket row */
.fs-portal-ticket-row,
.fs-ticket-item {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    border-block-end: 1px solid var(--color-border-subtle);
    transition: background-color var(--duration-200);
}

.fs-portal-ticket-row:hover,
.fs-ticket-item:hover {
    background: var(--color-surface-secondary);
}

.fs-portal-ticket-row:last-child,
.fs-ticket-item:last-child {
    border-block-end: none;
}

/* Ticket title */
.fs-ticket-title {
    flex: 1;
    font-weight: var(--weight-medium);
    color: var(--color-text-primary);
}

.fs-ticket-title a {
    color: inherit;
    text-decoration: none;
}

.fs-ticket-title a:hover {
    color: var(--color-brand-primary);
}

/* Ticket meta */
.fs-ticket-meta {
    font-size: var(--text-sm);
    color: var(--color-text-tertiary);
}

/* Status badges */
.fs-ticket-status,
.fs-status-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: var(--radius-full);
}

.fs-ticket-status-open,
.fs-status-badge--open {
    background: var(--color-success-light);
    color: var(--color-success);
}

.fs-ticket-status-pending,
.fs-status-badge--pending {
    background: var(--color-warning-light);
    color: var(--color-warning);
}

.fs-ticket-status-closed,
.fs-status-badge--closed {
    background: var(--color-surface-secondary);
    color: var(--color-text-tertiary);
}

/* ==========================================================================
   TICKET VIEW
   ========================================================================== */

/* Ticket header */
.fs-ticket-header {
    padding: var(--space-6);
    border-block-end: 1px solid var(--color-border-subtle);
}

.fs-ticket-header h1,
.fs-ticket-header .fs-ticket-subject {
    margin: 0 0 var(--space-2);
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    color: var(--color-text-primary);
}

/* Ticket conversation */
.fs-ticket-conversation {
    padding: var(--space-6);
}

/* Message bubble */
.fs-message,
.fs-ticket-reply {
    margin-block-end: var(--space-5);
    padding: var(--space-5);
    background: var(--color-surface-secondary);
    border-radius: var(--radius-lg);
}

.fs-message--agent,
.fs-ticket-reply--agent {
    background: rgba(99, 102, 241, 0.08);
    border-inline-start: 3px solid var(--color-brand-primary);
}

.fs-message-author {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-block-end: var(--space-3);
}

.fs-message-author-name {
    font-weight: var(--weight-semibold);
    color: var(--color-text-primary);
}

.fs-message-date {
    font-size: var(--text-sm);
    color: var(--color-text-tertiary);
}

.fs-message-content {
    font-size: var(--text-base);
    color: var(--color-text-primary);
    line-height: var(--leading-relaxed);
}

/* Reply form */
.fs-reply-form textarea {
    width: 100%;
    min-height: 120px;
    padding: var(--input-padding-y) var(--input-padding-x);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    color: var(--color-text-primary);
    background: var(--input-bg);
    border: var(--input-border);
    border-radius: var(--input-radius);
    resize: vertical;
}

.fs-reply-form textarea:focus {
    outline: none;
    border-color: var(--color-brand-primary);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1);
}

/* ==========================================================================
   FLUENTCRM UNSUBSCRIBE PAGE
   ========================================================================== */

.fc-unsubscribe-form {
    max-width: 480px;
    margin: 0 auto;
    padding: var(--space-8);
    background: var(--color-surface-primary);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    text-align: center;
}

.fc-unsubscribe-form h2 {
    margin: 0 0 var(--space-4);
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: var(--weight-bold);
    color: var(--color-text-primary);
}

.fc-unsubscribe-form p {
    margin: 0 0 var(--space-6);
    color: var(--color-text-secondary);
}

.fc-unsubscribe-form .fc-btn {
    display: inline-flex;
    padding: var(--space-3) var(--space-6);
    font-weight: var(--weight-semibold);
    color: var(--color-text-inverse);
    background: var(--color-error);
    border: none;
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--duration-200);
}

.fc-unsubscribe-form .fc-btn:hover {
    background: var(--color-error-dark);
}
