/* ============================================================
   Health Plan Search Wizard
   All classes prefixed .hps- to avoid theme conflicts
   ============================================================ */

.hps-wizard {
    --hps-primary: #2563EB;
    --hps-primary-hover: #1D4ED8;
    --hps-primary-light: #DBEAFE;
    --hps-primary-lightest: #EFF6FF;
    --hps-success: #059669;
    --hps-success-light: #D1FAE5;
    --hps-danger: #DC2626;
    --hps-danger-light: #FEE2E2;
    --hps-warning: #D97706;
    --hps-warning-light: #FEF3C7;
    --hps-bronze: #CD7F32;
    --hps-silver: #9CA3AF;
    --hps-gold: #D4A017;
    --hps-platinum: #6366F1;
    --hps-catastrophic: #6B7280;
    --hps-text: #111827;
    --hps-text-secondary: #6B7280;
    --hps-text-light: #9CA3AF;
    --hps-bg: #FFFFFF;
    --hps-bg-subtle: #F9FAFB;
    --hps-border: #E5E7EB;
    --hps-border-focus: var(--hps-primary);
    --hps-radius: 16px;
    --hps-radius-sm: 10px;
    --hps-radius-xs: 6px;
    --hps-shadow: 0 1px 3px rgba(0,0,0,0.08), 0 4px 16px rgba(0,0,0,0.04);
    --hps-shadow-lg: 0 4px 24px rgba(0,0,0,0.10), 0 8px 32px rgba(0,0,0,0.05);
    --hps-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);

    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    max-width: 680px;
    margin: 40px auto;
    color: var(--hps-text);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

.hps-wizard *, .hps-wizard *::before, .hps-wizard *::after {
    box-sizing: border-box;
}

/* ============================================================
   Progress Bar
   ============================================================ */

.hps-progress {
    margin-bottom: 32px;
    padding: 0 8px;
}

.hps-progress-steps {
    display: flex;
    justify-content: space-between;
    position: relative;
}

.hps-progress-track {
    height: 3px;
    background: var(--hps-border);
    border-radius: 2px;
    margin-bottom: 12px;
    position: relative;
    overflow: hidden;
}

.hps-progress-fill {
    height: 100%;
    background: var(--hps-primary);
    border-radius: 2px;
    width: 0%;
    transition: width 0.5s ease;
}

.hps-progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
}

.hps-step-dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--hps-border);
    background: var(--hps-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--hps-text-light);
    transition: all var(--hps-transition);
    position: relative;
    z-index: 1;
}

.hps-progress-step.hps-active .hps-step-dot {
    border-color: var(--hps-primary);
    background: var(--hps-primary);
    color: #fff;
    box-shadow: 0 0 0 4px var(--hps-primary-light);
}

.hps-progress-step.hps-completed .hps-step-dot {
    border-color: var(--hps-success);
    background: var(--hps-success);
    color: #fff;
}

.hps-progress-step.hps-completed .hps-step-dot span {
    display: none;
}

.hps-progress-step.hps-completed .hps-step-dot::after {
    content: '';
    width: 10px;
    height: 6px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg);
    margin-top: -2px;
}

.hps-step-label {
    margin-top: 6px;
    font-size: 12px;
    font-weight: 500;
    color: var(--hps-text-light);
    transition: color var(--hps-transition);
}

.hps-progress-step.hps-active .hps-step-label {
    color: var(--hps-primary);
    font-weight: 600;
}

.hps-progress-step.hps-completed .hps-step-label {
    color: var(--hps-success);
}

/* ============================================================
   Step Container & Transitions
   ============================================================ */

.hps-step-container {
    position: relative;
    overflow: hidden;
}

.hps-step {
    display: none;
    animation: hpsFadeSlideIn 0.35s ease forwards;
}

.hps-step.hps-step-active {
    display: block;
}

.hps-step.hps-step-exit {
    animation: hpsFadeSlideOut 0.25s ease forwards;
}

@keyframes hpsFadeSlideIn {
    from { opacity: 0; transform: translateX(24px); }
    to   { opacity: 1; transform: translateX(0); }
}

@keyframes hpsFadeSlideOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(-24px); }
}

@keyframes hpsFadeSlideInReverse {
    from { opacity: 0; transform: translateX(-24px); }
    to   { opacity: 1; transform: translateX(0); }
}

.hps-step.hps-step-back {
    animation: hpsFadeSlideInReverse 0.35s ease forwards;
}

.hps-step-inner {
    background: var(--hps-bg);
    border: 1px solid var(--hps-border);
    border-radius: var(--hps-radius);
    padding: 40px 36px;
    box-shadow: var(--hps-shadow);
    text-align: center;
}

.hps-step-icon {
    margin-bottom: 16px;
    color: var(--hps-primary);
}

.hps-icon-warning {
    color: var(--hps-warning);
}

.hps-step-title {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 8px;
    color: var(--hps-text);
    letter-spacing: -0.02em;
}

.hps-step-subtitle {
    font-size: 15px;
    color: var(--hps-text-secondary);
    margin: 0 0 28px;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   Form Fields
   ============================================================ */

.hps-field-group {
    margin-bottom: 20px;
    text-align: left;
}

.hps-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--hps-text);
    margin-bottom: 6px;
}

.hps-input-wrap {
    position: relative;
}

.hps-input {
    width: 100%;
    height: 48px;
    padding: 0 16px;
    border: 2px solid var(--hps-border);
    border-radius: var(--hps-radius-sm);
    font-size: 16px;
    font-family: inherit;
    color: var(--hps-text);
    background: var(--hps-bg);
    transition: border-color var(--hps-transition), box-shadow var(--hps-transition);
    outline: none;
}

.hps-input:focus {
    border-color: var(--hps-primary);
    box-shadow: 0 0 0 3px var(--hps-primary-light);
}

.hps-input::placeholder {
    color: var(--hps-text-light);
}

.hps-input.hps-input-error {
    border-color: var(--hps-danger);
}

.hps-input.hps-input-error:focus {
    box-shadow: 0 0 0 3px var(--hps-danger-light);
}

.hps-input-large .hps-input {
    height: 56px;
    font-size: 20px;
    text-align: center;
    letter-spacing: 0.1em;
    font-weight: 600;
}

.hps-input-dollar {
    display: flex;
    align-items: center;
}

.hps-input-prefix {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 20px;
    font-weight: 600;
    color: var(--hps-text-secondary);
    pointer-events: none;
    z-index: 1;
}

.hps-input-dollar .hps-input {
    padding-left: 36px;
    text-align: left;
    letter-spacing: normal;
}

.hps-field-error {
    font-size: 13px;
    color: var(--hps-danger);
    margin-top: 6px;
    min-height: 0;
}

.hps-helper-text {
    font-size: 13px;
    color: var(--hps-text-secondary);
    margin-top: 8px;
}

/* Toggle Group (Gender) */
.hps-toggle-group {
    display: flex;
    gap: 0;
    border: 2px solid var(--hps-border);
    border-radius: var(--hps-radius-sm);
    overflow: hidden;
}

.hps-toggle {
    flex: 1;
    height: 40px;
    border: none;
    background: var(--hps-bg);
    font-size: 14px;
    font-weight: 500;
    font-family: inherit;
    color: var(--hps-text-secondary);
    cursor: pointer;
    transition: all var(--hps-transition);
}

.hps-toggle:first-child {
    border-right: 1px solid var(--hps-border);
}

.hps-toggle.hps-toggle-active {
    background: var(--hps-primary);
    color: #fff;
}

.hps-toggle:hover:not(.hps-toggle-active) {
    background: var(--hps-bg-subtle);
}

/* Checkbox */
.hps-checkbox-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 14px;
    color: var(--hps-text-secondary);
}

.hps-checkbox {
    width: 18px;
    height: 18px;
    accent-color: var(--hps-primary);
}

/* ============================================================
   Member Cards
   ============================================================ */

.hps-members-list {
    text-align: left;
    margin-bottom: 16px;
}

.hps-member-card {
    background: var(--hps-bg-subtle);
    border: 1px solid var(--hps-border);
    border-radius: var(--hps-radius-sm);
    padding: 16px 20px;
    margin-bottom: 12px;
    position: relative;
    transition: box-shadow var(--hps-transition);
}

.hps-member-card:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.hps-member-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.hps-member-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--hps-text);
}

.hps-member-remove {
    width: 28px;
    height: 28px;
    border: none;
    background: transparent;
    color: var(--hps-text-light);
    cursor: pointer;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--hps-transition);
    font-size: 18px;
    line-height: 1;
}

.hps-member-remove:hover {
    background: var(--hps-danger-light);
    color: var(--hps-danger);
}

.hps-member-fields {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hps-field-row {
    display: flex;
    gap: 12px;
    align-items: flex-end;
}

.hps-field {
    flex: 1;
}

.hps-field .hps-input {
    height: 42px;
    font-size: 15px;
}

/* ============================================================
   Buttons
   ============================================================ */

.hps-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 48px;
    padding: 0 28px;
    border-radius: var(--hps-radius-sm);
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    border: none;
    transition: all var(--hps-transition);
    text-decoration: none;
    white-space: nowrap;
}

.hps-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.hps-btn-primary {
    background: var(--hps-primary);
    color: #fff;
    box-shadow: 0 1px 3px rgba(37,99,235,0.3);
}

.hps-btn-primary:hover:not(:disabled) {
    background: var(--hps-primary-hover);
    box-shadow: 0 4px 12px rgba(37,99,235,0.35);
    transform: translateY(-1px);
}

.hps-btn-primary:active:not(:disabled) {
    transform: translateY(0);
}

.hps-btn-outline {
    background: transparent;
    color: var(--hps-primary);
    border: 2px solid var(--hps-primary-light);
}

.hps-btn-outline:hover:not(:disabled) {
    background: var(--hps-primary-lightest);
    border-color: var(--hps-primary);
}

.hps-btn-ghost {
    background: transparent;
    color: var(--hps-text-secondary);
    padding: 0 16px;
}

.hps-btn-ghost:hover {
    color: var(--hps-text);
    background: var(--hps-bg-subtle);
}

.hps-btn-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 24px;
}

.hps-btn-add-member {
    width: 100%;
    height: 44px;
    margin-bottom: 8px;
}

.hps-btn.hps-btn-loading {
    pointer-events: none;
    position: relative;
    color: transparent;
}

.hps-btn.hps-btn-loading::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255,255,255,0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: hpsSpin 0.6s linear infinite;
}

/* ============================================================
   Loading Step
   ============================================================ */

.hps-loading-inner {
    padding: 60px 36px;
}

.hps-loading-animation {
    margin-bottom: 24px;
}

.hps-spinner {
    width: 56px;
    height: 56px;
    border: 4px solid var(--hps-primary-light);
    border-top-color: var(--hps-primary);
    border-radius: 50%;
    animation: hpsSpin 0.8s linear infinite;
    margin: 0 auto;
}

@keyframes hpsSpin {
    to { transform: rotate(360deg); }
}

.hps-loading-bar-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
    max-width: 400px;
    margin: 24px auto 0;
}

.hps-loading-bar {
    flex: 1;
    height: 8px;
    background: var(--hps-border);
    border-radius: 4px;
    overflow: hidden;
}

.hps-loading-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--hps-primary), #818CF8);
    border-radius: 4px;
    transition: width 0.8s ease;
    position: relative;
}

.hps-loading-bar-fill::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    animation: hpsShimmer 1.5s infinite;
}

@keyframes hpsShimmer {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

.hps-loading-percent {
    font-size: 14px;
    font-weight: 600;
    color: var(--hps-primary);
    min-width: 36px;
    text-align: right;
}

.hps-loading-message {
    transition: opacity 0.3s ease;
}

/* ============================================================
   Plan Cards
   ============================================================ */

.hps-results-inner {
    text-align: left;
    padding: 32px 28px;
}

.hps-results-inner .hps-step-title,
.hps-results-inner .hps-step-subtitle {
    text-align: center;
}

.hps-results-filters {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.hps-filter-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--hps-text-secondary);
}

.hps-filter-btn {
    height: 32px;
    padding: 0 14px;
    border: 1px solid var(--hps-border);
    border-radius: 16px;
    background: var(--hps-bg);
    font-size: 13px;
    font-weight: 500;
    font-family: inherit;
    color: var(--hps-text-secondary);
    cursor: pointer;
    transition: all var(--hps-transition);
}

.hps-filter-btn:hover {
    border-color: var(--hps-primary);
    color: var(--hps-primary);
}

.hps-filter-btn.hps-filter-active {
    background: var(--hps-primary);
    color: #fff;
    border-color: var(--hps-primary);
}

.hps-plan-card {
    background: var(--hps-bg);
    border: 1px solid var(--hps-border);
    border-radius: var(--hps-radius-sm);
    padding: 0;
    margin-bottom: 16px;
    display: flex;
    overflow: hidden;
    transition: box-shadow var(--hps-transition), transform var(--hps-transition);
    cursor: pointer;
}

.hps-plan-card:hover {
    box-shadow: var(--hps-shadow-lg);
    transform: translateY(-2px);
}

.hps-plan-card.hps-plan-selected {
    border-color: var(--hps-primary);
    box-shadow: 0 0 0 2px var(--hps-primary-light), var(--hps-shadow);
}

.hps-plan-metal-bar {
    width: 6px;
    flex-shrink: 0;
}

.hps-metal-bronze  { background: var(--hps-bronze); }
.hps-metal-silver  { background: var(--hps-silver); }
.hps-metal-gold    { background: var(--hps-gold); }
.hps-metal-platinum { background: var(--hps-platinum); }
.hps-metal-catastrophic { background: var(--hps-catastrophic); }

.hps-plan-content {
    flex: 1;
    padding: 20px;
}

.hps-plan-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 12px;
    gap: 12px;
}

.hps-plan-carrier {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--hps-text-secondary);
    margin-bottom: 2px;
}

.hps-plan-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--hps-text);
    line-height: 1.3;
}

.hps-plan-price {
    text-align: right;
    flex-shrink: 0;
}

.hps-plan-premium {
    font-size: 28px;
    font-weight: 800;
    color: var(--hps-text);
    line-height: 1;
}

.hps-plan-premium-period {
    font-size: 13px;
    font-weight: 400;
    color: var(--hps-text-secondary);
}

.hps-plan-original-price {
    font-size: 14px;
    color: var(--hps-text-light);
    text-decoration: line-through;
    margin-bottom: 2px;
}

.hps-plan-subsidy-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    color: var(--hps-success);
    background: var(--hps-success-light);
    padding: 2px 8px;
    border-radius: 10px;
    margin-top: 4px;
}

.hps-plan-stats {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.hps-plan-stat {
    flex: 1;
    min-width: 100px;
}

.hps-plan-stat-label {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--hps-text-light);
    margin-bottom: 2px;
}

.hps-plan-stat-value {
    font-size: 15px;
    font-weight: 700;
    color: var(--hps-text);
}

.hps-plan-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.hps-plan-badges {
    display: flex;
    gap: 6px;
}

.hps-badge {
    display: inline-flex;
    align-items: center;
    height: 24px;
    padding: 0 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.hps-badge-bronze     { background: #FDF2E3; color: var(--hps-bronze); }
.hps-badge-silver     { background: #F3F4F6; color: #4B5563; }
.hps-badge-gold       { background: #FEF8E6; color: #92600A; }
.hps-badge-platinum   { background: #EEF2FF; color: var(--hps-platinum); }
.hps-badge-catastrophic { background: #F3F4F6; color: var(--hps-catastrophic); }

.hps-badge-type {
    background: var(--hps-bg-subtle);
    color: var(--hps-text-secondary);
}

.hps-plan-select-btn {
    height: 36px;
    padding: 0 20px;
    border-radius: 18px;
    border: 2px solid var(--hps-primary);
    background: transparent;
    color: var(--hps-primary);
    font-size: 13px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: all var(--hps-transition);
}

.hps-plan-select-btn:hover {
    background: var(--hps-primary);
    color: #fff;
}

.hps-plan-card.hps-plan-selected .hps-plan-select-btn {
    background: var(--hps-primary);
    color: #fff;
}

/* ============================================================
   County Selection
   ============================================================ */

.hps-county-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 24px;
    text-align: left;
}

.hps-county-option {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 2px solid var(--hps-border);
    border-radius: var(--hps-radius-sm);
    cursor: pointer;
    transition: all var(--hps-transition);
    background: var(--hps-bg);
}

.hps-county-option:hover {
    border-color: var(--hps-primary-light);
    background: var(--hps-primary-lightest);
}

.hps-county-option.hps-county-selected {
    border-color: var(--hps-primary);
    background: var(--hps-primary-lightest);
}

.hps-county-option input[type="radio"] {
    accent-color: var(--hps-primary);
    width: 18px;
    height: 18px;
}

.hps-county-option label {
    font-size: 15px;
    font-weight: 500;
    color: var(--hps-text);
    cursor: pointer;
}

/* ============================================================
   Lead Form
   ============================================================ */

.hps-lead-form {
    text-align: left;
    margin-bottom: 8px;
}

.hps-lead-form .hps-input {
    height: 48px;
}

.hps-selected-plan-preview {
    background: var(--hps-primary-lightest);
    border: 1px solid var(--hps-primary-light);
    border-radius: var(--hps-radius-sm);
    padding: 16px;
    margin-bottom: 24px;
    text-align: left;
}

.hps-preview-carrier {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--hps-primary);
}

.hps-preview-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--hps-text);
    margin-bottom: 4px;
}

.hps-preview-price {
    font-size: 14px;
    color: var(--hps-text-secondary);
}

/* ============================================================
   Confirmation / Success
   ============================================================ */

.hps-confirmation-inner {
    padding: 60px 36px;
}

.hps-success-animation {
    margin-bottom: 24px;
}

.hps-checkmark {
    color: var(--hps-success);
}

.hps-checkmark-circle {
    stroke-dasharray: 166;
    stroke-dashoffset: 166;
    animation: hpsStroke 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}

.hps-checkmark-check {
    stroke-dasharray: 48;
    stroke-dashoffset: 48;
    animation: hpsStroke 0.3s cubic-bezier(0.65, 0, 0.45, 1) 0.5s forwards;
}

@keyframes hpsStroke {
    to { stroke-dashoffset: 0; }
}

.hps-confirmation-plan {
    background: var(--hps-bg-subtle);
    border: 1px solid var(--hps-border);
    border-radius: var(--hps-radius-sm);
    padding: 20px;
    margin-top: 24px;
    text-align: left;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   Error & No Plans States
   ============================================================ */

.hps-no-plans,
.hps-error-message {
    text-align: center;
    padding: 20px 0;
}

.hps-no-plans h3,
.hps-error-message h3 {
    font-size: 20px;
    font-weight: 700;
    margin: 16px 0 8px;
    color: var(--hps-text);
}

.hps-no-plans p,
.hps-error-message p {
    color: var(--hps-text-secondary);
    font-size: 15px;
    margin-bottom: 20px;
}

/* ============================================================
   Responsive
   ============================================================ */

@media (max-width: 720px) {
    .hps-wizard {
        margin: 20px 16px;
    }

    .hps-step-inner {
        padding: 28px 20px;
    }

    .hps-step-title {
        font-size: 20px;
    }

    .hps-step-label {
        font-size: 10px;
    }

    .hps-step-dot {
        width: 28px;
        height: 28px;
        font-size: 12px;
    }
}

@media (max-width: 480px) {
    .hps-wizard {
        margin: 12px 8px;
    }

    .hps-step-inner {
        padding: 24px 16px;
        border-radius: 12px;
    }

    .hps-plan-header {
        flex-direction: column;
        gap: 8px;
    }

    .hps-plan-price {
        text-align: left;
    }

    .hps-plan-premium {
        font-size: 24px;
    }

    .hps-plan-stats {
        flex-direction: column;
        gap: 8px;
    }

    .hps-plan-stat {
        min-width: unset;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .hps-plan-footer {
        flex-direction: column;
        gap: 12px;
        align-items: stretch;
    }

    .hps-plan-select-btn {
        width: 100%;
    }

    .hps-field-row {
        flex-direction: column;
        gap: 12px;
    }

    .hps-btn-row {
        flex-direction: column-reverse;
        gap: 8px;
    }

    .hps-btn-row .hps-btn {
        width: 100%;
    }

    .hps-results-filters {
        justify-content: center;
    }

    .hps-step-label {
        display: none;
    }

    .hps-loading-inner,
    .hps-confirmation-inner {
        padding: 40px 16px;
    }
}
