/* ==========================================================================
   GRAVITY FORMS UTILITY CLASSES & ADDITIONAL STYLING
   ========================================================================== */

/* ==========================================================================
   FORM LAYOUT UTILITIES
   ========================================================================== */

/* Two column layout */
.gform_wrapper.gf_two_column .gform_body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}

.gform_wrapper.gf_two_column .gform_footer {
    grid-column: 1 / -1;
}

/* Three column layout */
.gform_wrapper.gf_three_column .gform_body {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2rem;
}

.gform_wrapper.gf_three_column .gform_footer {
    grid-column: 1 / -1;
}

/* Compact form */
.gform_wrapper.gf_compact .gfield {
    margin-bottom: 1rem;
}

.gform_wrapper.gf_compact input,
.gform_wrapper.gf_compact textarea,
.gform_wrapper.gf_compact select {
    padding: 0.5rem;
    font-size: 0.875rem;
}

/* ==========================================================================
   FIELD SIZE UTILITIES
   ========================================================================== */

/* Small fields */
.gform_wrapper .gf_small input,
.gform_wrapper .gf_small textarea,
.gform_wrapper .gf_small select {
    max-width: 200px;
}

/* Medium fields */
.gform_wrapper .gf_medium input,
.gform_wrapper .gf_medium textarea,
.gform_wrapper .gf_medium select {
    max-width: 400px;
}

/* Large fields */
.gform_wrapper .gf_large input,
.gform_wrapper .gf_large textarea,
.gform_wrapper .gf_large select {
    max-width: 600px;
}

/* ==========================================================================
   BUTTON STYLE VARIATIONS
   ========================================================================== */

/* Primary button (default) */
.gform_wrapper input[type="submit"].gf_primary,
.gform_wrapper .gform_button.gf_primary {
    background-color: var(--wp--preset--color--primary, #007cba);
    color: #fff;
}

/* Secondary button */
.gform_wrapper input[type="submit"].gf_secondary,
.gform_wrapper .gform_button.gf_secondary {
    background-color: var(--wp--preset--color--secondary, #6c757d);
    color: #fff;
}

/* Success button */
.gform_wrapper input[type="submit"].gf_success,
.gform_wrapper .gform_button.gf_success {
    background-color: #28a745;
    color: #fff;
}

/* Danger button */
.gform_wrapper input[type="submit"].gf_danger,
.gform_wrapper .gform_button.gf_danger {
    background-color: #dc3545;
    color: #fff;
}

/* Warning button */
.gform_wrapper input[type="submit"].gf_warning,
.gform_wrapper .gform_button.gf_warning {
    background-color: #ffc107;
    color: #212529;
}

/* Info button */
.gform_wrapper input[type="submit"].gf_info,
.gform_wrapper .gform_button.gf_info {
    background-color: #17a2b8;
    color: #fff;
}

/* Light button */
.gform_wrapper input[type="submit"].gf_light,
.gform_wrapper .gform_button.gf_light {
    background-color: #f8f9fa;
    color: #212529;
    border: 1px solid #dee2e6;
}

/* Dark button */
.gform_wrapper input[type="submit"].gf_dark,
.gform_wrapper .gform_button.gf_dark {
    background-color: #343a40;
    color: #fff;
}

/* Outline button variations */
.gform_wrapper input[type="submit"].gf_outline,
.gform_wrapper .gform_button.gf_outline {
    background-color: transparent;
    color: var(--wp--preset--color--primary, #007cba);
    border: 2px solid var(--wp--preset--color--primary, #007cba);
}

.gform_wrapper input[type="submit"].gf_outline:hover,
.gform_wrapper .gform_button.gf_outline:hover {
    background-color: var(--wp--preset--color--primary, #007cba);
    color: #fff;
}

.gform_wrapper input[type="submit"].gf_outline_secondary,
.gform_wrapper .gform_button.gf_outline_secondary {
    background-color: transparent;
    color: var(--wp--preset--color--secondary, #6c757d);
    border: 2px solid var(--wp--preset--color--secondary, #6c757d);
}

.gform_wrapper input[type="submit"].gf_outline_secondary:hover,
.gform_wrapper .gform_button.gf_outline_secondary:hover {
    background-color: var(--wp--preset--color--secondary, #6c757d);
    color: #fff;
}

/* Rounded button */
.gform_wrapper input[type="submit"].gf_rounded,
.gform_wrapper .gform_button.gf_rounded {
    border-radius: 2rem;
}

/* Pill button */
.gform_wrapper input[type="submit"].gf_pill,
.gform_wrapper .gform_button.gf_pill {
    border-radius: 3rem;
    padding-left: 2rem;
    padding-right: 2rem;
}

/* Block button (full width) */
.gform_wrapper input[type="submit"].gf_block,
.gform_wrapper .gform_button.gf_block {
    display: block;
    width: 100%;
}

/* Button with icon */
.gform_wrapper input[type="submit"].gf_with_icon,
.gform_wrapper .gform_button.gf_with_icon {
    position: relative;
    padding-left: 3rem;
}

.gform_wrapper input[type="submit"].gf_with_icon::before,
.gform_wrapper .gform_button.gf_with_icon::before {
    content: "→";
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.2em;
}

/* ==========================================================================
   FIELD STATE UTILITIES
   ========================================================================== */

/* Disabled state */
.gform_wrapper .gfield_disabled input,
.gform_wrapper .gfield_disabled textarea,
.gform_wrapper .gfield_disabled select {
    background-color: #e9ecef;
    cursor: not-allowed;
    opacity: 0.6;
}

/* Read-only state */
.gform_wrapper .gfield_readonly input,
.gform_wrapper .gfield_readonly textarea,
.gform_wrapper .gfield_readonly select {
    background-color: #f8f9fa;
    border-color: #dee2e6;
}

/* ==========================================================================
   CUSTOM FIELD STYLING
   ========================================================================== */

/* Phone field with country code */
.gform_wrapper .ginput_container_phone {
    display: flex;
    gap: 0.5rem;
}

.gform_wrapper .ginput_container_phone .ginput_container_phone_3 {
    flex: 1;
}

.gform_wrapper .ginput_container_phone .ginput_container_phone_1 {
    width: 80px;
}

/* Date field */
.gform_wrapper .ginput_container_date {
    display: flex;
    gap: 0.5rem;
}

.gform_wrapper .ginput_container_date input {
    flex: 1;
}

/* Time field */
.gform_wrapper .ginput_container_time {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.gform_wrapper .ginput_container_time input {
    width: auto;
    min-width: 80px;
}

/* ==========================================================================
   CONDITIONAL LOGIC STYLING
   ========================================================================== */

/* Hidden fields */
.gform_wrapper .gfield_hidden {
    display: none !important;
}

/* Conditional fields with fade effect */
.gform_wrapper .gfield_conditional {
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
}

.gform_wrapper .gfield_conditional.gfield_visible {
    opacity: 1;
    transform: translateY(0);
}

/* ==========================================================================
   LOADING STATES
   ========================================================================== */

/* Form loading state */
.gform_wrapper.gform_loading {
    opacity: 0.6;
    pointer-events: none;
}

.gform_wrapper.gform_loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    margin: -20px 0 0 -20px;
    border: 4px solid #f3f3f3;
    border-top: 4px solid var(--wp--preset--color--primary, #007cba);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ==========================================================================
   PRINT STYLES
   ========================================================================== */

@media print {
    .gform_wrapper .gform_footer,
    .gform_wrapper .gform_page_footer {
        display: none;
    }
    
    .gform_wrapper input,
    .gform_wrapper textarea,
    .gform_wrapper select {
        border: 1px solid #000;
        background: transparent;
    }
    
    .gform_wrapper .gfield_error {
        border-left: 4px solid #000;
    }
}

/* ==========================================================================
   DARK MODE SUPPORT
   ========================================================================== */

@media (prefers-color-scheme: dark) {
    .gform_wrapper {
        /* --gf-bg-color: #2d3748;
        --gf-text-color: #0c0c0c;
        --gf-border-color: #4a5568;
        --gf-input-bg: #1a202c; */
    }
    
    .gform_wrapper input,
    .gform_wrapper textarea,
    .gform_wrapper select {
        background-color: var(--gf-input-bg);
        color: var(--gf-text-color);
        border-color: var(--gf-border-color);
    }
    
    .gform_wrapper .gfield_label {
        color: var(--gf-text-color);
    }
    
    .gform_wrapper .gfield_description {
        color: #a0aec0;
    }
}

/* ==========================================================================
   HIGH CONTRAST MODE
   ========================================================================== */

@media (prefers-contrast: high) {
    .gform_wrapper input,
    .gform_wrapper textarea,
    .gform_wrapper select {
        border-width: 2px;
    }
    
    .gform_wrapper .gform_footer input[type="submit"] {
        border: 2px solid #000;
    }
    
    .gform_wrapper .gfield_error {
        border-left-width: 6px;
    }
}

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
    .gform_wrapper * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    .gform_wrapper .gfield_conditional {
        transition: none;
    }
}
