|
|
|
|
|
:root{
|
|
|
|
|
|
--bg: #f7f9fb;
|
|
|
--bg-accent: #eef3f7;
|
|
|
--card: #ffffff;
|
|
|
--border: #e5ebf0;
|
|
|
--text: #1f2937;
|
|
|
--muted: #6b7280;
|
|
|
--muted-2: #9aa3ae;
|
|
|
|
|
|
--accent: #6ea8fe;
|
|
|
--accent-weak: #e8f1ff;
|
|
|
--you: #8ed1c6;
|
|
|
--you-weak: #e9f7f4;
|
|
|
|
|
|
--shadow: 0 12px 30px rgba(16,24,40,.06);
|
|
|
--radius-lg: 18px;
|
|
|
--radius-md: 14px;
|
|
|
--radius-sm: 12px;
|
|
|
|
|
|
--focus-ring: 0 0 0 4px rgba(110,168,254,.25);
|
|
|
}
|
|
|
|
|
|
|
|
|
[data-theme="dark"]{
|
|
|
--bg: #0f1720;
|
|
|
--bg-accent: #0e1b28;
|
|
|
--card: #111827cc;
|
|
|
--border: rgba(255,255,255,.08);
|
|
|
--text: #e5e7eb;
|
|
|
--muted: #a3a9b3;
|
|
|
--muted-2: #94a3b8;
|
|
|
|
|
|
--accent: #7ab0ff;
|
|
|
--accent-weak: rgba(122,176,255,.08);
|
|
|
--you: #9adacc;
|
|
|
--you-weak: rgba(154,218,204,.10);
|
|
|
|
|
|
--shadow: 0 18px 40px rgba(0,0,0,.45);
|
|
|
}
|
|
|
|
|
|
|
|
|
*{box-sizing:border-box}
|
|
|
html,body{height:100%}
|
|
|
body{
|
|
|
margin:0;
|
|
|
font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans";
|
|
|
color:var(--text);
|
|
|
background:
|
|
|
radial-gradient(1200px 700px at 10% -10%, var(--bg-accent), transparent 60%),
|
|
|
radial-gradient(1200px 700px at 90% 0%, var(--bg-accent), transparent 60%),
|
|
|
var(--bg);
|
|
|
background-attachment: fixed;
|
|
|
}
|
|
|
|
|
|
|
|
|
.page{
|
|
|
min-height:100%;
|
|
|
display:flex;
|
|
|
align-items:center;
|
|
|
justify-content:center;
|
|
|
padding:24px;
|
|
|
}
|
|
|
.chat-card{
|
|
|
width:100%;
|
|
|
max-width: 920px;
|
|
|
height: 80vh;
|
|
|
min-height:560px;
|
|
|
display:flex;
|
|
|
flex-direction:column;
|
|
|
border-radius: var(--radius-lg);
|
|
|
backdrop-filter: blur(8px);
|
|
|
background: var(--card);
|
|
|
border:1px solid var(--border);
|
|
|
overflow:hidden;
|
|
|
box-shadow: var(--shadow);
|
|
|
}
|
|
|
|
|
|
|
|
|
.chat-header{
|
|
|
display:flex;align-items:center;gap:14px;
|
|
|
padding:14px 16px;
|
|
|
border-bottom:1px solid var(--border);
|
|
|
background: linear-gradient(180deg, var(--card), color-mix(in srgb, var(--card) 92%, transparent));
|
|
|
}
|
|
|
.avatar{position:relative;width:44px;height:44px}
|
|
|
.avatar img{
|
|
|
width:44px;height:44px;border-radius:50%;
|
|
|
border:2px solid color-mix(in srgb, var(--border) 50%, transparent);
|
|
|
}
|
|
|
.status-dot{
|
|
|
position:absolute;right:-2px;bottom:-2px;
|
|
|
width:12px;height:12px;border-radius:50%;
|
|
|
background:#16a34a;border:2px solid var(--card);
|
|
|
}
|
|
|
.hdr-text .title{font-weight:700;letter-spacing:.2px}
|
|
|
.hdr-text .subtitle{color:var(--muted);font-size:12px;margin-top:-2px}
|
|
|
.hdr-actions{display:flex;gap:8px}
|
|
|
.btn-icon{
|
|
|
width:36px;height:36px;border-radius:10px;border:1px solid var(--border);
|
|
|
background: color-mix(in srgb, var(--card) 92%, white 8%);
|
|
|
color:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
|
|
|
transition: box-shadow .15s, transform .05s;
|
|
|
}
|
|
|
.btn-icon:hover{box-shadow: var(--focus-ring)}
|
|
|
.btn-icon:active{transform: translateY(1px)}
|
|
|
|
|
|
|
|
|
.chat-body{
|
|
|
flex:1;overflow:auto;padding:18px;
|
|
|
display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth;
|
|
|
}
|
|
|
|
|
|
|
|
|
.empty-state{
|
|
|
margin:auto;text-align:center;max-width:520px;color:var(--muted);
|
|
|
}
|
|
|
.empty-state.hidden{display:none}
|
|
|
.empty-emoji{font-size:44px;margin-bottom:8px;opacity:.9}
|
|
|
.empty-title{font-size:18px;color:var(--text);margin-bottom:6px;font-weight:600}
|
|
|
.empty-hint{font-size:14px;margin-bottom:12px}
|
|
|
.empty-suggestions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
|
|
|
.chip{
|
|
|
border:1px solid var(--border);background:var(--accent-weak);color:#1e3a8a;
|
|
|
padding:8px 10px;border-radius:999px;font-size:13px;cursor:pointer;
|
|
|
}
|
|
|
[data-theme="dark"] .chip{color:#cfe1ff}
|
|
|
|
|
|
|
|
|
.msg{display:flex;gap:10px;align-items:flex-end}
|
|
|
.msg.user{justify-content:flex-end}
|
|
|
.msg-avatar img{
|
|
|
width:36px;height:36px;border-radius:50%;
|
|
|
border:1.5px solid var(--border);
|
|
|
}
|
|
|
.msg-bubble{
|
|
|
max-width: 72%;
|
|
|
padding:12px 14px;border-radius:16px;position:relative;line-height:1.5;word-wrap:anywhere;
|
|
|
background: color-mix(in srgb, var(--card) 94%, var(--bg-accent) 6%);
|
|
|
border:1px solid var(--border);
|
|
|
}
|
|
|
.msg.user .msg-bubble{
|
|
|
background: var(--you-weak);
|
|
|
border-color: color-mix(in srgb, var(--you) 38%, var(--border));
|
|
|
}
|
|
|
.msg.bot .msg-bubble{
|
|
|
background: var(--accent-weak);
|
|
|
border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
|
|
|
}
|
|
|
.msg-text{font-size:15px}
|
|
|
.msg-time{margin-top:6px;font-size:11px;color:var(--muted-2)}
|
|
|
|
|
|
|
|
|
.typing{display:flex;gap:6px;align-items:center;padding:0 18px 10px}
|
|
|
.typing.hidden{display:none}
|
|
|
.typing span{
|
|
|
display:inline-block;width:8px;height:8px;border-radius:50%;background: var(--muted);
|
|
|
opacity:.65;animation: bounce 1.4s infinite ease-in-out;
|
|
|
}
|
|
|
.typing span:nth-child(2){animation-delay:.15s}
|
|
|
.typing span:nth-child(3){animation-delay:.3s}
|
|
|
@keyframes bounce{0%,80%,100%{transform:scale(0)} 40%{transform:scale(1)}}
|
|
|
|
|
|
|
|
|
.chat-footer{
|
|
|
padding:12px;border-top:1px solid var(--border);
|
|
|
background: color-mix(in srgb, var(--card) 94%, transparent);
|
|
|
}
|
|
|
.input{
|
|
|
flex:1;resize:none;background: #ffffff;
|
|
|
border:1px solid var(--border);color:var(--text);
|
|
|
padding:12px 14px;border-radius: var(--radius-md);
|
|
|
outline:none;height:48px;transition:border .2s, box-shadow .2s, background .2s;
|
|
|
}
|
|
|
[data-theme="dark"] .input{background: color-mix(in srgb, var(--card) 88%, #000 12%)}
|
|
|
.input:focus{box-shadow: var(--focus-ring);border-color: color-mix(in srgb, var(--accent) 60%, var(--border))}
|
|
|
.send-btn{
|
|
|
margin-left:10px;width:48px;height:48px;border-radius: var(--radius-sm);
|
|
|
display:inline-flex;align-items:center;justify-content:center;
|
|
|
background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 80%, #3b82f6));
|
|
|
color:white;border:none;outline:none;cursor:pointer;transition: transform .05s, filter .2s, box-shadow .15s;
|
|
|
box-shadow: 0 6px 16px rgba(110,168,254,.35);
|
|
|
}
|
|
|
.send-btn:hover{box-shadow: 0 8px 22px rgba(110,168,254,.45)}
|
|
|
.send-btn:active{ transform: translateY(1px) }
|
|
|
.send-btn:disabled{ filter: grayscale(.4) brightness(.9); cursor:not-allowed }
|
|
|
|
|
|
|
|
|
.chat-body::-webkit-scrollbar{width:10px}
|
|
|
.chat-body::-webkit-scrollbar-thumb{
|
|
|
background: color-mix(in srgb, var(--muted) 30%, transparent);
|
|
|
border-radius:999px;border:2px solid transparent;background-clip:padding-box;
|
|
|
}
|
|
|
.chat-body{-ms-overflow-style:none;scrollbar-color: color-mix(in srgb, var(--muted) 30%, transparent) transparent}
|
|
|
|
|
|
|
|
|
@media (max-width: 576px){
|
|
|
.chat-card{height: 90
|
|
|
}
|
|
|
} |