CAPStone / static /style.css
Rohan246's picture
Upload 20 files
503a7f1 verified
/* ========== Calm, Accessible UI ========== */
:root{
/* Light (default) */
--bg: #f7f9fb;
--bg-accent: #eef3f7;
--card: #ffffff;
--border: #e5ebf0;
--text: #1f2937;
--muted: #6b7280;
--muted-2: #9aa3ae;
--accent: #6ea8fe; /* calm blue */
--accent-weak: #e8f1ff;
--you: #8ed1c6; /* mint */
--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);
}
/* Dark theme */
[data-theme="dark"]{
--bg: #0f1720;
--bg-accent: #0e1b28;
--card: #111827cc; /* glassy card */
--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);
}
/* Base */
*{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;
}
/* Layout */
.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);
}
/* Header */
.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)}
/* Body */
.chat-body{
flex:1;overflow:auto;padding:18px;
display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth;
}
/* Empty state */
.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}
/* Messages */
.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 dots */
.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)}}
/* Footer */
.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; /* light */
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 }
/* Scrollbar (subtle) */
.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}
/* Mobile tweaks */
@media (max-width: 576px){
.chat-card{height: 90
}
}