:root{color-scheme:light;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:radial-gradient(circle at top left,rgba(251,191,36,.12),transparent 28%),radial-gradient(circle at top right,rgba(34,197,94,.14),transparent 32%),linear-gradient(180deg,#f8fbf7,#eef5ff);color:#122033}*{box-sizing:border-box}html,body,#app{min-height:100%;overflow-x:hidden}body{margin:0;touch-action:pan-y;overscroll-behavior-x:none}button,input,textarea{font:inherit}a{color:inherit;text-decoration:none}.auth-shell,.app-shell{min-height:100vh}.auth-shell{display:grid;place-items:center;padding:24px}.auth-card,.surface-card,.card{background:#ffffffc2;border:1px solid rgba(255,255,255,.9);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 26px 70px #0f172a14}.auth-card{width:min(100%,430px);padding:30px;border-radius:32px;display:grid;gap:20px}.auth-brand h1,.hero-card h2,.contacts-header h2,.profile-hero h2,.top-bar h1{margin:0}.auth-brand{display:grid;gap:8px}.eyebrow,.hero-eyebrow,.top-bar-caption{margin:0;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#0f766e}.stack{display:grid;gap:12px}input,textarea{width:100%;border:1px solid rgba(148,163,184,.22);border-radius:18px;padding:14px 16px;background:#ffffffe6;color:#122033}button{border:none;cursor:pointer}.primary-btn,.ghost-btn,.send-btn,.icon-btn{border-radius:18px;padding:12px 16px;font-weight:700}.primary-btn,.send-btn,.plus-btn,.floating-plus-btn{color:#fff;background:linear-gradient(135deg,#1ca66a,#1686d9);box-shadow:0 16px 30px #1686d938}.ghost-btn,.icon-btn{background:#f1f5f9eb;color:#122033}.ghost-btn.danger{background:#fee2e2;color:#dc2626}.auth-submit,.switch-btn{width:100%}.app-shell{display:grid;min-height:100vh;grid-template-rows:auto minmax(0,1fr)}.top-bar{position:sticky;top:0;z-index:20;display:flex;align-items:flex-end;justify-content:space-between;min-height:72px;padding:16px 18px 8px;background:#f8fbf7c7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.top-bar-actions{display:flex;align-items:center;gap:10px}.top-bar-main{min-width:0}.top-bar-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.top-bar h1{font-size:28px;line-height:1.1}.top-status-chip{display:inline-flex;align-items:center;height:28px;padding:0 10px;border-radius:999px;background:#0f766e14;color:#0f766e;font-size:12px;font-weight:700}.top-status-chip.online{background:#22c55e1f;color:#15803d}.plus-btn,.floating-plus-btn{width:42px;height:42px;border-radius:15px;font-size:28px;line-height:1}.floating-plus-btn{position:fixed;top:18px;right:16px;z-index:24}.view-panel{min-height:0;padding:10px 16px 94px}.view-panel.chat-room-panel{display:flex;height:calc(100vh - 72px);padding:10px 16px 12px;overflow:hidden}.page-section{display:grid;gap:16px;align-content:start}.hero-card,.surface-card{border-radius:28px}.hero-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px;background:radial-gradient(circle at top right,rgba(255,255,255,.72),transparent 36%),linear-gradient(135deg,#0f766e,#1d4ed8);color:#fff;box-shadow:0 28px 60px #0e746e33}.hero-card .muted,.hero-card .hero-eyebrow{color:#ffffffd1}.hero-status{flex-shrink:0;padding:10px 14px;border-radius:999px;background:#ffffff26;font-size:13px;font-weight:700}.hero-status.online{background:#ffffff38}.surface-card{padding:18px;height:fit-content}.section-title-row,.panel-head,.inline-actions,.inline-form{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.chat-page{align-content:start}.chat-list-card{align-self:start}.chat-list-card .section-title-row{margin-bottom:14px}.chat-list-head{align-items:center;margin-bottom:16px}.compact-btn{height:38px;padding:0 16px;border-radius:14px;color:#fff;background:linear-gradient(135deg,#f59e0b,#f97316);box-shadow:0 14px 28px #f973163d}.section-title-row h3,.panel-head h2,.panel-head h3{margin:0}.section-pill{min-width:36px;height:36px;display:inline-grid;place-items:center;border-radius:999px;background:#0f766e1a;color:#0f766e;font-weight:700}.conversation-stack,.list-grid,.message-thread{display:grid;gap:12px}.conversation-item,.directory-card{display:flex;align-items:center;justify-content:space-between;gap:14px}.conversation-item{width:100%;padding:14px;border-radius:22px;text-align:left;background:#ffffffe6;box-shadow:inset 0 0 0 1px #e2e8f0bf}.swipe-row{position:relative;overflow:hidden;border-radius:22px;isolation:isolate}.swipe-card{position:relative;z-index:2;transition:transform .22s ease}.swipe-delete-btn{position:absolute;top:0;right:0;bottom:0;width:94px;border-radius:0 22px 22px 0;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-weight:800;letter-spacing:.02em;opacity:0;pointer-events:none;transform:translate(100%);transition:transform .22s ease,opacity .18s ease}.swipe-row.active .swipe-delete-btn{opacity:1;pointer-events:auto;transform:translate(0)}.conversation-side-actions{display:grid;justify-items:end;gap:8px;min-width:16px}.slim-btn{height:30px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:700}.dot-badge{width:10px;height:10px;border-radius:999px;background:#ef4444;flex-shrink:0;box-shadow:0 0 0 4px #ef444424}.conversation-main{flex:1;min-width:0;display:grid;gap:4px}.conversation-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.conversation-heading{display:flex;align-items:center;gap:8px;min-width:0}.chat-kind-tag{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:700}.chat-kind-tag.direct{background:#f59e0b1f;color:#b45309}.chat-kind-tag.group{background:#2563eb1f;color:#1d4ed8}.conversation-preview{margin:0;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.time-chip{font-size:12px;color:#64748b}.avatar-badge,.message-side-avatar,.profile-hero-avatar{display:grid;place-items:center;color:#fff;font-weight:800}.avatar-badge{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#0f766e,#22c55e);flex-shrink:0}.avatar-badge.soft{background:linear-gradient(135deg,#f59e0b,#f97316)}.avatar-badge.group{background:linear-gradient(135deg,#7c3aed,#2563eb)}.badge{min-width:24px;height:24px;display:inline-grid;place-items:center;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:12px;font-weight:700}.empty-card{padding:26px 20px;border-radius:24px;background:#ffffffb8;text-align:center}.empty-card.compact{padding:18px 16px}.muted{margin:0;color:#64748b}.chat-room-page{display:flex;flex-direction:column;flex:1;gap:12px;height:100%;min-height:0;padding-bottom:0;overflow:hidden}.compact-card{padding:16px 18px;border-radius:24px}.group-announcement-banner{display:grid;gap:10px;padding:12px 14px;border-radius:20px;background:linear-gradient(135deg,#fffffff5,#f3f8fff0),radial-gradient(circle at top right,rgba(16,185,129,.08),transparent 42%);box-shadow:0 14px 30px #0f172a0f}.group-announcement-banner.single-line{gap:0;padding:10px 14px}.group-announcement-banner.in-chat{margin-bottom:12px}.group-announcement-inline-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:16px;background:#ffffffe0;box-shadow:inset 0 0 0 1px #e2e8f0cc}.sticky-announcement-bar{position:sticky;top:74px;z-index:11;margin-top:0}.group-announcement-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.group-announcement-head.compact{align-items:center;gap:10px}.group-announcement-head h3{margin:0;font-size:18px}.announcement-edit-btn{height:30px;padding:0 12px;border-radius:999px;background:#0f766e1f;color:#0f766e;font-size:13px;font-weight:700}.chat-room-header{display:flex;align-items:center;gap:12px}.sticky-room-header{flex-shrink:0;position:sticky;top:0;z-index:12;padding:8px 0 10px;border-radius:20px;background:#ffffff8f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.room-menu-wrap{position:relative;margin-left:auto}.room-menu-btn{min-width:48px;height:40px;border-radius:14px;background:#f1f5f9eb;color:#122033;font-size:18px;letter-spacing:2px}.room-menu-pop{position:absolute;top:48px;right:0;z-index:8;display:grid;min-width:132px;padding:8px;border-radius:18px;background:#122033f0;box-shadow:0 18px 36px #0f172a2e}.room-menu-item{padding:10px 12px;border-radius:12px;background:transparent;color:#fff;text-align:left;font-weight:600}.room-menu-item:hover{background:#ffffff14}.back-btn{min-width:66px;border-radius:999px;padding:10px 14px;background:#ffffffdb;box-shadow:0 12px 22px #0f172a14}.chat-room-meta h2{margin:0;font-size:24px}.chat-room-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.chat-room-meta p{margin:4px 0 0;color:#64748b}.chat-room-body{display:flex;flex-direction:column;align-items:stretch;flex:1;gap:12px;min-height:0;padding:12px;border-radius:28px;background:linear-gradient(180deg,#ffffff8a,#ffffffc2),linear-gradient(135deg,#10b98114,#3b82f614);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}.invite-card{margin-top:0}.message-row{display:flex;align-items:flex-end;gap:10px}.message-row.system{justify-content:center}.message-row.self{justify-content:flex-end}.message-row.self .message-side-avatar{order:2}.message-side-avatar{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#0f766e,#22c55e);flex-shrink:0;font-size:12px}.message-row.self .message-side-avatar{background:linear-gradient(135deg,#f59e0b,#ef4444)}.message-bubble{max-width:min(72vw,320px);padding:12px 14px;border-radius:22px 22px 22px 8px;background:#fffffff5;box-shadow:0 12px 28px #0f172a14}.message-row.self .message-bubble{background:linear-gradient(135deg,#d9fbe7,#ecfeff);border-radius:22px 22px 8px}.message-meta{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:#64748b}.message-text{margin:8px 0 0;line-height:1.6;word-break:break-word}.message-image{width:min(100%,240px);margin-top:8px;border-radius:16px;display:block}.system-message{max-width:84%;padding:8px 12px;border-radius:999px;background:#94a3b82e;color:#475569;font-size:12px;text-align:center}.chat-input-bar{display:grid;grid-template-columns:auto 1fr auto;gap:10px;padding:10px;margin-bottom:0;border-radius:26px;background:#fffc;box-shadow:0 18px 32px #0f172a14}.sticky-chat-input{flex-shrink:0;z-index:12;margin-top:0}.chat-input{height:46px;border-radius:16px}.icon-btn,.send-btn{height:46px}.contacts-header,.profile-hero{display:flex;align-items:center;gap:16px}.directory-card{padding:16px;border-radius:24px}.directory-meta{display:flex;align-items:center;gap:14px}.contact-actions{display:grid;justify-items:end;gap:8px}.profile-hero{padding:18px;border-radius:30px;background:linear-gradient(135deg,#0e746eeb,#3b82f6eb);color:#fff;box-shadow:0 28px 60px #1e40af2e}.profile-hero .muted,.profile-hero .hero-eyebrow{color:#ffffffd6}.profile-hero-avatar{width:68px;height:68px;border-radius:24px;background:#ffffff29;font-size:24px}.profile-row{display:grid;gap:6px;padding:14px 0;border-bottom:1px solid rgba(148,163,184,.16)}.announcement-chip{flex-shrink:0;display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:999px;background:#0f766e1a;color:#0f766e;font-size:11px;font-weight:700}.group-announcement-text{margin:0;flex:1;color:#0f172a;font-size:14px;line-height:1.4}.line-clamp-1{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-announcement-editor textarea{min-height:72px}.profile-row:last-of-type{border-bottom:none}.profile-label{font-size:13px;color:#64748b}.profile-value strong{font-size:18px}.logout-btn{width:100%;padding:14px 16px;border-radius:20px;background:#122033;color:#fff;font-weight:700}.overlay{position:fixed;inset:0;z-index:50;display:grid;align-items:end;background:#0f172a4d}.action-sheet{display:grid;gap:16px;padding:18px 16px 26px;background:linear-gradient(180deg,#fffffffa,#f3f8fffa),linear-gradient(135deg,#0ea5e90a,#22c55e0a);border-radius:28px 28px 0 0;max-height:86vh;overflow:auto}.action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.action-tile{min-height:92px;padding:14px 10px;display:grid;align-content:center;gap:6px;border-radius:22px;text-align:left;background:#ffffffeb;box-shadow:inset 0 0 0 1px #e2e8f0c7}.action-tile span{font-weight:800}.action-tile small{color:#64748b}.success-text{color:#0f766e}.error-text{color:#dc2626}.hidden{display:none}.bottom-nav{position:fixed;left:12px;right:12px;bottom:10px;z-index:30;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px;border-radius:24px;background:#ffffffe6;box-shadow:0 20px 36px #0f172a1f;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.bottom-nav a{display:grid;place-items:center;min-height:44px;border-radius:16px;font-size:14px;font-weight:700;color:#475569}.bottom-nav .router-link-active{color:#0f766e;background:#0f766e14}@media(min-width:900px){.view-panel{max-width:860px;width:100%;margin:0 auto;padding:14px 24px 104px}.view-panel.chat-room-panel{height:calc(100vh - 82px);padding:14px 24px 18px}.top-bar{padding:18px 24px 10px}.floating-plus-btn{top:24px;right:24px}.chat-room-body{padding:20px}.overlay{place-items:center}.action-sheet{width:min(720px,92vw);border-radius:28px}.bottom-nav{left:50%;right:auto;width:540px;transform:translate(-50%)}}
