/**
 * License Capture Field - Modern Soft/Neutral Design
 *
 * Professional tablet-friendly styles with soft neutral tones.
 * Uses !important to override Gravity Forms Orbital theme styles.
 *
 * @package WC_Unified_KM
 * @subpackage License_Capture
 * @since 2.5.0
 */

/* ========================================
   CSS Variables
   ======================================== */
:root {
    --lc-white: #ffffff;
    --lc-gray-50: #f9fafb;
    --lc-gray-100: #f3f4f6;
    --lc-gray-200: #e5e7eb;
    --lc-gray-300: #d1d5db;
    --lc-gray-400: #9ca3af;
    --lc-gray-500: #6b7280;
    --lc-gray-600: #4b5563;
    --lc-gray-700: #374151;
    --lc-gray-800: #1f2937;
    --lc-gray-900: #111827;
    --lc-emerald: #10b981;
    --lc-emerald-light: #d1fae5;
    --lc-red: #ef4444;
    --lc-red-light: #fee2e2;
    --lc-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --lc-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
    --lc-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
    --lc-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
    --lc-radius: 16px;
    --lc-radius-sm: 12px;
    --lc-radius-xs: 8px;
}

/* ========================================
   Main Container
   ======================================== */
.ginput_container_license_capture {
    max-width: 900px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}

/* ========================================
   Instructions Box
   ======================================== */
.license-capture-instructions {
    background: linear-gradient(135deg, var(--lc-gray-50) 0%, var(--lc-white) 100%) !important;
    border: 1px solid var(--lc-gray-200) !important;
    border-radius: var(--lc-radius-sm) !important;
    padding: 18px 24px !important;
    margin-bottom: 24px !important;
    box-shadow: var(--lc-shadow-sm) !important;
}

.license-capture-instructions p {
    margin: 0 !important;
    font-size: 15px !important;
    color: var(--lc-gray-600) !important;
    line-height: 1.6 !important;
    padding: 0 !important;
    background: transparent !important;
}

/* ========================================
   Sections Wrapper (Side-by-Side Layout)
   ======================================== */
.license-capture-sections {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
}

@media (min-width: 768px) {
    .license-capture-sections {
        flex-direction: row !important;
        gap: 24px !important;
    }

    .license-capture-section {
        flex: 1 !important;
        min-width: 0 !important;
    }
}

/* ========================================
   Section Wrapper
   ======================================== */
.license-capture-section {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
}

/* ========================================
   Card Styling
   ======================================== */
.license-capture-card {
    background: var(--lc-white) !important;
    border: 1px solid var(--lc-gray-200) !important;
    border-radius: var(--lc-radius) !important;
    overflow: hidden !important;
    box-shadow: var(--lc-shadow) !important;
    transition: all 0.2s ease !important;
    padding: 0 !important;
    margin: 0 !important;
}

.license-capture-card:hover {
    border-color: var(--lc-gray-300) !important;
    box-shadow: var(--lc-shadow-md) !important;
}

.license-capture-card.has-image {
    border-color: var(--lc-emerald) !important;
}

.license-capture-card.has-image:hover {
    border-color: var(--lc-emerald) !important;
}

/* ========================================
   Card Header
   ======================================== */
.license-capture-header {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 18px 22px !important;
    background: linear-gradient(180deg, var(--lc-gray-50) 0%, var(--lc-gray-100) 100%) !important;
    border-bottom: 1px solid var(--lc-gray-200) !important;
    border-radius: 0 !important;
    margin: 0 !important;
}

.license-capture-card.has-image .license-capture-header {
    background: linear-gradient(180deg, var(--lc-emerald-light) 0%, #ecfdf5 100%) !important;
    border-bottom-color: #a7f3d0 !important;
}

/* Step Badge */
.license-capture-step {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
    background: linear-gradient(135deg, var(--lc-gray-600) 0%, var(--lc-gray-700) 100%) !important;
    color: var(--lc-white) !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
    box-shadow: var(--lc-shadow-sm) !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    line-height: 1 !important;
}

.license-capture-card.has-image .license-capture-step {
    background: linear-gradient(135deg, var(--lc-emerald) 0%, #059669 100%) !important;
}

/* Title Container */
.license-capture-title {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
}

.license-capture-title h4 {
    margin: 0 0 3px !important;
    padding: 0 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--lc-gray-900) !important;
    letter-spacing: -0.01em !important;
    line-height: 1.3 !important;
    background: transparent !important;
    border: none !important;
}

.license-capture-title p {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
    color: var(--lc-gray-500) !important;
    line-height: 1.4 !important;
    background: transparent !important;
    border: none !important;
}

/* ========================================
   Dropzone
   ======================================== */
.license-capture-dropzone {
    position: relative !important;
    min-height: 240px !important;
    cursor: pointer !important;
    background: var(--lc-white) !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    border-radius: 0 !important;
}

/* ========================================
   Placeholder Content
   ======================================== */
.license-capture-placeholder {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 36px 24px !important;
    text-align: center !important;
    min-height: 240px !important;
    background: var(--lc-white) !important;
    border: none !important;
    margin: 0 !important;
}

/* Camera Icon Circle */
.license-capture-icon {
    width: 72px !important;
    height: 72px !important;
    min-width: 72px !important;
    min-height: 72px !important;
    background: linear-gradient(135deg, var(--lc-gray-100) 0%, var(--lc-gray-200) 100%) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 0 24px 0 !important;
    padding: 0 !important;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.06) !important;
    border: none !important;
}

.license-capture-icon i {
    font-size: 32px !important;
    color: var(--lc-gray-500) !important;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Take Photo Button */
.license-capture-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    min-width: 200px !important;
    min-height: 52px !important;
    padding: 14px 28px !important;
    background: linear-gradient(135deg, var(--lc-gray-700) 0%, var(--lc-gray-800) 100%) !important;
    color: var(--lc-white) !important;
    border: none !important;
    border-radius: var(--lc-radius-xs) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-shadow: var(--lc-shadow) !important;
    -webkit-tap-highlight-color: transparent !important;
    margin: 0 !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    line-height: 1.2 !important;
}

.license-capture-btn:hover {
    background: linear-gradient(135deg, var(--lc-gray-800) 0%, var(--lc-gray-900) 100%) !important;
    box-shadow: var(--lc-shadow-md) !important;
    transform: translateY(-1px) !important;
    color: var(--lc-white) !important;
}

.license-capture-btn:active {
    transform: translateY(0) scale(0.98) !important;
    box-shadow: var(--lc-shadow-sm) !important;
}

.license-capture-btn:focus {
    outline: none !important;
    box-shadow: var(--lc-shadow), 0 0 0 3px rgba(55, 65, 81, 0.3) !important;
}

.license-capture-btn i {
    font-size: 20px !important;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Or Divider */
.license-capture-or {
    display: block !important;
    margin: 14px 0 !important;
    padding: 0 !important;
    font-size: 12px !important;
    color: var(--lc-gray-400) !important;
    text-transform: uppercase !important;
    letter-spacing: 1.5px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    background: transparent !important;
    border: none !important;
}

/* Browse Text */
.license-capture-browse {
    display: block !important;
    font-size: 14px !important;
    color: var(--lc-gray-500) !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    line-height: 1.4 !important;
}

/* Hidden File Input */
.license-capture-input {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    opacity: 0 !important;
    cursor: pointer !important;
    z-index: 2 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ========================================
   Preview State
   ======================================== */
.license-capture-preview {
    position: relative !important;
    min-height: 240px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px !important;
    background: var(--lc-gray-50) !important;
    margin: 0 !important;
    border: none !important;
}

.license-capture-preview img {
    max-width: 100% !important;
    max-height: 180px !important;
    border-radius: var(--lc-radius-xs) !important;
    box-shadow: var(--lc-shadow-md) !important;
    border: 1px solid var(--lc-gray-200) !important;
    margin: 0 !important;
    padding: 0 !important;
}

.license-capture-preview-actions {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    margin: 18px 0 0 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}

/* Retake Button */
.license-capture-retake {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 10px 18px !important;
    background: var(--lc-white) !important;
    color: var(--lc-gray-700) !important;
    border: 1px solid var(--lc-gray-300) !important;
    border-radius: var(--lc-radius-xs) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    z-index: 3 !important;
    position: relative !important;
    margin: 0 !important;
    text-decoration: none !important;
    text-transform: none !important;
    line-height: 1.2 !important;
}

.license-capture-retake:hover {
    background: var(--lc-gray-50) !important;
    border-color: var(--lc-gray-400) !important;
    color: var(--lc-gray-700) !important;
}

.license-capture-retake i {
    font-size: 16px !important;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Success Badge */
.license-capture-success {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--lc-emerald) !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    line-height: 1.2 !important;
}

.license-capture-success i {
    font-size: 18px !important;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ========================================
   Interactive States
   ======================================== */

/* Dragover */
.license-capture-dropzone.dragover {
    background: var(--lc-gray-50) !important;
}

.license-capture-dropzone.dragover .license-capture-placeholder {
    background: linear-gradient(135deg, var(--lc-gray-50) 0%, var(--lc-gray-100) 100%) !important;
}

/* Loading / Uploading */
.license-capture-dropzone.loading .license-capture-placeholder,
.license-capture-dropzone.uploading .license-capture-placeholder {
    opacity: 0.5 !important;
    pointer-events: none !important;
}

.license-capture-dropzone.loading::after {
    content: '' !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 48px !important;
    height: 48px !important;
    margin: -24px 0 0 -24px !important;
    border: 3px solid var(--lc-gray-200) !important;
    border-top-color: var(--lc-gray-600) !important;
    border-radius: 50% !important;
    animation: lc-spin 0.7s linear infinite !important;
    z-index: 10 !important;
    padding: 0 !important;
    background: transparent !important;
}

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

/* Uploading State */
.license-capture-dropzone.uploading {
    pointer-events: none !important;
}

.license-capture-dropzone.uploading .license-capture-preview {
    opacity: 0.85 !important;
}

/* Spinning icon animation for uploading text */
.license-capture-success.uploading-text {
    color: var(--lc-gray-600) !important;
}

.license-capture-success.uploading-text i.spinning {
    display: inline-block !important;
    animation: lc-spin 0.8s linear infinite !important;
}

/* Uploaded Success State */
.license-capture-success.uploaded {
    color: var(--lc-emerald) !important;
}

.license-capture-success.uploaded i {
    color: var(--lc-emerald) !important;
}

/* Uploaded card styling */
.license-capture-card.uploaded .license-capture-header {
    background: linear-gradient(180deg, var(--lc-emerald-light) 0%, #ecfdf5 100%) !important;
    border-bottom-color: #a7f3d0 !important;
}

.license-capture-card.uploaded .license-capture-step {
    background: linear-gradient(135deg, var(--lc-emerald) 0%, #059669 100%) !important;
}

/* Has Image - Hide Placeholder */
.license-capture-dropzone.has-image .license-capture-placeholder {
    display: none !important;
}

.license-capture-dropzone.has-image .license-capture-input {
    z-index: 0 !important;
}

/* ========================================
   Error State
   ======================================== */
.license-capture-card.error {
    border-color: var(--lc-red) !important;
}

.license-capture-error {
    color: var(--lc-red) !important;
    font-size: 14px !important;
    padding: 14px 22px !important;
    background: var(--lc-red-light) !important;
    border-top: 1px solid #fecaca !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    border-radius: 0 !important;
    line-height: 1.4 !important;
}

/* ========================================
   Responsive - Mobile
   ======================================== */
@media (max-width: 767px) {
    .license-capture-instructions {
        padding: 16px 18px !important;
        margin-bottom: 20px !important;
    }

    .license-capture-header {
        padding: 16px 18px !important;
    }

    .license-capture-title h4 {
        font-size: 15px !important;
    }

    .license-capture-btn {
        width: 100% !important;
        min-height: 50px !important;
        font-size: 15px !important;
    }

    .license-capture-placeholder {
        padding: 28px 20px !important;
        min-height: 220px !important;
    }

    .license-capture-dropzone {
        min-height: 220px !important;
    }

    .license-capture-preview {
        min-height: 220px !important;
    }

    .license-capture-icon {
        width: 64px !important;
        height: 64px !important;
        min-width: 64px !important;
        min-height: 64px !important;
        margin-bottom: 20px !important;
    }

    .license-capture-icon i {
        font-size: 28px !important;
    }
}

/* ========================================
   Touch Device Optimizations
   ======================================== */
@media (hover: none) and (pointer: coarse) {
    .license-capture-btn {
        min-height: 54px !important;
    }

    .license-capture-retake {
        min-height: 44px !important;
        padding: 12px 20px !important;
    }
}

/* ========================================
   Gravity Forms Integration
   ======================================== */
.gfield .ginput_container_license_capture {
    margin-top: 12px !important;
}

.gform_wrapper .gfield_description + .ginput_container_license_capture {
    margin-top: 8px !important;
}

/* Override any GF Orbital theme specifics */
.gform_wrapper.gravity-theme .ginput_container_license_capture,
.gform_wrapper.gravity-theme .ginput_container_license_capture * {
    box-sizing: border-box !important;
}

.gform_wrapper.gravity-theme .license-capture-btn,
.gform_wrapper.gravity-theme .license-capture-retake {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
}

/* ========================================
   Finance Fields Status Indicator
   ======================================== */
.fp-finance-status {
    display: inline-block;
    margin-left: 8px;
    font-size: 12px;
    font-weight: 500;
    padding: 2px 8px;
    border-radius: 4px;
    vertical-align: middle;
}

.fp-finance-status.saving {
    color: var(--lc-gray-600);
    background-color: var(--lc-gray-100);
}

.fp-finance-status.success {
    color: var(--lc-emerald);
    background-color: var(--lc-emerald-light);
}

.fp-finance-status.error {
    color: var(--lc-red);
    background-color: var(--lc-red-light);
}
