:root{--cream:#fff8f3;--pink:#ffb6c1;--blue:#add8e6;--lavender:plum;--text:#4a4a4a;--soft-pink:#ffe4e1;--mint:#b0e0e6;--shadow:0 4px 20px #b496b426;--radius:18px;--card-bg:#fff;--border:#eee0d8;--subtext:#888;--search-bg:#f7f0fa}*{box-sizing:border-box}#root,body,html{height:100%;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#fff8f3;background:var(--cream);color:#4a4a4a;color:var(--text);font-family:Quicksand,Nunito,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}button{background:none;border:none;cursor:pointer}button,input,textarea{color:inherit;font-family:inherit}.page-frame{min-height:100dvh;padding-bottom:env(safe-area-inset-bottom);position:relative;width:100%}@keyframes page-fade-in{0%{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.page-fade-in{animation:page-fade-in .45s cubic-bezier(.2,.8,.2,1)}@keyframes pop-in{0%{opacity:0;transform:scale(.5)}60%{opacity:1;transform:scale(1.08)}to{transform:scale(1)}}.pop-in{animation:pop-in .5s cubic-bezier(.2,.8,.2,1) both}@keyframes sticker-bounce{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-8px) rotate(-4deg)}}.sticker-bounce{animation:sticker-bounce 2.6s ease-in-out infinite}@keyframes sticker-wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.sticker-wiggle{animation:sticker-wiggle 3s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.sparkle{animation:sparkle 1.8s ease-in-out infinite}@keyframes status-pulse{0%,to{box-shadow:0 0 0 0 #add8e6b3}70%{box-shadow:0 0 0 10px #add8e600}}.status-pulse{animation:status-pulse 2s ease-out infinite}@keyframes typing-dot{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.typing-dot{animation:typing-dot 1.4s ease-in-out infinite}@keyframes caret-blink{0%,50%{opacity:1}50.01%,to{opacity:0}}.caret{animation:caret-blink 1s step-end infinite;background:plum;background:var(--lavender);display:inline-block;height:1em;margin-left:2px;vertical-align:text-bottom;width:2px}@keyframes slide-in-right{0%{transform:translateX(100%)}to{transform:translateX(0)}}.slide-in-right{animation:slide-in-right .35s cubic-bezier(.2,.8,.2,1)}@keyframes toast-in{0%{opacity:0;transform:translateX(120%)}to{opacity:1;transform:translateX(0)}}.toast-in{animation:toast-in .4s cubic-bezier(.2,.8,.2,1)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.float{animation:float 3s ease-in-out infinite}@keyframes modalIn{0%{opacity:0;transform:scale(.86) translateY(18px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modalOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.9) translateY(10px)}}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@keyframes backdropOut{0%{opacity:1}to{opacity:0}}.modal-in{animation:modalIn .32s cubic-bezier(.34,1.52,.64,1) both}.modal-out{animation:modalOut .2s cubic-bezier(.4,0,1,1) both}.backdrop-in{animation:backdropIn .22s ease both}.backdrop-out{animation:backdropOut .2s ease both}@keyframes alarmPop{0%{opacity:0;transform:translateY(-28px) scale(.88)}65%{transform:translateY(5px) scale(1.03)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bellSwing{0%,to{transform:rotate(0deg)}15%{transform:rotate(-12deg)}35%{transform:rotate(12deg)}55%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}@keyframes alarmGlow{0%,to{box-shadow:0 0 0 0 #ffb6c180,0 24px 60px #0009}50%{box-shadow:0 0 0 14px #ffb6c100,0 24px 60px #0009}}.alarm-popup{animation:alarmPop .5s cubic-bezier(.34,1.52,.64,1) both}.alarm-bell{animation:bellSwing .7s ease-in-out infinite;display:inline-block}.alarm-glow{animation:alarmGlow 1.4s ease-in-out infinite}.card{background:#fff;border-radius:18px;border-radius:var(--radius);box-shadow:0 4px 20px #b496b426;box-shadow:var(--shadow);padding:20px}.btn{align-items:center;background:#ffb6c1;background:var(--pink);border-radius:999px;color:#fff;display:inline-flex;font-weight:600;gap:8px;justify-content:center;padding:10px 22px;transition:transform .2s,box-shadow .2s}.btn:hover{box-shadow:0 6px 20px #ffb6c180;transform:translateY(-2px)}.btn:active{transform:scale(.97)}.btn.btn-blue{background:#add8e6;background:var(--blue)}.btn.btn-lavender{background:plum;background:var(--lavender)}.btn.btn-ghost{background:#0000;border:2px dashed #ffb6c1;border:2px dashed var(--pink);color:#4a4a4a;color:var(--text)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.input{background:#fff;border:2px solid #ffe4e1;border:2px solid var(--soft-pink);border-radius:999px;font-size:16px;outline:none;padding:12px 18px;transition:border-color .2s,box-shadow .2s;width:100%}.input:focus{border-color:#ffb6c1;border-color:var(--pink);box-shadow:0 0 0 3px #ffb6c140}.badge{align-items:center;background:#ffe4e1;background:var(--soft-pink);border-radius:999px;color:#4a4a4a;color:var(--text);display:inline-flex;font-size:12px;padding:3px 10px}.avatar{background:#fff;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #00000014;height:52px;object-fit:cover;width:52px}.avatar-lg{background:#fff;border:4px solid #fff;border-radius:50%;box-shadow:0 4px 16px #0000001a;height:96px;width:96px}.hamburger{border-radius:10px;cursor:pointer;display:inline-flex;flex-direction:column;height:36px;justify-content:space-between;padding:8px 6px;transition:background .2s;width:36px}.hamburger:hover{background:#ffe4e1;background:var(--soft-pink)}.hamburger span{background:#4a4a4a;background:var(--text);border-radius:3px;display:block;height:3px;width:100%}.container{margin:0 auto;max-width:960px;padding:24px 20px 80px}.center{align-items:flex-start;display:flex;justify-content:center;min-height:100dvh;overflow-y:auto;padding:calc(24px + env(safe-area-inset-top)) 16px calc(60px + env(safe-area-inset-bottom))}@media (min-height:700px){.center{align-items:center}}.hero{padding:30px 0 10px;text-align:center}.hero h1{background:linear-gradient(90deg,#ffb6c1,plum,#add8e6);background:linear-gradient(90deg,var(--pink),var(--lavender),var(--blue));-webkit-background-clip:text;background-clip:text;color:#0000;font-size:44px;margin:0 0 10px}.hero h1 .caret{background:#ffb6c1;background:var(--pink)}.tagline{color:#888;margin:0 0 30px}.home-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.home-tile{background:#fff;border:3px solid #0000;border-radius:18px;border-radius:var(--radius);box-shadow:0 4px 20px #b496b426;box-shadow:var(--shadow);cursor:pointer;padding:28px 22px;text-align:center;transition:transform .25s,box-shadow .25s}.home-tile:hover{border-color:#ffe4e1;border-color:var(--soft-pink);box-shadow:0 10px 30px #b496b440;transform:translateY(-6px) rotate(-.5deg)}.home-tile .emoji{display:block;font-size:54px;margin-bottom:10px}.home-tile h3{font-size:20px;margin:0 0 8px}.home-tile p{color:#777;font-size:14px;margin:0}.login-card{background:#fff;border-radius:28px;box-shadow:0 10px 40px #ffb6c14d;max-width:420px;padding:36px 28px;width:100%}.login-tabs{background:#ffe4e1;background:var(--soft-pink);border-radius:999px;display:flex;gap:4px;margin-bottom:22px;padding:4px}.login-tabs button{border-radius:999px;color:#4a4a4a;color:var(--text);flex:1 1;font-weight:600;padding:10px}.login-tabs button.active{background:#fff;box-shadow:0 2px 6px #00000014}.code-input{background:#fff8f3;background:var(--cream);border:2px solid plum;border:2px solid var(--lavender);border-radius:16px;font-size:22px;font-weight:700;letter-spacing:.25em;outline:none;padding:16px;text-align:center;text-transform:uppercase;width:100%}.code-input:focus{border-color:#ffb6c1;border-color:var(--pink);box-shadow:0 0 0 3px #ffb6c140}.code-display{background:linear-gradient(135deg,#ffe4e1,#b0e0e6);background:linear-gradient(135deg,var(--soft-pink),var(--mint));border-radius:16px;display:inline-block;font-family:Courier New,monospace;font-size:22px;font-weight:700;letter-spacing:.2em;padding:14px 24px}.avatar-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));max-height:360px;overflow-y:auto;padding:6px}.avatar-grid .avatar-option{aspect-ratio:1;background:#fff;border:3px solid #0000;border-radius:50%;cursor:pointer;padding:4px;position:relative;transition:transform .2s,box-shadow .2s}.avatar-grid .avatar-option:hover{transform:scale(1.1) rotate(-5deg)}.avatar-grid .avatar-option.selected{border-color:#ffb6c1;border-color:var(--pink);box-shadow:0 0 0 3px #ffe4e1;box-shadow:0 0 0 3px var(--soft-pink)}.avatar-grid .avatar-option img{border-radius:50%;height:100%;width:100%}.friend-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.friend-tile{align-items:center;background:#fff;border-radius:18px;border-radius:var(--radius);box-shadow:0 4px 20px #b496b426;box-shadow:var(--shadow);cursor:pointer;display:flex;gap:12px;padding:16px;transition:transform .2s}.friend-tile:hover{transform:translateY(-3px)}.friend-tile .name{font-weight:700;margin:0}.friend-tile .sub{color:#888;font-size:12px;margin:0}.friend-tile .dot{background:#ccc;border-radius:50%;display:inline-block;height:10px;margin-right:4px;width:10px}.friend-tile .dot.online{background:#7bd389}.chat-wrap{display:flex;flex-direction:column;height:100dvh;overflow:hidden;padding-top:env(safe-area-inset-top)}.chat-header{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffd9;border-bottom:1px solid #ffe4e1;border-bottom:1px solid var(--soft-pink);display:flex;justify-content:space-between;padding:12px 18px;position:sticky;top:0;z-index:5}.chat-header .peer{align-items:center;display:flex;gap:12px}.chat-header .peer h3{font-size:16px;margin:0}.chat-header .peer .status{color:#888;font-size:12px}.chat-header .peer .status.online{color:#4fa865}.chat-body{flex:1 1;overflow-y:auto;padding:16px;position:relative}.chat-footer{background:#fff;border-top:1px solid #ffe4e1;border-top:1px solid var(--soft-pink);gap:8px;padding:10px 14px calc(10px + env(safe-area-inset-bottom))}.chat-footer,.msg-row{align-items:flex-end;display:flex}.msg-row{padding:3px 12px}.msg-row.me{justify-content:flex-end}.msg-row.you{justify-content:flex-start}.msg-bubble-v2{word-wrap:break-word;border-radius:20px;font-size:15px;line-height:1.45;max-width:100%;padding:10px 13px 8px;position:relative;word-break:break-word}.msg-bubble-v2.own{background:linear-gradient(135deg,#ffb6c1,#e8a0d0);border-bottom-right-radius:5px;box-shadow:0 2px 12px #ffb6c166;color:#fff}.msg-bubble-v2.theirs{background:#fff;border-bottom-left-radius:5px;box-shadow:0 2px 8px #00000012;color:#4a4a4a;color:var(--text)}.msg-bubble-v2.emoji-only{background:#0000!important;box-shadow:none!important;font-size:42px;line-height:1.2;padding:2px 4px}.msg-bubble-v2.recalled{background:#f5f5f5!important;box-shadow:none!important;color:#aaa!important;font-style:italic;opacity:.55}.bubble-text{white-space:pre-wrap}.bubble-meta{align-items:center;display:flex;font-size:10px;gap:4px;justify-content:flex-end;margin-top:4px;opacity:.65}.reply-preview{background:#ffffff40;border-radius:10px;display:flex;gap:8px;margin-bottom:7px;overflow:hidden;padding:6px 8px}.msg-bubble-v2.theirs .reply-preview{background:#ffb6c11f}.reply-preview-bar{background:#ffffffb3;border-radius:2px;flex-shrink:0;width:3px}.msg-bubble-v2.theirs .reply-preview-bar{background:plum;background:var(--lavender)}.reply-preview-name{font-size:11px;font-weight:700;margin-bottom:2px;opacity:.9}.reply-preview-text{font-size:12px;max-width:200px;opacity:.75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-toolbar{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f;display:flex;flex-direction:column;flex-shrink:0;gap:3px;padding:4px;z-index:5}.msg-toolbar button{align-items:center;border-radius:8px;display:flex;font-size:15px;height:30px;justify-content:center;transition:background .15s;width:30px}.msg-toolbar button:hover{background:#ffe4e1;background:var(--soft-pink)}.date-pill{align-items:center;display:flex;justify-content:center;padding:20px 0 8px}.date-pill span{background:#c8b4dc26;border-radius:999px;color:#b0a0c0;font-size:11px;font-weight:600;letter-spacing:.03em;padding:4px 14px}.chat-input-area{background:#fff;border-top:1px solid #f0e6f0;padding:10px 14px calc(42px + env(safe-area-inset-bottom));position:relative}.input-row{align-items:flex-end;display:flex;gap:8px}.input-pill{background:#f7f0fa;border:1.5px solid #0000;border-radius:22px;flex:1 1;overflow:hidden;transition:border-color .2s,box-shadow .2s}.input-pill:focus-within{border-color:plum;box-shadow:0 0 0 3px #dda0dd26}.message-textarea{background:#0000;border:none;color:#4a4a4a;color:var(--text);display:block;font-family:inherit;font-size:15px;line-height:1.5;max-height:120px;min-height:42px;outline:none;padding:10px 16px;resize:none;width:100%}.message-textarea::placeholder{color:#c0b0cc}.icon-btn{align-items:center;background:#f7f0fa;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;height:42px;justify-content:center;transition:background .15s,transform .15s;width:42px}.icon-btn:hover{transform:scale(1.08)}.icon-btn.active,.icon-btn:hover{background:#ffe4e1;background:var(--soft-pink)}.send-btn{align-items:center;background:#e0d0ec;border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:42px;justify-content:center;transition:background .2s,transform .15s,box-shadow .2s;width:42px}.send-btn.active{background:linear-gradient(135deg,#ffb6c1,plum);box-shadow:0 4px 14px #dda0dd80}.send-btn.active:hover{transform:scale(1.08)}.send-btn:disabled{cursor:default;opacity:.6}.reply-bar{align-items:center;background:#dda0dd1a;border-radius:12px;display:flex;gap:10px;margin-bottom:8px;padding:8px 12px}.reply-bar-accent{background:plum;background:var(--lavender);border-radius:2px;flex-shrink:0;min-height:28px;width:3px}.reply-bar-name{color:plum;color:var(--lavender);font-size:11px;font-weight:700}.reply-bar-text{color:#888;font-size:12px;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-bar-close{color:#ccc;flex-shrink:0;font-size:15px;margin-left:auto;transition:color .15s}.reply-bar-close:hover{color:#999}.emoji-picker{grid-gap:4px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;display:grid;gap:4px;grid-template-columns:repeat(8,1fr);margin-bottom:8px;padding:10px}.emoji-btn{border-radius:8px;font-size:22px;padding:4px;transition:background .12s,transform .12s}.emoji-btn:hover{background:#ffe4e1;background:var(--soft-pink);transform:scale(1.2)}.msg-bubble{word-wrap:break-word;background:#fff;border-radius:18px;box-shadow:0 2px 6px #0000000f;max-width:70%;padding:10px 14px;position:relative}.msg-row.me .msg-bubble{background:#ffb6c1;background:var(--pink);border-bottom-right-radius:6px;color:#fff}.msg-row.you .msg-bubble{background:#fff;border-bottom-left-radius:6px}.msg-bubble.emoji-only{background:#0000!important;box-shadow:none!important;color:#4a4a4a!important;color:var(--text)!important;font-size:40px;padding:2px 6px}.msg-bubble.recalled{font-style:italic;opacity:.6}.msg-bubble .reply-ref{background:#ffffff4d;border-left:3px solid plum;border-left:3px solid var(--lavender);border-radius:6px;font-size:12px;margin-bottom:6px;opacity:.85;padding:4px 8px}.msg-row.you .msg-bubble .reply-ref{background:#ffe4e1;background:var(--soft-pink)}.msg-bubble .meta{align-items:center;display:flex;font-size:10px;gap:6px;margin-top:4px;opacity:.7}.msg-bubble .pin{font-size:12px}.msg-actions{display:none}.particles-canvas{inset:0;pointer-events:none;position:absolute;z-index:0}.chat-body>:not(.particles-canvas){position:relative;z-index:1}.drawer-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#4a4a4a33;inset:0;position:fixed;z-index:50}.drawer{background:#fff8f3;background:var(--cream);box-shadow:-8px 0 30px #0000001a;height:100dvh;max-width:90vw;overflow-y:auto;padding:calc(24px + env(safe-area-inset-top)) 20px calc(24px + env(safe-area-inset-bottom));position:fixed;right:0;top:0;width:340px;z-index:51}.drawer h3{color:#888;font-size:14px;letter-spacing:.08em;margin:20px 0 10px;text-transform:uppercase}.drawer .drawer-close{background:#fff;border-radius:50%;box-shadow:0 4px 20px #b496b426;box-shadow:var(--shadow);font-size:18px;height:34px;position:absolute;right:14px;top:14px;width:34px}.toast-stack{display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:16px;top:16px;z-index:100}.toast{align-items:center;background:#fff;border-left:4px solid #ffb6c1;border-left:4px solid var(--pink);border-radius:14px;box-shadow:0 8px 24px #0000001f;display:flex;gap:10px;max-width:300px;padding:12px 18px;pointer-events:auto}.toast .toast-title{font-size:14px;font-weight:700;margin:0}.toast .toast-body{color:#666;font-size:13px;margin:2px 0 0}.media-preview-bar{align-items:center;background:#f7f0fa;border-radius:12px;display:flex;gap:10px;margin-bottom:8px;padding:8px 10px}.media-preview-img{border-radius:8px;flex-shrink:0;height:60px;object-fit:cover;width:60px}.media-preview-file{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.media-file-icon{font-size:28px}.media-file-info{display:flex;flex-direction:column;min-width:0}.media-file-name{color:#4a4a4a;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-file-size{color:#aaa;font-size:11px}.media-preview-remove{background:none;border:none;border-radius:50%;color:#b08abd;cursor:pointer;flex-shrink:0;font-size:16px;padding:2px 6px;transition:background .15s}.media-preview-remove:hover{background:#b08abd26}.bubble-media-img{margin-bottom:4px}.bubble-media-file{align-items:center;background:#ffffff59;border-radius:10px;color:inherit;display:flex;gap:10px;margin-bottom:4px;max-width:220px;padding:8px 10px;text-decoration:none;transition:background .15s}.bubble-media-file:hover{background:#ffffff8c}.bubble-file-name{color:inherit;font-size:13px;font-weight:600;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bubble-file-size{font-size:11px;margin-top:1px;opacity:.65}.reaction-picker{background:#fff;border:1px solid #f0e6f0;border-radius:24px;box-shadow:0 4px 16px #00000024;display:flex;gap:4px;padding:5px 8px;position:absolute;top:-48px;white-space:nowrap;z-index:50}.reaction-picker.picker-left{right:0}.reaction-picker.picker-right{left:0}.reaction-option{background:none;border:none;border-radius:50%;cursor:pointer;font-size:20px;line-height:1;padding:2px 3px;transition:transform .15s,background .15s}.reaction-option:hover{background:#fff0f5;transform:scale(1.3)}.reaction-option.reacted{background:#ffb6c140}.reaction-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.reaction-pills.pills-own{justify-content:flex-end;padding-right:8px}.reaction-pills.pills-theirs{justify-content:flex-start;padding-left:40px}.reaction-pill{align-items:center;background:#fff;border:1.5px solid #f0e6f0;border-radius:12px;box-shadow:0 1px 3px #00000012;cursor:pointer;display:inline-flex;font-size:13px;gap:3px;padding:2px 7px;transition:border-color .15s,background .15s,transform .1s}.reaction-pill span{color:#888;font-size:11px;font-weight:600}.reaction-pill:hover{border-color:plum;transform:scale(1.08)}.reaction-pill.mine{background:#ffb6c12e;border-color:#ffb6c1}.reaction-pill.mine span{color:#c06080}.signature{background:linear-gradient(#0000,#fff8f3f7 40%);bottom:0;color:#aaa;font-size:11px;font-style:italic;left:0;padding:8px 12px 10px;pointer-events:none;position:fixed;right:0;text-align:center;z-index:10}.loading-dots{display:inline-flex;gap:4px}.loading-dots .d{animation:typing-dot 1.4s ease-in-out infinite;background:#ffb6c1;background:var(--pink);border-radius:50%;height:8px;width:8px}.loading-dots .d:nth-child(2){animation-delay:.15s;background:#add8e6;background:var(--blue)}.loading-dots .d:nth-child(3){animation-delay:.3s;background:plum;background:var(--lavender)}.v1-loading{align-items:flex-start;display:flex;flex-direction:column;gap:6px}.v1-loading .line{animation:v1-line 1.6s cubic-bezier(.5,0,.5,1) infinite;background:#ffb6c1;background:var(--pink);border-radius:3px;height:6px;transform-origin:left center}.v1-loading .line:first-child{animation-delay:0s;width:80px}.v1-loading .line:nth-child(2){animation-delay:.15s;background:#add8e6;background:var(--blue);width:120px}.v1-loading .line:nth-child(3){animation-delay:.3s;background:plum;background:var(--lavender);width:60px}@keyframes v1-line{0%{opacity:.3;transform:translateX(-30%) rotate(-4deg)}50%{opacity:1;transform:translateX(0) rotate(0deg)}to{opacity:.3;transform:translateX(30%) rotate(4deg)}}.home-mobile-wrap{background:#fff8f3;background:var(--cream);display:flex;flex-direction:column;min-height:100dvh;padding:0 0 calc(80px + env(safe-area-inset-bottom))}.home-mobile-header{align-items:center;background:linear-gradient(135deg,#ffb6c1,plum 50%,#add8e6);display:flex;justify-content:space-between;padding:calc(16px + env(safe-area-inset-top)) 18px 12px}.home-mobile-user{align-items:center;display:flex;gap:10px}.home-mobile-avatar{border:2px solid #fff9;border-radius:50%;height:42px;object-fit:cover;width:42px}.home-mobile-name{color:#fff;font-size:15px;font-weight:700;margin:0}.home-mobile-status{align-items:center;color:#ffffffd9;display:flex;font-size:11px;gap:4px;margin:0}.home-mobile-dot{border-radius:50%;display:inline-block;flex-shrink:0;height:7px;width:7px}.home-mobile-logout{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff40;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:7px 14px;transition:background .2s}.home-mobile-logout:hover{background:#fff6}.home-mobile-greeting{background:linear-gradient(90deg,#ffb6c1,plum,#add8e6);background:linear-gradient(90deg,var(--pink),var(--lavender),var(--blue));-webkit-background-clip:text;background-clip:text;color:#0000;font-size:22px;font-weight:800;min-height:44px;padding:20px 20px 4px}.home-mobile-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;padding:12px 18px 0}.home-mobile-tile{align-items:center;border:none;border-radius:24px;box-shadow:0 4px 16px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:22px 12px 18px;text-align:center;transition:transform .22s,box-shadow .22s}.home-mobile-tile:active,.home-mobile-tile:hover{box-shadow:0 2px 8px #00000024;transform:scale(.96)}.home-mobile-emoji{display:block;font-size:42px;line-height:1}.home-mobile-label{color:#fff;font-size:13px;font-weight:700;line-height:1.3;text-shadow:0 1px 4px #0000002e}.home-mobile-code-wrap{background:#fff;background:var(--card-bg);border-radius:18px;box-shadow:0 4px 20px #b496b426;box-shadow:var(--shadow);margin:22px 18px 0;padding:16px;text-align:center}.home-mobile-code-hint{margin:0 0 8px}.home-mobile-code-hint,.home-mobile-time{color:#888;color:var(--subtext);font-size:12px}.home-mobile-time{margin:14px 0 0;text-align:center}body.dark .home-mobile-tile{box-shadow:0 4px 16px #00000059}@media (max-width:700px){.hero h1{font-size:34px}.home-tile{padding:22px 16px}.home-tile .emoji{font-size:44px}.container{padding:16px 14px 70px}.drawer{max-width:100vw;width:100vw}.msg-bubble{max-width:85%}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(58px,1fr));max-height:220px}.login-card{padding:28px 20px 24px}.header-datetime{display:none}}@media (max-width:420px){.hero h1{font-size:26px}.login-card{border-radius:20px;padding:22px 16px 20px}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(52px,1fr));max-height:190px}.btn{font-size:14px;padding:10px 16px}.back-label{display:none}}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-30px) rotate(0deg) scaleX(1)}50%{opacity:.8;transform:translateY(50vh) rotate(1turn) scaleX(-1)}to{opacity:0;transform:translateY(110vh) rotate(2turn) scaleX(1)}}@media (min-width:701px) and (max-width:1100px){.container{max-width:680px;padding:24px 28px 70px}.home-grid{gap:16px;grid-template-columns:repeat(3,1fr)}.home-tile{padding:24px 18px}.home-tile .emoji{font-size:44px}.home-tile h3{font-size:14px}.home-tile p{font-size:12px}.hero h1{font-size:38px}.chat-layout{height:100dvh}.chat-sidebar{min-width:180px;width:220px}.drawer{width:min(360px,80vw)}.msg-bubble{max-width:72%}.login-card{max-width:500px;padding:40px 36px 36px}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(62px,1fr));max-height:260px}.header-datetime{display:block}}body.dark{--cream:#1e1a2e;--text:#ede6ff;--soft-pink:#3a2d50;--shadow:0 4px 20px #00000073;--card-bg:#2a2445;--border:#3e2f60;--subtext:#9a8abe;--search-bg:#241e3a}body.dark .card,body.dark .drawer,body.dark .drawer .drawer-close,body.dark .home-tile,body.dark .login-card,body.dark .msg-toolbar,body.dark .reaction-picker{background:#2a2445}body.dark .chat-footer,body.dark .chat-header{background:#1a162aeb;border-color:#3e2f60}body.dark .chat-body{background:#1e1a2e}body.dark .msg-bubble-v2.theirs{background:#302850;color:#ede6ff}body.dark .msg-bubble-v2.recalled{background:#2a2445!important;color:#7a6a90!important}body.dark .input{background:#241e3a;border-color:#4a3868;color:#ede6ff}body.dark .input::placeholder{color:#7a6a90}body.dark .input:focus{box-shadow:0 0 0 3px #ffb6c12e}body.dark .btn-ghost,body.dark .input:focus{border-color:#ffb6c1;border-color:var(--pink)}body.dark .btn-ghost{color:#ede6ff}body.dark .code-input{background:#241e3a;border-color:plum;border-color:var(--lavender);color:#ede6ff}body.dark .code-display{background:linear-gradient(135deg,#3a2d50,#2a3850)}body.dark .avatar-grid .avatar-option,body.dark .friend-tile{background:#2a2445}body.dark .tagline{color:#9a8abe}body.dark .toast{background:#2a2445}body.dark .toast .toast-body{color:#9a8abe}body.dark .reaction-pill{background:#2a2445;border-color:#4a3868}body.dark .reaction-pill span{color:#9a8abe}body.dark .reaction-pill.mine{background:#ffb6c11f;border-color:#ffb6c1}body.dark .media-preview-bar{background:#241e3a}body.dark .media-file-name{color:#ede6ff}body.dark .login-tabs{background:#241e3a}body.dark .login-tabs button.active{background:#2a2445}body.dark .signature{background:linear-gradient(#0000,#1e1a2ef7 40%)}body.dark .chat-input-area{background:#2a2445;border-color:#3e2f60}body.dark .input-pill{background:#1e1a2e;border-color:#0000}body.dark .input-pill:focus-within{border-color:plum}body.dark .icon-btn{background:#3a2d50}body.dark .icon-btn.active,body.dark .icon-btn:hover{background:#4a3868}body.dark .emoji-picker{background:#2a2445;box-shadow:0 8px 32px #0006}body.dark .reply-bar{background:#dda0dd14}body.dark .home-tile p,body.dark .reply-bar-text{color:#9a8abe}body.dark .home-tile:hover{border-color:#4a3868}body.dark .reply-preview{background:#ffffff14}body.dark .msg-bubble-v2.theirs .reply-preview{background:#ffb6c114}body.dark .date-pill span{background:#64508c33;color:#9a8abe}.theme-toggle{flex-shrink:0;height:32px;position:relative;width:60px}.theme-toggle input{height:0;opacity:0;position:absolute;width:0}.theme-toggle-track{align-items:center;background:linear-gradient(135deg,#87ceeb,gold);border-radius:999px;cursor:pointer;display:flex;font-size:14px;inset:0;justify-content:space-between;padding:0 6px;position:absolute;transition:background .4s}.theme-toggle input:checked+.theme-toggle-track{background:linear-gradient(135deg,#2a1a5e,#4a3a90)}.theme-toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 2px 6px #0003;height:24px;left:4px;pointer-events:none;position:absolute;top:4px;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;width:24px}.theme-toggle input:checked~.theme-toggle-thumb{box-shadow:0 2px 8px #0006;transform:translateX(28px)}.lang-btn{align-items:center;background:#ffe4e1;background:var(--soft-pink);border:2px solid #0000;border-radius:999px;color:#4a4a4a;color:var(--text);cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:6px;padding:9px 18px;transition:transform .2s,box-shadow .2s,background .2s}.lang-btn:hover{box-shadow:0 4px 12px #b496b440;transform:translateY(-2px)}.lang-btn.active{background:#ffb6c1;background:var(--pink);border-color:#0000;box-shadow:0 4px 14px #ffb6c173;color:#fff}body.dark .lang-btn{background:#3a2d50;color:#ede6ff}body.dark .lang-btn.active{background:#ffb6c1;background:var(--pink);color:#fff}.gif-icon-btn{align-items:center;background:linear-gradient(135deg,#ffb6c1,plum);border-radius:10px;box-shadow:0 2px 8px #dda0dd66;color:#fff!important;display:flex;font-size:11px!important;font-weight:800;height:36px;justify-content:center;letter-spacing:.5px;min-width:36px;padding:0 6px;transition:transform .15s,box-shadow .15s}.gif-icon-btn:hover{box-shadow:0 4px 12px #dda0dd80;transform:translateY(-1px)}.gif-icon-btn.active{background:linear-gradient(135deg,plum,#b08abd);box-shadow:0 2px 8px #b08abd80}.gif-btn-label{font-size:11px;font-weight:800;letter-spacing:.5px}.gif-picker{animation:gif-picker-in .22s cubic-bezier(.2,.8,.2,1) both;background:#fff;border:1.5px solid #f0e4f8;border-radius:18px;bottom:calc(100% + 10px);box-shadow:0 8px 40px #b496b440,0 2px 12px #00000014;display:flex;flex-direction:column;left:0;max-height:380px;overflow:hidden;position:absolute;right:0;z-index:200}@keyframes gif-picker-in{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}body.dark .gif-picker{background:#2d2042;border-color:#4a3d6a;box-shadow:0 8px 40px #0006}.gif-picker-header{align-items:center;display:flex;gap:8px;padding:10px 12px 0}.gif-tabs{display:flex;flex:1 1;gap:6px}.gif-tab{background:#f7f0fa;border-radius:20px;color:#888;font-size:13px;font-weight:700;padding:5px 14px;transition:background .15s,color .15s,transform .1s}.gif-tab:hover{background:#ede0f5;color:#b08abd}.gif-tab.active{background:linear-gradient(135deg,#ffb6c1,plum);box-shadow:0 2px 8px #dda0dd66;color:#fff}body.dark .gif-tab{background:#3a2d50;color:#bba8dd}body.dark .gif-tab.active{background:linear-gradient(135deg,#ffb6c1,plum);color:#fff}.gif-close{align-items:center;background:#f0e4f8;border-radius:50%;color:#888;display:flex;font-size:13px;height:28px;justify-content:center;transition:background .15s;width:28px}.gif-close:hover{background:#ffb6c1;color:#fff}.gif-search-wrap{align-items:center;background:#f7f0fa;border:1.5px solid #0000;border-radius:12px;display:flex;gap:6px;margin:10px 12px 6px;padding:0 10px;transition:border-color .15s}.gif-search-wrap:focus-within{border-color:plum}.gif-search-icon{flex-shrink:0;font-size:14px}.gif-search-input{background:#0000;border:none;color:#4a4a4a;color:var(--text);flex:1 1;font-size:13px;outline:none;padding:8px 0}.gif-search-clear{align-items:center;border-radius:50%;color:#aaa;display:flex;font-size:12px;height:20px;justify-content:center;transition:background .15s;width:20px}.gif-search-clear:hover{background:#ffb6c1;color:#fff}body.dark .gif-search-wrap{background:#3a2d50}body.dark .gif-search-input{color:#ede6ff}.gif-suggestions{padding:0 12px}.gif-suggestions-label{color:#b08abd;font-size:11px;font-weight:700;letter-spacing:.3px;margin-bottom:6px}.gif-grid-suggest{gap:4px!important;grid-template-columns:repeat(4,1fr)!important;max-height:80px;overflow:hidden}.gif-suggestions-divider{color:#bac;font-size:11px;font-weight:700;letter-spacing:.5px;margin:8px 0 4px;text-transform:uppercase}.gif-scroll{flex:1 1;min-height:0;overflow-y:auto;padding:6px 12px 4px}.gif-scroll::-webkit-scrollbar{width:4px}.gif-scroll::-webkit-scrollbar-thumb{background:plum;border-radius:4px}.gif-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(3,1fr)}.gif-item{aspect-ratio:1;background:#f0e8f8;border:2px solid #0000;border-radius:10px;overflow:hidden;padding:0;transition:border-color .15s,transform .15s,box-shadow .15s}.gif-item:hover{border-color:#ffb6c1;box-shadow:0 4px 12px #ffb6c166;transform:scale(1.04)}.gif-item img{display:block;height:100%;object-fit:cover;width:100%}.gif-loading{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(3,1fr)}.gif-skeleton{animation:gif-shimmer 1.4s ease-in-out infinite;aspect-ratio:1;background:linear-gradient(90deg,#f0e8f8 25%,#ede0f5 50%,#f0e8f8 75%);background-size:200% 100%;border-radius:10px}@keyframes gif-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gif-empty{color:#bac;font-size:13px;padding:24px;text-align:center}.gif-no-key{align-items:center;display:flex;flex-direction:column;gap:8px;padding:20px 16px;text-align:center}.gif-no-key span{font-size:28px}.gif-no-key p{color:#888;font-size:12px;line-height:1.5;margin:0}.gif-no-key code{background:#f0e8f8;border-radius:4px;font-size:11px;padding:1px 5px}.gif-no-key a{color:plum;font-size:12px;font-weight:700;text-decoration:underline}.gif-footer{border-top:1px solid #f0e4f8;display:flex;justify-content:flex-end;padding:6px 12px 8px}.bubble-gif{display:block;max-width:240px}.bubble-gif-img{border-radius:12px;cursor:pointer;display:block;max-height:200px;max-width:100%;transition:transform .15s}.bubble-gif-img:hover{transform:scale(1.02)}body.dark .gif-item{background:#3a2d50}body.dark .gif-skeleton{background:linear-gradient(90deg,#3a2d50 25%,#4a3d6a 50%,#3a2d50 75%);background-size:200% 100%}body.dark .gif-footer{border-color:#4a3d6a}.sticker-pack-tabs{border-bottom:1px solid #f0e4f8;display:flex;gap:4px;overflow-x:auto;padding:6px 10px 4px;scrollbar-width:none}.sticker-pack-tabs::-webkit-scrollbar{display:none}.sticker-pack-tab{background:none;border:1.5px solid #0000;border-radius:10px;cursor:pointer;flex-shrink:0;font-size:18px;line-height:1;padding:4px 8px;transition:background .15s,border-color .15s}.sticker-pack-tab:hover{background:#f7eff8}.sticker-pack-tab.active{background:#f7eff8;border-color:plum}body.dark .sticker-pack-tab:hover{background:#3a2d50}body.dark .sticker-pack-tab.active{background:#3a2d50;border-color:#c9a6e0}.sticker-emoji-grid{gap:4px!important;grid-template-columns:repeat(5,1fr)!important}.sticker-emoji-btn{align-items:center;aspect-ratio:1;background:none;border:1.5px solid #0000;border-radius:12px;cursor:pointer;display:flex;font-size:26px;justify-content:center;line-height:1;padding:6px;text-align:center;transition:background .12s,transform .12s,border-color .12s}.sticker-emoji-btn:hover{background:#f7eff8;border-color:plum;transform:scale(1.15)}.sticker-emoji-btn:active{transform:scale(.95)}body.dark .sticker-emoji-btn:hover{background:#3a2d50;border-color:#c9a6e0}.bubble-emoji-sticker{cursor:default;display:inline-block;filter:drop-shadow(0 2px 6px rgba(180,120,200,.25));font-size:48px;line-height:1.1;padding:4px;transition:transform .2s;-webkit-user-select:none;user-select:none}.bubble-emoji-sticker:hover{transform:scale(1.08) rotate(-3deg)}.sticker-store{display:flex;flex-direction:column;height:100%}.sticker-store-header{align-items:center;border-bottom:1px solid #f0e4f8;display:flex;flex-shrink:0;gap:8px;padding:10px 12px 8px}.store-back-btn{background:none;border:none;border-radius:8px;color:plum;cursor:pointer;font-size:18px;line-height:1;padding:2px 6px}.store-back-btn:hover{background:#f7eff8}.store-title{color:#6b4e8b;flex:1 1;font-size:14px;font-weight:700}.store-subtitle{color:#bbb;flex-shrink:0;font-size:11px;padding:4px 14px 6px}.store-pack-list{flex:1 1;overflow-y:auto;padding:6px 10px}.store-pack-row{align-items:center;border-bottom:1px solid #f7f0fa;border-radius:14px;cursor:pointer;display:flex;gap:12px;padding:10px 8px;transition:background .15s}.store-pack-row:hover{background:#fff0f8}.store-pack-cover{align-items:center;background:linear-gradient(135deg,#ffe4f0,#ede7ff);border-radius:12px;display:flex;flex-shrink:0;font-size:32px;height:44px;justify-content:center;width:44px}.store-pack-meta{flex:1 1;min-width:0}.store-pack-name{color:#4a4a4a;font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.store-pack-desc{color:#999;font-size:11px;margin-top:2px}.store-pack-count{color:#b08abd;font-size:11px;margin-top:2px}.store-pack-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px}.store-tag{background:#f3e8ff;border-radius:8px;color:#b08abd;font-size:10px;padding:1px 6px}.store-add-btn{align-items:center;background:#fff;border:2px solid plum;border-radius:50%;color:plum;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:32px;justify-content:center;line-height:1;transition:all .15s;width:32px}.store-add-btn:hover{background:plum;color:#fff;transform:scale(1.1)}.store-add-btn.added{background:plum;border-color:plum;color:#fff}.store-add-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.store-pack-info{border-bottom:1px solid #f0e4f8;gap:14px;padding:14px}.store-pack-cover-lg,.store-pack-info{align-items:center;display:flex;flex-shrink:0}.store-pack-cover-lg{background:linear-gradient(135deg,#ffe4f0,#ede7ff);border-radius:16px;font-size:48px;height:64px;justify-content:center;width:64px}.store-preview-grid{grid-gap:6px;display:grid;flex:1 1;gap:6px;grid-template-columns:repeat(5,1fr);overflow-y:auto;padding:10px 12px}.store-preview-item{align-items:center;aspect-ratio:1;background:#fff8ff;border:1.5px solid #f0e4f8;border-radius:10px;display:flex;font-size:28px;justify-content:center;transition:transform .12s,border-color .12s}.store-preview-item:hover{border-color:plum;transform:scale(1.12)}.store-detail-footer{border-top:1px solid #f0e4f8;flex-shrink:0;padding:10px 12px}.sticker-store-shortcut{border:1.5px dashed plum!important;color:plum;font-size:20px!important;font-weight:700}.sticker-store-shortcut:hover{background:#f7eff8;color:#b080cc}.store-loading{display:flex;flex-direction:column;gap:8px;padding:10px}.store-skeleton{animation:shimmer 1.4s infinite;background:linear-gradient(90deg,#f7f0fa 25%,#ede7ff 50%,#f7f0fa 75%);background-size:200% 100%;border-radius:14px;height:64px}body.dark .store-pack-row:hover{background:#2a1f3d}body.dark .store-pack-cover,body.dark .store-pack-cover-lg{background:linear-gradient(135deg,#3a2d50,#2a1f3d)}body.dark .store-pack-name{color:#e8d5f0}body.dark .store-preview-item{background:#2a1f3d;border-color:#3a2d50}body.dark .store-tag{background:#2a1f3d;color:#c9a6e0}body.dark .store-skeleton{background:linear-gradient(90deg,#2a1f3d 25%,#3a2d50 50%,#2a1f3d 75%);background-size:200% 100%}.avatar-modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.avatar-modal{animation:popIn .2s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:20px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:420px;overflow-y:auto;padding:20px;width:100%}.avatar-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.avatar-modal-title{color:#4a4a4a;font-size:16px;font-weight:700}.avatar-modal-close{align-items:center;background:#f0e4f8;border:none;border-radius:50%;color:#888;cursor:pointer;display:flex;font-size:13px;height:28px;justify-content:center;transition:background .15s;width:28px}.avatar-modal-close:hover{background:plum;color:#fff}.avatar-section-label{color:#888;font-size:12px;font-weight:600;margin-bottom:7px}.sticker-avatar-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr);max-height:280px;overflow-y:auto;padding:2px}.sticker-avatar-item{align-items:center;background:#0000;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:3px;padding:5px;transition:all .12s}.sticker-avatar-item:hover{background:#fff0f8}.sticker-avatar-item.selected{background:#f7eff8;border-color:plum}.sticker-avatar-item img{border-radius:8px;display:block;height:48px;width:48px}.sticker-avatar-item span{color:#999;font-size:9px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%}.avatar-type-btn{background:#fff;border:1.5px solid plum;border-radius:20px;color:#6b4e8b;cursor:pointer;font-size:13px;font-weight:600;padding:8px 14px;transition:all .15s;white-space:nowrap}.avatar-type-btn:hover{background:linear-gradient(135deg,#ffb6c1,plum);border-color:#0000;box-shadow:0 4px 12px #dda0dd66;color:#fff;transform:translateY(-1px)}body.dark .avatar-modal{background:#1e1430}body.dark .avatar-modal-title{color:#e8d5f0}body.dark .avatar-section-label{color:#9b7eb8}body.dark .sticker-avatar-item:hover{background:#2a1f3d}body.dark .avatar-type-btn,body.dark .sticker-avatar-item.selected{background:#2a1f3d;border-color:plum}body.dark .avatar-type-btn{color:#e8d5f0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
/*# sourceMappingURL=main.5b875dc7.css.map*/