feat(onboarding): add conversational ChatOnboarding component

This commit is contained in:
2026-02-28 22:06:15 +01:00
parent 04bab32e26
commit e40b486ae5
8 changed files with 870 additions and 3 deletions
+251 -1
View File
@@ -420,6 +420,256 @@ input {
border-color: var(--border-hover);
}
/* ============================================
CHAT ONBOARDING
============================================ */
.chat-onboarding {
min-height: 100vh;
display: flex;
justify-content: center;
padding: var(--space-5);
background: radial-gradient(circle at top, rgba(255, 107, 74, 0.08), transparent 55%), var(--bg-primary);
}
.chat-shell {
width: 100%;
max-width: 720px;
min-height: calc(100vh - var(--space-10));
background: var(--bg-card);
border-radius: var(--radius-2xl);
border: 1px solid var(--border);
box-shadow: var(--shadow-elevated);
display: flex;
flex-direction: column;
overflow: hidden;
}
.chat-header {
padding: var(--space-5) var(--space-5) var(--space-4);
border-bottom: 1px solid var(--border);
display: flex;
justify-content: space-between;
align-items: center;
background: linear-gradient(135deg, rgba(255, 107, 74, 0.1), rgba(18, 18, 26, 0.9));
}
.chat-header h1 {
font-size: var(--font-2xl);
}
.chat-subtitle {
font-size: var(--font-sm);
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 1px;
margin-bottom: var(--space-1);
}
.chat-status {
font-size: var(--font-sm);
padding: var(--space-2) var(--space-3);
border-radius: var(--radius-full);
background: rgba(34, 197, 94, 0.12);
color: var(--success);
border: 1px solid rgba(34, 197, 94, 0.3);
}
.chat-status.saving {
background: rgba(245, 158, 11, 0.12);
color: var(--warning);
border-color: rgba(245, 158, 11, 0.3);
}
.chat-messages {
flex: 1;
overflow-y: auto;
padding: var(--space-5);
display: flex;
flex-direction: column;
gap: var(--space-4);
background: var(--bg-elevated);
}
.chat-message {
display: flex;
align-items: flex-end;
gap: var(--space-3);
animation: slideUp 0.3s ease both;
}
.chat-message.user {
justify-content: flex-end;
}
.chat-message.user .chat-bubble {
background: var(--accent);
color: #fff;
border-bottom-right-radius: var(--radius-sm);
box-shadow: var(--shadow-glow);
}
.chat-message.coach .chat-bubble {
background: var(--bg-secondary);
border: 1px solid var(--border);
border-bottom-left-radius: var(--radius-sm);
}
.chat-bubble {
max-width: 80%;
padding: var(--space-3) var(--space-4);
border-radius: var(--radius-lg);
font-size: var(--font-base);
line-height: 1.5;
}
.chat-avatar {
width: 36px;
height: 36px;
border-radius: 50%;
background: var(--accent-subtle);
color: var(--accent);
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
flex-shrink: 0;
}
.chat-actions {
padding: var(--space-4);
border-top: 1px solid var(--border);
background: var(--bg-card);
}
.chat-input-area {
display: flex;
flex-direction: column;
gap: var(--space-3);
}
.chat-input-row {
display: flex;
gap: var(--space-3);
}
.chat-input-row input {
flex: 1;
padding: var(--space-3) var(--space-4);
border-radius: var(--radius-md);
border: 1px solid var(--border);
background: var(--bg-secondary);
color: var(--text-primary);
font-size: var(--font-base);
}
.chat-input-row input:focus {
outline: none;
border-color: var(--accent);
box-shadow: 0 0 0 2px var(--accent-subtle);
}
.send-btn {
padding: var(--space-3) var(--space-4);
border-radius: var(--radius-md);
background: var(--accent);
color: #fff;
font-weight: 600;
transition: transform var(--transition-fast);
}
.send-btn:active {
transform: scale(0.97);
}
.chat-error {
color: var(--error);
font-size: var(--font-sm);
}
.quick-replies {
display: flex;
gap: var(--space-2);
overflow-x: auto;
padding-bottom: var(--space-1);
-webkit-overflow-scrolling: touch;
}
.quick-reply {
padding: var(--space-2) var(--space-4);
border-radius: var(--radius-full);
background: var(--bg-secondary);
color: var(--text-primary);
border: 1px solid var(--border);
white-space: nowrap;
transition: all var(--transition-fast);
}
.quick-reply:hover:not(:disabled) {
border-color: var(--accent);
color: var(--accent);
}
.quick-reply:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.quick-reply.ghost {
background: transparent;
color: var(--text-muted);
}
.typing-indicator {
display: flex;
gap: var(--space-2);
align-items: center;
}
.typing-indicator span {
width: 6px;
height: 6px;
border-radius: 50%;
background: var(--text-muted);
animation: typingPulse 1.2s infinite;
}
.typing-indicator span:nth-child(2) {
animation-delay: 0.2s;
}
.typing-indicator span:nth-child(3) {
animation-delay: 0.4s;
}
@keyframes slideUp {
from { transform: translateY(12px); opacity: 0; }
to { transform: translateY(0); opacity: 1; }
}
@keyframes typingPulse {
0%, 100% { transform: translateY(0); opacity: 0.4; }
50% { transform: translateY(-4px); opacity: 1; }
}
@media (max-width: 700px) {
.chat-onboarding {
padding: var(--space-3);
}
.chat-shell {
min-height: calc(100vh - var(--space-6));
}
.chat-header {
padding: var(--space-4);
}
.chat-messages {
padding: var(--space-4);
}
}
.field input:focus {
border-color: var(--accent);
box-shadow: 0 0 0 3px var(--accent-subtle);
@@ -570,4 +820,4 @@ input[type="tel"],
select,
textarea {
font-size: 16px;
}
}