/**
 * LoanFlow Frontend Styles
 * Beautiful modern form styling
 */

/* Import Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* CSS Variables */
:root {
    --lf-bg-dark: #030712;
    --lf-bg-card: rgba(15, 23, 42, 0.8);
    --lf-bg-input: rgba(10, 22, 40, 0.6);
    --lf-accent-cyan: #06b6d4;
    --lf-accent-purple: #8b5cf6;
    --lf-accent-pink: #ec4899;
    --lf-accent-green: #10b981;
    --lf-text-white: #f8fafc;
    --lf-text-gray: #94a3b8;
    --lf-text-muted: #64748b;
    --lf-border: rgba(148, 163, 184, 0.15);
    --lf-glow: 0 0 40px rgba(6, 182, 212, 0.2);
}

/* Form Container */
.loanflow-form-container {
    max-width: 600px;
    margin: 40px auto;
    padding: 0 20px;
    font-family: 'Inter', system-ui, sans-serif;
}

/* Glass Card */
.loanflow-form-container .glass-card,
#loanflow-application-form {
    background: var(--lf-bg-card) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--lf-border) !important;
    border-radius: 24px !important;
    padding: 40px !important;
    box-shadow: var(--lf-glow);
}

/* Form Headings */
.loanflow-form-container h2,
.form-step h2 {
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 24px !important;
    font-weight: 600 !important;
    color: var(--lf-text-white) !important;
    margin-bottom: 28px !important;
    text-align: center;
}

/* Step Indicator */
.step-indicator {
    margin-bottom: 36px !important;
}

.step-indicator .step {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.step-indicator .step.active {
    background: linear-gradient(135deg, var(--lf-accent-cyan), var(--lf-accent-purple)) !important;
    color: white !important;
    box-shadow: 0 0 30px rgba(6, 182, 212, 0.4) !important;
    transform: scale(1.1);
}

.step-indicator .step:not(.active) {
    background: rgba(30, 41, 59, 0.8) !important;
    color: var(--lf-text-muted) !important;
}

.step-indicator .step.completed {
    background: linear-gradient(135deg, var(--lf-accent-green), #059669) !important;
    color: white !important;
}

.step-line {
    width: 60px !important;
    height: 3px !important;
    background: linear-gradient(90deg, var(--lf-border), var(--lf-border)) !important;
    margin: 0 12px !important;
    border-radius: 2px !important;
    transition: all 0.4s ease !important;
}

.step-line.active {
    background: linear-gradient(90deg, var(--lf-accent-cyan), var(--lf-accent-purple)) !important;
}

/* Labels */
.label-text,
.loanflow-form-container label {
    display: block !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--lf-text-gray) !important;
    margin-bottom: 8px !important;
    letter-spacing: 0.3px;
}

/* Input Fields */
.input-field,
.loanflow-form-container input[type="text"],
.loanflow-form-container input[type="email"],
.loanflow-form-container input[type="tel"],
.loanflow-form-container input[type="number"],
.loanflow-form-container select,
.loanflow-form-container textarea {
    width: 100% !important;
    padding: 14px 18px !important;
    font-size: 15px !important;
    font-family: 'Inter', sans-serif !important;
    color: var(--lf-text-white) !important;
    background: var(--lf-bg-input) !important;
    border: 1px solid var(--lf-border) !important;
    border-radius: 12px !important;
    transition: all 0.3s ease !important;
    outline: none !important;
}

.loanflow-form-container input::placeholder,
.loanflow-form-container textarea::placeholder {
    color: var(--lf-text-muted) !important;
}

.loanflow-form-container input:focus,
.loanflow-form-container select:focus,
.loanflow-form-container textarea:focus {
    border-color: var(--lf-accent-cyan) !important;
    box-shadow: 0 0 20px rgba(6, 182, 212, 0.2) !important;
    background: rgba(10, 22, 40, 0.8) !important;
}

/* Select Dropdown */
.loanflow-form-container select {
    appearance: none !important;
    -webkit-appearance: none !important;
    cursor: pointer !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 20px !important;
    padding-right: 48px !important;
}

.loanflow-form-container select option {
    background: #1e293b !important;
    color: var(--lf-text-white) !important;
    padding: 12px !important;
}

/* Textarea */
.loanflow-form-container textarea {
    min-height: 120px !important;
    resize: vertical !important;
    line-height: 1.6 !important;
}

/* Buttons Container */
.form-navigation,
.form-buttons {
    display: flex !important;
    gap: 12px !important;
    margin-top: 32px !important;
    justify-content: space-between !important;
}

/* Primary Button */
.btn-primary,
.loanflow-form-container button[type="submit"],
.next-step-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 14px 28px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    font-family: 'Inter', sans-serif !important;
    color: white !important;
    background: linear-gradient(135deg, var(--lf-accent-cyan), var(--lf-accent-purple)) !important;
    border: none !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 4px 15px rgba(6, 182, 212, 0.3) !important;
}

.btn-primary:hover,
.loanflow-form-container button[type="submit"]:hover,
.next-step-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(6, 182, 212, 0.4) !important;
}

/* Secondary Button */
.btn-secondary,
.prev-step-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 14px 28px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    font-family: 'Inter', sans-serif !important;
    color: var(--lf-text-white) !important;
    background: rgba(30, 41, 59, 0.8) !important;
    border: 1px solid var(--lf-border) !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.btn-secondary:hover,
.prev-step-btn:hover {
    background: rgba(51, 65, 85, 0.8) !important;
    border-color: var(--lf-accent-purple) !important;
}

/* Success Button */
.btn-success {
    background: linear-gradient(135deg, var(--lf-accent-green), #059669) !important;
    box-shadow: 0 4px 15px rgba(16, 185, 129, 0.3) !important;
}

.btn-success:hover {
    box-shadow: 0 8px 25px rgba(16, 185, 129, 0.4) !important;
}

/* Error Messages */
.form-error {
    padding: 14px 18px !important;
    border-radius: 12px !important;
    background: rgba(239, 68, 68, 0.1) !important;
    border: 1px solid rgba(239, 68, 68, 0.3) !important;
    color: #f87171 !important;
    font-size: 14px !important;
    margin-bottom: 20px !important;
}

/* ====================================
   SUCCESS MODAL & GAUGE
   ==================================== */

.loanflow-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 99999;
    padding: 20px;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.loanflow-modal-content {
    background: linear-gradient(135deg, rgba(15, 23, 42, 0.95) 0%, rgba(30, 41, 59, 0.95) 100%);
    border: 1px solid var(--lf-border);
    border-radius: 28px;
    padding: 48px 40px;
    max-width: 480px;
    width: 100%;
    text-align: center;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.5);
    animation: slideUp 0.4s ease;
}

@keyframes slideUp {
    from { 
        opacity: 0;
        transform: translateY(30px) scale(0.95);
    }
    to { 
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.success-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 24px;
    background: linear-gradient(135deg, var(--lf-accent-green), #059669);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 40px rgba(16, 185, 129, 0.4);
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { box-shadow: 0 0 40px rgba(16, 185, 129, 0.4); }
    50% { box-shadow: 0 0 60px rgba(16, 185, 129, 0.6); }
}

.success-icon svg {
    width: 40px;
    height: 40px;
    stroke: white;
    stroke-width: 3;
}

.modal-title {
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: var(--lf-text-white) !important;
    margin-bottom: 12px !important;
}

.modal-subtitle {
    font-size: 15px;
    color: var(--lf-text-gray);
    margin-bottom: 36px;
    line-height: 1.6;
}

/* ====================================
   HALF-CIRCLE GAUGE
   ==================================== */

.gauge-container {
    position: relative;
    width: 220px;
    height: 130px;
    margin: 0 auto 24px;
}

.gauge-body {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
}

.gauge-fill {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 200%;
    border-radius: 50%;
    background: conic-gradient(
        from 180deg,
        #ef4444 0deg,
        #f97316 45deg,
        #eab308 90deg,
        #84cc16 135deg,
        #22c55e 180deg,
        transparent 180deg
    );
    mask: radial-gradient(circle at 50% 50%, transparent 60%, black 60%);
    -webkit-mask: radial-gradient(circle at 50% 50%, transparent 60%, black 60%);
}

.gauge-cover {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.gauge-center {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 24px;
    height: 24px;
    background: linear-gradient(135deg, var(--lf-accent-cyan), var(--lf-accent-purple));
    border-radius: 50%;
    box-shadow: 0 0 20px rgba(6, 182, 212, 0.5);
    z-index: 10;
}

.gauge-needle {
    position: absolute;
    bottom: 12px;
    left: 50%;
    width: 4px;
    height: 85px;
    background: linear-gradient(to top, var(--lf-accent-cyan), var(--lf-accent-purple));
    border-radius: 4px;
    transform-origin: bottom center;
    transform: translateX(-50%) rotate(-90deg);
    transition: transform 1.5s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 0 15px rgba(6, 182, 212, 0.5);
}

.gauge-labels {
    position: absolute;
    bottom: -5px;
    left: 0;
    right: 0;
    display: flex;
    justify-content: space-between;
    padding: 0 5px;
    font-size: 12px;
    color: var(--lf-text-muted);
    font-weight: 500;
}

.gauge-value {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 42px;
    font-weight: 700;
    text-align: center;
    margin-top: 16px;
    transition: color 0.5s ease;
}

.gauge-value.high { color: var(--lf-accent-green); }
.gauge-value.medium { color: #f59e0b; }
.gauge-value.low { color: #ef4444; }

.gauge-message {
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    margin-top: 8px;
}

.gauge-message.high { color: var(--lf-accent-green); }
.gauge-message.medium { color: #f59e0b; }
.gauge-message.low { color: #ef4444; }

.gauge-disclaimer {
    font-size: 12px;
    color: var(--lf-text-muted);
    font-style: italic;
    margin-top: 24px;
    line-height: 1.5;
}

.home-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 28px;
    padding: 14px 32px;
    background: linear-gradient(135deg, var(--lf-accent-cyan), var(--lf-accent-purple));
    color: white;
    font-weight: 600;
    font-size: 15px;
    border-radius: 12px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.home-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(6, 182, 212, 0.4);
    color: white;
}

/* ====================================
   RESPONSIVE
   ==================================== */

@media (max-width: 640px) {
    .loanflow-form-container {
        padding: 0 16px;
    }
    
    .loanflow-form-container .glass-card,
    #loanflow-application-form {
        padding: 28px 20px !important;
    }
    
    .form-navigation,
    .form-buttons {
        flex-direction: column !important;
    }
    
    .btn-primary,
    .btn-secondary {
        width: 100% !important;
    }
    
    .loanflow-modal-content {
        padding: 32px 24px;
        margin: 16px;
    }
    
    .gauge-container {
        width: 180px;
        height: 105px;
    }
    
    .gauge-needle {
        height: 70px;
    }
    
    .gauge-value {
        font-size: 36px;
    }
}

/* ====================================
   LOADING STATE
   ==================================== */

.btn-loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.btn-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.loanflow-comments-close {
    background: transparent;
    
    width: 55px!important;
   
}

@keyframes spin {
    to { transform: rotate(360deg); }
}
