/* Rapid Quote Form - V1.3 Screenshot-Matched Design */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
    --rapid-navy: #0a1b4d;
    --rapid-blue: #324bab;
    --rapid-error: #d93025;
    --rapid-border: #ccd0d5;
    --rapid-bg: #ffffff;
    --rapid-text-main: #0a1b4d;
    --rapid-text-sub: #5c6c7b;
}

#rapid-quote-wrapper {
    font-family: 'Inter', sans-serif;
    color: var(--rapid-text-main);
}

/* Hero Header */
.rapid-hero-header {
    background: linear-gradient(180deg, #edf4fc 0%, #9fc9f6 100%);
    color: var(--rapid-navy); /* Changing to dark color for better contrast against light background */
    text-align: center;
    padding: 60px 20px;
    margin-bottom: 0;
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}

.rapid-hero-header h1 {
    font-size: 48px;
    font-weight: 700;
    margin: 0 0 15px;
    color: var(--rapid-navy);
}

.rapid-hero-header p {
    font-size: 18px;
    opacity: 0.9;
    margin: 0;
}

/* Form Container */
#rapid-quote-container {
    max-width: 600px;
    margin: -40px auto 60px;
    background: var(--rapid-bg);
    padding: 50px;
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.1);
    position: relative;
    z-index: 10;
}

/* Trust Badge */
.rapid-trust-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--rapid-blue);
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 40px;
}

.rapid-trust-badge svg {
    width: 18px;
    fill: currentColor;
}

/* Section Titles */
.rapid-form-section-title {
    text-align: center;
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 35px;
    color: var(--rapid-navy);
}

/* Form Fields */
.rapid-input-group {
    margin-bottom: 25px;
    position: relative;
}

.rapid-input-group label {
    display: block;
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 10px;
    color: var(--rapid-navy);
}

.rapid-input-group input, 
.rapid-input-group select, 
.rapid-input-group textarea {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--rapid-border);
    border-radius: 4px;
    font-size: 16px;
    color: var(--rapid-navy);
    transition: border-color 0.2s;
}

.rapid-input-group input::placeholder {
    color: #a0aec0;
}

.rapid-input-group input:focus {
    outline: none;
    border-color: var(--rapid-blue);
}

/* Error States */
.rapid-input-group.has-error input {
    border-color: var(--rapid-error);
}

.error-message {
    color: var(--rapid-error);
    font-size: 13px;
    margin-top: 6px;
    display: none;
    align-items: center;
    gap: 6px;
}

.rapid-input-group.has-error .error-message {
    display: flex;
}

/* Buttons */
.rapid-button-row {
    display: flex;
    justify-content: flex-end;
    gap: 15px;
    margin-top: 40px;
}

.rapid-btn {
    padding: 12px 30px;
    font-size: 16px;
    font-weight: 500;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
}

.rapid-btn-next, .rapid-btn-submit {
    background-color: var(--rapid-blue);
    color: white;
    border: none;
    min-width: 120px;
}

.rapid-btn-next:hover, .rapid-btn-submit:hover {
    background-color: #263a8a;
}

.rapid-btn-back {
    background-color: transparent;
    color: var(--rapid-blue);
    border: 1px solid var(--rapid-blue);
}

.rapid-btn-back:hover {
    background-color: #f0f4ff;
}

/* Steps Control */
.rapid-step {
    display: none;
}

.rapid-step.active {
    display: block;
    animation: fadeIn 0.4s ease-out;
}

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

/* Success State */
#rapid-success-msg {
    text-align: center;
    padding: 40px 0;
}

.rapid-hidden { display: none; }

/* Resolved State Display Label */
.rapid-zip-state {
    font-size: 13px;
    font-weight: 600;
    color: var(--rapid-blue);
    margin-top: 6px;
    display: none;
    align-items: center;
    gap: 4px;
}

.rapid-zip-state.active {
    display: flex;
}
