.contact-ai-body {
    min-height: 100vh;
}

.cursor-pointer {
    cursor: pointer;
}

.attr-card {
    transition: border-color 0.15s ease, background 0.15s ease;
}

.attr-card:has(input:checked) {
    border-color: #0d6efd !important;
    background: #f0f7ff;
}

.step-indicator .step-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: #e9ecef;
    color: #6c757d;
    font-size: 0.875rem;
}

.step-indicator .step-pill.active {
    background: #0d6efd;
    color: #fff;
}

.step-indicator .step-pill.done {
    background: #198754;
    color: #fff;
}

.step-indicator .step-num {
    font-weight: 700;
}

.faq-accordion .accordion-button:not(.collapsed) {
    background: #f8f9fa;
}

.faq-answer {
    line-height: 1.65;
}

.faq-answer p:last-child {
    margin-bottom: 0;
}

.chat-page {
    min-height: 100vh;
    padding-bottom: 12rem;
}

.chat-messages {
    max-width: 720px;
    margin: 0 auto;
}

.chat-bubble {
    max-width: 90%;
    padding: 0.75rem 1rem;
    border-radius: 1rem;
    margin-bottom: 1rem;
    white-space: pre-wrap;
    word-break: break-word;
}

.chat-bubble.user {
    margin-left: auto;
    background: #0d6efd;
    color: #fff;
    border-bottom-right-radius: 0.25rem;
}

.chat-bubble.assistant {
    margin-right: auto;
    background: #fff;
    border: 1px solid #dee2e6;
    border-bottom-left-radius: 0.25rem;
}

.chat-footer-fixed {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1030;
}

.pb-chat-area {
    padding-bottom: 14rem;
}

.genre-tab.active {
    font-weight: 600;
}
