:root{font-family:PingFang SC,Hiragino Sans GB,Noto Sans SC,Segoe UI,sans-serif;color:#311425;background:#fdebf5;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--paper: rgba(255, 243, 250, .82);--paper-strong: rgba(255, 248, 253, .94);--paper-soft: rgba(255, 255, 255, .64);--ink: #311425;--muted: #8a5f79;--line: rgba(145, 60, 109, .16);--accent: #f05aa6;--accent-deep: #c5337f;--green: #cb3a90}*{box-sizing:border-box}html,body,#app{margin:0;min-height:100%;width:100%;overflow-x:hidden}body{min-height:100vh;background:radial-gradient(circle at top left,rgba(255,177,217,.92),transparent 30%),radial-gradient(circle at right center,rgba(255,214,236,.7),transparent 30%),linear-gradient(135deg,#fdebf5,#f8ddea 45%,#f2cde0)}button,input,textarea{font:inherit}select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid rgba(145,60,109,.2);background:#ffffffc7;color:var(--ink);outline:none}button{border:0;cursor:pointer}h1,h2,h3,p{margin:0}.shell{position:relative;min-height:100dvh;padding:max(12px,env(safe-area-inset-top)) 12px max(12px,env(safe-area-inset-bottom));overflow:hidden}.backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:24px 24px;-webkit-mask-image:radial-gradient(circle at center,black 20%,transparent 80%);mask-image:radial-gradient(circle at center,black 20%,transparent 80%);pointer-events:none}.auth-card,.app-frame{position:relative;z-index:1}.auth-card{width:min(100%,520px);margin:6vh auto 0;padding:24px 20px;background:var(--paper-strong);border:1px solid var(--line);border-radius:28px;box-shadow:0 30px 80px #913c6d33;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.compact-card{text-align:center}.eyebrow{margin:0 0 8px;color:var(--accent-deep);font-size:12px;letter-spacing:.16em;text-transform:uppercase}h1{font-size:clamp(30px,10vw,52px);line-height:1.02;letter-spacing:-.04em}h2{font-size:clamp(22px,7vw,32px);line-height:1.08}.muted{color:var(--muted)}.auth-card .muted{margin-top:14px}.auth-form{display:grid;gap:16px;margin-top:28px}.auth-form label,.contact-form{display:grid;gap:8px}.auth-form span{font-size:14px;color:var(--muted)}input,textarea{width:100%;padding:14px 16px;border-radius:18px;border:1px solid rgba(145,60,109,.2);background:#ffffffb3;color:var(--ink);outline:none;-webkit-appearance:none}textarea{resize:none;min-height:88px}input:focus,textarea:focus{border-color:#f05aa68c;box-shadow:0 0 0 4px #f05aa629}.primary-button,.ghost-button,.contact-form button,.emoji-button,.back-button{min-height:44px;border-radius:16px;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.primary-button{padding:14px 18px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-deep) 100%);color:#fff5fb;box-shadow:0 18px 34px #c5337f4d}.ghost-button,.contact-form button,.back-button{padding:12px 16px;background:var(--paper-soft);color:var(--ink);border:1px solid var(--line)}.primary-button:hover,.ghost-button:hover,.contact-form button:hover,.emoji-button:hover,.contact-item:hover,.back-button:hover{transform:translateY(-1px)}.auth-card .ghost-button{width:100%;margin-top:14px}.app-frame{display:grid;grid-template-columns:1fr;gap:12px;min-height:calc(100dvh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom));padding-bottom:calc(84px + env(safe-area-inset-bottom));min-width:0}.sidebar,.chat-panel,.profile-panel{display:flex;flex-direction:column;min-height:0;background:var(--paper);border:1px solid var(--line);border-radius:28px;box-shadow:0 24px 60px #913c6d24;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);min-width:0}.sidebar,.chat-panel,.profile-panel{padding:16px}.mobile-pane{min-height:calc(100dvh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}.sidebar-header,.chat-header,.panel-foot{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.sidebar-user,.profile-title{display:grid;gap:4px}.username-tag{font-size:12px}.avatar{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:#ffffffbd}.avatar-lg{width:56px;height:56px;border-radius:16px}.status-pill{padding:8px 12px;border-radius:999px;font-size:12px;text-transform:uppercase;background:#ffffffb8}.status-pill.online{color:var(--green)}.status-pill.connecting{color:var(--accent-deep)}.status-pill.offline{color:#9e4d4d}.mobile-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.mobile-summary div{display:grid;gap:2px;padding:14px;border-radius:20px;border:1px solid var(--line);background:#ffffff94}.mobile-summary strong{font-size:18px}.mobile-summary span{color:var(--muted);font-size:13px}.contact-form{display:flex;align-items:center;gap:8px;margin:16px 0}.contact-form input{flex:1 1 auto;min-width:0;padding:10px 12px;border-radius:14px}.contact-form button{flex:0 0 auto;margin-left:auto;min-height:38px;padding:8px 14px;border-radius:12px}.contacts,.messages{display:flex;flex-direction:column;gap:12px;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch}.contact-item,.empty-card,.message-bubble,.composer-box,.chat-empty{border:1px solid var(--line)}.contact-item{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:16px;text-align:left;background:#ffffff8f;border-radius:22px}.contact-copy{min-width:0;flex:1}.contact-item strong{display:block;font-size:16px}.contact-item p{margin-top:4px;color:var(--muted);font-size:13px}.contact-preview{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-meta{display:grid;justify-items:end;gap:8px;flex:0 0 auto}.contact-item.active{background:linear-gradient(135deg,#f05aa62e,#fff6fbf0);border-color:#f05aa657}.contact-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--green),#b9e6d2)}.unread-badge{min-width:22px;height:22px;padding:0 7px;display:inline-grid;place-items:center;border-radius:999px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-deep) 100%);color:#fff5fb;font-size:11px;font-weight:700;line-height:1}.empty-card,.chat-empty{display:grid;place-items:center;gap:8px;text-align:center;color:var(--muted);padding:24px;border-radius:24px;background:#ffffff6b}.chat-panel{gap:12px}.profile-panel{gap:14px}.profile-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.profile-grid{display:grid;gap:12px}.profile-card{display:grid;gap:6px;padding:16px;border-radius:22px;border:1px solid var(--line);background:#ffffff94}.profile-label{display:grid;gap:6px;font-size:13px;color:var(--muted)}.profile-select{margin-top:2px}.avatar-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.avatar-pick{padding:6px;border-radius:12px;border:1px solid var(--line);background:#ffffffbf}.avatar-pick.active{border-color:#f05aa6a6;box-shadow:0 0 0 3px #f05aa633}.profile-card strong{font-size:18px}.profile-card span{color:var(--muted);font-size:13px}.logout-button{justify-self:start;min-width:110px;background:#f05aa61f;border-color:#f05aa652;color:var(--accent-deep)}.accent-card{background:linear-gradient(135deg,#f05aa633,#fff5fbf2);border-color:#f05aa657}.wide-card{min-height:118px}.chat-header{padding-bottom:10px;border-bottom:1px solid var(--line)}.chat-title-wrap{display:flex;align-items:center;gap:10px}.chat-header-right{display:grid;gap:6px;justify-items:end}.read-toggle{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#ffffff8f;border:1px solid var(--line);font-size:12px;color:var(--muted)}.read-toggle input{width:16px;height:16px;margin:0}.back-button{flex:0 0 auto}.chat-header-note{max-width:220px;font-size:13px;text-align:right}.messages{flex:1;padding:8px 0}.message-row{display:flex}.message-row.outgoing{justify-content:flex-end}.message-bubble{max-width:min(88%,560px);padding:14px 16px 10px;border-radius:22px;background:#ffffffb8;box-shadow:0 16px 30px #913c6d1f}.message-row.outgoing .message-bubble{background:linear-gradient(135deg,#f05aa633,#fff8fcf5)}.message-bubble p{white-space:pre-wrap;word-break:break-word}.message-bubble span{display:block;margin-top:8px;color:var(--muted);font-size:12px}.message-meta{display:flex;justify-content:flex-end;gap:8px;align-items:center;margin-top:8px}.message-state{font-size:12px;color:var(--accent-deep);font-weight:600}.message-image{display:block;width:min(100%,280px);border-radius:18px;cursor:zoom-in}.composer{display:grid;gap:10px;margin-top:auto;position:sticky;bottom:0;padding-bottom:max(4px,env(safe-area-inset-bottom));background:linear-gradient(180deg,#fdebf500,#fdebf5bd 18%,#fdebf5eb);min-width:0}.composer-tools-row{display:flex;gap:8px;overflow:auto hidden;padding:2px 0;align-items:center}.emoji-button{width:36px;height:36px;flex:0 0 auto;background:#ffffffbd;border:1px solid var(--line);border-radius:999px}.composer-box{padding:10px;border-radius:18px;background:#fffbf5f2;min-width:0}.composer-inline{display:flex;align-items:flex-end;gap:8px;min-width:0}.composer-box textarea{flex:1 1 auto;min-width:0;min-height:38px;max-height:108px;padding:10px 12px;border-radius:14px;font-size:14px;line-height:1.35;overflow:auto}.composer-actions{display:flex;justify-content:flex-end;align-items:center;flex:0 0 auto;gap:8px;margin-top:0}.image-icon-button{width:36px;min-width:36px;min-height:36px;height:36px;padding:0;border-radius:999px;display:inline-grid;place-items:center;font-size:15px;line-height:1}.toggle-tools-button{width:36px;min-width:36px;min-height:36px;height:36px;padding:0;border-radius:999px;display:inline-grid;place-items:center;font-size:20px;line-height:1;font-weight:500}.send-pill-button{min-height:38px;padding:8px 22px;border-radius:999px;font-weight:600}.panel-foot{min-height:24px}.notice{font-size:13px}.notice.info{color:var(--green)}.notice.error{color:#a23c3c}.mobile-tabbar{position:fixed;left:12px;right:12px;bottom:max(10px,env(safe-area-inset-bottom));z-index:3;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:8px;border-radius:24px;border:1px solid rgba(145,60,109,.14);background:#fffcf7d1;box-shadow:0 20px 40px #913c6d33;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.tab-button{min-height:48px;padding:12px 10px;border-radius:18px;background:transparent;color:var(--muted);transition:background .16s ease,color .16s ease,transform .16s ease}.tab-button.active{background:linear-gradient(135deg,#f05aa633,#fff5fbf5);color:var(--accent-deep);box-shadow:inset 0 0 0 1px #f05aa633}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#140e0ad6;padding:18px}.lightbox-image{max-width:min(94vw,760px);max-height:80vh;border-radius:18px;box-shadow:0 20px 80px #00000073}.lightbox-close{margin-top:12px;min-height:42px;padding:10px 18px;border-radius:999px;color:#fff;background:#ffffff29;border:1px solid rgba(255,255,255,.3)}@media(min-width:821px){.shell{padding:24px}.auth-card{padding:32px;margin-top:8vh}.app-frame{grid-template-columns:340px 1fr;gap:20px;min-height:calc(100vh - 48px);padding-bottom:0}.sidebar,.chat-panel,.profile-panel{padding:22px}.mobile-summary{display:none}.chat-header,.panel-foot,.sidebar-header{align-items:center}.chat-header-right{justify-items:end}.chat-header-note{text-align:right}.composer{position:static;padding-bottom:0;background:transparent}.composer-actions{display:flex;justify-content:flex-end}.composer-actions button{min-width:108px}.composer-actions .image-icon-button{min-width:38px}.composer-actions .toggle-tools-button{min-width:36px}.mobile-tabbar{display:none}}@media(max-width:480px){.shell{padding-left:10px;padding-right:10px}.auth-card,.sidebar,.chat-panel{border-radius:24px}.sidebar-header,.chat-header,.panel-foot{flex-direction:column}.chat-header-right{width:100%;justify-items:start}.chat-header-note{max-width:none;text-align:left}.message-bubble{max-width:92%}.composer-box textarea{font-size:16px}}
