:root { --bg: #f6f8fb; --surface: #fff; --surface-soft: #f9fbff; --ink: #101828; --text: #344054; --muted: #667085; --line: #e4e7ec; --line-strong: #d0d5dd; --primary: #335cff; --primary-soft: #eef3ff; --success: #0e9384; --success-soft: #e7f8f5; --warning: #b54708; --warning-soft: #fff4e5; --danger: #b42318; --danger-soft: #ffebe9; --nav: #0b1220; --nav-muted: #7d89a5; --radius: 8px; --ease: cubic-bezier(.2, .8, .2, 1); font-family: Inter, "SF Pro Display", "Segoe UI", "PingFang SC", "Microsoft YaHei", Arial, sans-serif; } * { box-sizing: border-box; } body { margin: 0; min-height: 100dvh; color: var(--text); background: var(--bg); } button, input, select, textarea { font: inherit; } button { cursor: pointer; } button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 3px solid rgba(51,92,255,.24); outline-offset: 2px; } .eyebrow { color: var(--primary); font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; } h1, h2, h3, p { margin: 0; } h1 { margin-top: 4px; color: var(--ink); font-size: clamp(25px, 3vw, 36px); line-height: 1.1; } .btn { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 0 14px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; color: var(--text); font-weight: 700; transition: transform 180ms var(--ease), box-shadow 180ms var(--ease), background 180ms var(--ease), border-color 180ms var(--ease); } .btn:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(16,24,40,.08); } .btn:active, .mini-btn:active, .chip:active, .nav-btn:active { transform: scale(.97); } .btn.primary { border-color: transparent; background: var(--primary); color: #fff; box-shadow: 0 12px 24px rgba(51,92,255,.22); } .btn.success { border-color: transparent; background: var(--success); color: #fff; } .btn.danger { border-color: rgba(180,35,24,.18); background: var(--danger-soft); color: var(--danger); } .btn.ghost { background: transparent; } .badge { display: inline-flex; min-height: 26px; align-items: center; padding: 4px 9px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-size: 12px; font-weight: 780; white-space: nowrap; } .badge.success { background: var(--success-soft); color: var(--success); } .badge.warning { background: var(--warning-soft); color: var(--warning); } .badge.danger { background: var(--danger-soft); color: var(--danger); } .panel { border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); box-shadow: 0 1px 2px rgba(16,24,40,.04); transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms var(--ease); } .panel:hover { transform: translateY(-2px); border-color: rgba(51,92,255,.22); box-shadow: 0 16px 42px rgba(16,24,40,.08); } .mini-btn { min-height: 34px; padding: 0 10px; border: 1px solid var(--line); border-radius: 7px; background: #fff; color: var(--text); font-size: 12px; font-weight: 750; } @keyframes grow { from { transform: scaleX(0); transform-origin: left; } to { transform: scaleX(1); transform-origin: left; } } @keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } } .message-list-enter-active, .message-list-leave-active { transition: opacity 220ms var(--ease), transform 220ms var(--ease); } .message-list-enter-from { opacity: 0; transform: translateY(8px) scale(.98); } .message-list-leave-to { opacity: 0; transform: translateY(-6px) scale(.98); } @media (max-width: 1180px) { .metric-strip, .overview-grid { grid-template-columns: 1fr 1fr; } } @media (max-width: 760px) { .topbar { flex-direction: column; padding: 18px 16px; } .top-actions, .search, .btn { width: 100%; } .filters, .metric-strip, .overview-grid, .donut-layout, .dialog-body, .dialog-foot, .review-summary, .chat-hero { grid-template-columns: 1fr; } .filters, .workarea { padding-inline: 16px; } .bar-row { grid-template-columns: 1fr; gap: 6px; } .bar-row strong { text-align: left; } .case-panel { border-left: 0; border-top: 1px solid var(--line); } .review-summary { grid-column: auto; } } @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 1ms !important; transition-duration: 1ms !important; scroll-behavior: auto !important; } }