.auth-screen{background:var(--surface);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.auth-card{background:var(--surface-dim);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:40px 32px;box-shadow:0 8px 24px -4px #0000000d}.auth-logo{text-align:center;margin-bottom:32px}.auth-heart{color:var(--primary);font-size:32px;display:block}.auth-brand{color:var(--primary);letter-spacing:-.5px;font-family:Noto Serif,serif;font-size:24px;font-style:italic}.auth-header{text-align:center;margin-bottom:28px}.auth-header h1{font-family:Noto Serif,serif;font-size:28px;font-weight:400}.auth-header p{color:var(--on-surface-var);margin-top:8px;font-size:15px}.auth-error{background:var(--error-container);color:var(--error);text-align:center;border-radius:12px;margin-bottom:16px;padding:12px 16px;font-size:14px}.auth-form{flex-direction:column;gap:18px;display:flex}.input-group{flex-direction:column;display:flex}.auth-switch{text-align:center;color:var(--on-surface-var);margin-top:24px;font-size:14px}.auth-switch a{color:var(--primary);margin-left:6px;font-weight:700}.auth-forgot-link{color:var(--primary);font-size:13px;font-weight:500}.home-loading{justify-content:center;align-items:center;height:100%;display:flex}.home-scroll{padding:0 20px;padding-top:calc(var(--safe-t) + 16px);padding-bottom:calc(var(--nav-h) + var(--safe-b) + 48px);height:100%;overflow-y:auto}.unpaired{justify-content:center;align-items:center;height:100%;padding:24px;display:flex;overflow-y:auto}.unpaired-inner{text-align:center;width:100%;max-width:400px}.unpaired-icon{margin-bottom:16px;font-size:64px;animation:2s ease-in-out infinite pulse;display:block}.unpaired-title{margin-bottom:8px;font-family:Noto Serif,serif;font-size:24px}.unpaired-sub{color:var(--on-surface-var);margin-bottom:24px;font-size:15px}.pairing-section{background:var(--surface-dim);border-radius:var(--radius-lg);text-align:center;padding:24px}.pairing-section h3{margin-bottom:6px;font-family:Noto Serif,serif;font-size:18px}.pairing-hint{color:var(--on-surface-var);margin-bottom:16px;font-size:13px}.code-display{cursor:pointer;background:#e8b4b84d;border-radius:12px;align-items:center;gap:12px;padding:12px 24px;display:inline-flex}.code-text{letter-spacing:4px;color:var(--primary);font-size:24px;font-weight:700}.code-copy{font-size:18px}.code-expires{color:var(--on-surface-var);margin-top:8px;font-size:11px;display:block}.pairing-divider{color:var(--outline);align-items:center;gap:16px;margin:20px 0;display:flex}.pairing-divider:before,.pairing-divider:after{content:"";background:var(--outline-var);flex:1;height:1px}.pairing-input-row{gap:8px;display:flex}.code-input{text-align:center;letter-spacing:4px;font-size:20px;font-weight:700}.greeting-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.greeting-text{font-family:Noto Serif,serif;font-size:26px;line-height:1.2}.greeting-name{color:var(--primary);font-family:Noto Serif,serif;font-size:22px;font-style:italic}.greeting-emoji{font-size:28px}.photo-card{cursor:pointer;border-radius:28px;width:100%;height:360px;margin-bottom:24px;transition:transform .2s;position:relative;overflow:hidden;box-shadow:0 12px 32px -4px #7c535726}.photo-card:active{transform:scale(.98)}[data-theme=dark] .photo-card{box-shadow:0 12px 32px -4px #7c535740}.photo-card-img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.photo-card-bg{background:linear-gradient(135deg, var(--grad-1), var(--grad-2));position:absolute;inset:0}.photo-card-placeholder{color:#fffc;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.photo-card-placeholder-icon{font-size:40px;animation:2s ease-in-out infinite pulse}.photo-card-placeholder p{margin-top:12px;font-size:15px}.photo-card-placeholder-hint{opacity:.6;margin-top:4px;font-size:12px}.photo-card-scrim{background:linear-gradient(#0000,#000000bf);height:160px;position:absolute;bottom:0;left:0;right:0}.photo-card-content{position:absolute;bottom:20px;left:20px;right:20px}.days-badge{cursor:pointer;background:#ffffff26;border-radius:16px;align-items:center;gap:8px;margin-bottom:10px;padding:8px 14px;transition:background .2s;display:inline-flex}.days-badge:hover{background:#ffffff40}.days-badge.set-date{background:#ffffff26}.days-text{color:#fff;font-size:14px;font-weight:600}.days-edit{opacity:.6;font-size:13px}.photo-card-names{color:#fff;margin-bottom:4px;font-family:Noto Serif,serif;font-size:20px;font-weight:500}.photo-card-status{color:#ffffffd9;align-items:center;gap:6px;font-size:12px;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.online{background:#4caf50}.status-dot.offline{background:#9e9e9e}.action-row{justify-content:space-evenly;display:flex}.action-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;padding:0;display:flex}.action-btn:active:not(.disabled){transition:transform .15s;transform:scale(.93)}.action-circle{background:#e8b4b840;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;font-size:24px;display:flex;position:relative}.unread-badge{color:#fff;text-align:center;background:#e53935;border-radius:10px;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:700;line-height:20px;position:absolute;top:-2px;right:-2px;box-shadow:0 2px 6px #e5393566}[data-theme=dark] .action-circle{background:#6b444826}.action-circle.disabled{opacity:.4;background:#d4c2c326}.action-label{letter-spacing:1.2px;color:var(--primary);font-size:11px;font-weight:600}.action-label.disabled{color:var(--on-surface-var);opacity:.4}.action-btn.disabled{cursor:default;pointer-events:none}.bottom-sheet{z-index:201;background:var(--surface-bright);padding:24px;padding-bottom:calc(var(--safe-b) + 24px);border-radius:24px 24px 0 0;min-height:60vh;max-height:92vh;animation:.35s slideUp;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.sheet-handle{background:var(--outline-var);border-radius:2px;width:40px;height:4px;margin:0 auto 20px}.sheet-title{text-align:center;margin-bottom:6px;font-family:Noto Serif,serif;font-size:20px}.sheet-subtitle{color:var(--on-surface-var);text-align:center;margin-bottom:24px;font-size:13px}.nudge-grid{flex-wrap:wrap;justify-content:space-evenly;gap:8px;display:flex}.nudge-option{border-radius:var(--radius);cursor:pointer;background:#e8b4b826;border:none;flex-direction:column;align-items:center;gap:8px;min-width:64px;padding:16px 12px;transition:all .2s;display:flex}.nudge-option:active{transform:scale(.9)}.nudge-emoji{font-size:32px}.nudge-label{color:var(--on-surface-var);font-size:10px;font-weight:600}.gallery-sheet{padding-bottom:calc(var(--safe-b) + 24px)}.gallery-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.gallery-header .sheet-title{text-align:left;margin-bottom:0}.gallery-count{color:var(--on-surface-var);font-size:13px}.add-photo-btn{cursor:pointer;color:var(--primary);background:#e8b4b84d;border:none;border-radius:12px;align-items:center;gap:4px;margin-left:auto;padding:6px 12px;font-size:13px;font-weight:600;display:inline-flex}.add-photo-btn:active{transform:scale(.95)}.upload-progress{background:#e8b4b833;border-radius:2px;height:4px;margin-bottom:16px;overflow:hidden}.upload-progress-bar{background:var(--primary);border-radius:2px;height:100%;animation:1.5s ease-in-out infinite uploadIndeterminate}@keyframes uploadIndeterminate{0%{width:30%;margin-left:0}50%{width:50%;margin-left:30%}to{width:30%;margin-left:70%}}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.gallery-empty{color:var(--on-surface-var);flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;padding:48px 24px;display:flex}.gallery-empty span{opacity:.3;font-size:48px}.gallery-empty p{margin-top:12px;font-size:15px}.gallery-empty p:last-child{opacity:.6;margin-top:4px;font-size:13px}.gallery-item{aspect-ratio:1;cursor:pointer;background:var(--surface-dim);border-radius:12px;overflow:hidden}.gallery-item:active{transform:scale(.95)}.gallery-item img{object-fit:cover;width:100%;height:100%}.gallery-item-placeholder{opacity:.3;justify-content:center;align-items:center;width:100%;height:100%;font-size:24px;display:flex}.nudge-overlay{z-index:100;pointer-events:none;background:#000000b3;flex-direction:column;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.nudge-pop{font-size:80px;animation:.6s cubic-bezier(.34,1.56,.64,1) nudgePop}.nudge-from{color:#fff;background:#ffffff2e;border-radius:20px;margin-top:12px;padding:8px 18px;font-size:15px;font-weight:600}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes nudgePop{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.chat-screen{background:var(--surface);flex-direction:column;height:100dvh;display:flex}.chat-bar{padding:12px 16px;padding-top:calc(var(--safe-t) + 12px);background:var(--surface);border-bottom:1px solid #0000000a;flex-shrink:0;align-items:center;gap:8px;min-height:56px;display:flex}[data-theme=dark] .chat-bar{border-bottom-color:#ffffff0a}.chat-back{cursor:pointer;color:var(--on-surface);background:0 0;border:none;align-items:center;margin:-8px;padding:8px;font-size:22px;display:flex}.chat-bar-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.chat-bar-name{font-family:Noto Serif,serif;font-size:17px;font-weight:500}.chat-bar-typing{color:var(--primary);font-size:12px;font-style:italic}.chat-bar-online{color:#4caf50;font-size:12px}.chat-bar-lastseen{color:var(--on-surface-var);font-size:12px}.online-dot{background:gray;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-right:4px;transition:background .3s}.online-dot.online{background:#4caf50}.chat-messages{overscroll-behavior:contain;flex-direction:column-reverse;flex:1;padding:8px 0;display:flex;overflow-y:auto}.chat-messages-inner{flex-direction:column;display:flex}.chat-loading{flex:1;justify-content:center;align-items:center;display:flex}.chat-loading-older{justify-content:center;align-items:center;padding:12px 0;display:flex}.chat-loading-older .spinner{width:24px;height:24px}.chat-empty{color:var(--on-surface-var);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:32px;display:flex}.chat-empty-icon{opacity:.4;font-size:64px}.chat-empty p{margin-top:12px;font-size:16px}.date-sep{text-align:center;padding:12px 0}.date-sep span{color:var(--on-surface-var);background:var(--surface-high);opacity:.7;border-radius:12px;padding:4px 12px;font-size:12px}.msg-row{position:relative}.msg-wrapper{-webkit-user-select:text;user-select:text;-webkit-touch-callout:none;flex-direction:column;padding:0 12px;display:flex;position:relative}.msg-wrapper.me{align-items:flex-end;padding-left:64px}.msg-wrapper.them{align-items:flex-start;padding-right:64px}.msg-wrapper{margin-top:1px;margin-bottom:1px}.msg-wrapper.last-in-group{margin-bottom:6px}.msg-wrapper.has-reactions{margin-bottom:18px}.msg-bubble{word-break:break-word;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;border-radius:18px;max-width:280px;font-size:15px;line-height:1.3;transition:transform .15s;animation:.3s cubic-bezier(.22,1,.36,1) both msgSlideIn;position:relative}.msg-wrapper.me .msg-bubble{background:var(--primary);color:var(--on-primary);transform-origin:100%}.msg-wrapper.them .msg-bubble{background:var(--surface-high);color:var(--on-surface);transform-origin:0}[data-theme=dark] .msg-wrapper.me .msg-bubble{background:var(--primary-container);color:var(--on-primary-container)}.msg-wrapper.me .msg-bubble.tail{border-bottom-right-radius:4px}.msg-wrapper.them .msg-bubble.tail{border-bottom-left-radius:4px}.msg-wrapper.me .msg-bubble{animation-name:msgSlideInRight}.msg-wrapper.them .msg-bubble{animation-name:msgSlideInLeft}@keyframes msgSlideInRight{0%{opacity:0;transform:translate(30%)scale(.85)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes msgSlideInLeft{0%{opacity:0;transform:translate(-30%)scale(.85)}to{opacity:1;transform:translate(0)scale(1)}}.msg-reply-snippet{border-left:3px solid;border-radius:12px;margin:4px 4px 0;padding:6px 8px}.msg-wrapper.me .msg-reply-snippet{background:#ffffff1f;border-left-color:#ffffffb3}.msg-wrapper.them .msg-reply-snippet{border-left-color:var(--primary);background:#0000000f}[data-theme=dark] .msg-wrapper.me .msg-reply-snippet{background:#ffffff14;border-left-color:#ffffff80}.reply-snippet-sender{font-size:11px;font-weight:600;display:block}.msg-wrapper.me .reply-snippet-sender{opacity:.9}.msg-wrapper.them .reply-snippet-sender{color:var(--primary)}.reply-snippet-text{opacity:.7;white-space:nowrap;text-overflow:ellipsis;max-width:200px;margin-top:2px;font-size:12px;display:block;overflow:hidden}.msg-media{border-radius:14px;margin:0;overflow:hidden}.msg-media img,.msg-media video{width:100%;max-width:260px;display:block}.msg-content{padding:10px 14px 8px}.msg-text-row{align-items:flex-end;gap:8px;display:flex}.msg-text{word-break:break-word;flex:1;min-width:0}.msg-meta{flex-shrink:0;justify-content:flex-end;align-items:center;gap:3px;display:flex}.msg-meta-standalone{justify-content:flex-end;align-items:center;gap:3px;padding:0 14px 6px;display:flex}.msg-time{opacity:.7;font-size:11px}.msg-star{color:#f5a623;font-size:11px;line-height:1}.status-icon{align-items:center;display:inline-flex}.status-icon svg{width:14px;height:14px}.status-icon.sent svg{opacity:.7}.status-icon.delivered svg{opacity:.8}.status-icon.seen svg{color:#82d4ff;opacity:1}[data-theme=light] .status-icon.seen svg{color:#29b6f6}.msg-reactions{gap:4px;display:flex;position:absolute;bottom:-14px}.msg-wrapper.me .msg-reactions{right:8px}.msg-wrapper.them .msg-reactions{left:8px}.reaction{background:var(--surface);border-radius:12px;padding:2px 6px;font-size:14px;box-shadow:0 1px 4px #0000001a}.heart-overlay{pointer-events:none;z-index:5;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.heart-pop{font-size:40px;animation:.5s cubic-bezier(.34,1.56,.64,1) forwards heartPop}@keyframes heartPop{0%{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1.15)}to{opacity:0;transform:scale(1)}}.swipe-container{touch-action:pan-y;position:relative}.swipe-reply-icon{background:var(--surface-high);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.swipe-reply-icon.active{background:var(--primary)}.swipe-reply-icon.active svg{color:var(--on-primary)}.swipe-reply-icon svg{width:20px;height:20px;color:var(--on-surface-var);transition:color .15s}.msg-wrapper.me .swipe-reply-icon{right:0}.msg-wrapper.them .swipe-reply-icon{left:0}.typing-row{align-self:flex-start;padding:4px 12px 8px}.typing-bubble{background:var(--surface-high);border-radius:18px 18px 18px 4px;gap:4px;padding:10px 16px;animation:.3s cubic-bezier(.22,1,.36,1) both typingSlideIn;display:flex}@keyframes typingSlideIn{0%{opacity:0;transform:translate(-40%)}to{opacity:1;transform:translate(0)}}.typing-dot{background:var(--on-surface-var);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite typingBounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.scroll-to-bottom{z-index:50;background:var(--primary-container);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;animation:.2s fadeIn;display:flex;position:absolute;bottom:80px;right:12px;box-shadow:0 2px 8px #00000026}[data-theme=dark] .scroll-to-bottom{background:var(--surface-high)}.scroll-to-bottom svg{width:24px;height:24px;color:var(--on-primary-container)}.upload-progress{background:#e8b4b833;height:3px;margin:0 8px;position:relative}.upload-progress-bar{background:var(--primary);border-radius:2px;width:40%;height:100%;animation:1.5s ease-in-out infinite uploadPulse}@keyframes uploadPulse{0%{width:30%;margin-left:0}50%{width:50%;margin-left:35%}to{width:30%;margin-left:70%}}.chat-input-area{padding:8px;padding-bottom:calc(var(--safe-b) + 8px);background:var(--surface);flex-shrink:0;box-shadow:0 -2px 8px #0000000d}.reply-bar{background:rgba(var(--primary-r,124),var(--primary-g,83),var(--primary-b,87),.08);border-left:3px solid var(--primary);border-radius:12px;align-items:center;gap:8px;margin-bottom:8px;padding:8px 12px;display:flex}[data-theme=dark] .reply-bar{background:#eeb9bd14}.reply-info{flex:1;min-width:0}.reply-name{color:var(--primary);font-size:12px;font-weight:600;display:block}.reply-text{color:var(--on-surface-var);white-space:nowrap;text-overflow:ellipsis;font-size:13px;display:block;overflow:hidden}.reply-close{color:var(--on-surface-var);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;font-size:16px;display:flex}.chat-input-row{align-items:flex-end;gap:4px;display:flex}.icon-btn{cursor:pointer;color:var(--on-surface-var);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:8px;transition:background .15s;display:flex}.icon-btn:active{background:#0000000d}.icon-btn svg{width:26px;height:26px}.icon-btn.camera-btn svg{width:24px;height:24px}.file-hidden{display:none}.input-wrapper{background:var(--surface-high);opacity:.5;border-radius:24px;flex:1;overflow:hidden}.input-wrapper:focus-within{opacity:1}.input-wrapper{opacity:1;transition:opacity .2s}.chat-input{width:100%;color:var(--on-surface);resize:none;background:0 0;border:none;outline:none;min-height:44px;max-height:120px;padding:10px 20px;font-family:inherit;font-size:15px;line-height:1.4;overflow-y:auto}.chat-input::placeholder{color:var(--on-surface-var);opacity:.5}.send-btn{background:var(--primary);width:42px;height:42px;color:var(--on-primary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .15s;display:flex}[data-theme=dark] .send-btn{background:var(--primary)}.send-btn svg{width:22px;height:22px}.send-btn:active:not(:disabled){transform:scale(.9)}.send-btn.bounce{animation:.3s cubic-bezier(.34,1.56,.64,1) sendBounce}@keyframes sendBounce{0%{transform:scale(1)}40%{transform:scale(1.15)}to{transform:scale(1)}}.sheet-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;animation:.2s fadeIn;position:fixed;inset:0}.bottom-sheet{z-index:201;background:var(--surface-bright);padding:20px;padding-bottom:calc(var(--safe-b) + 20px);border-radius:24px 24px 0 0;animation:.3s cubic-bezier(.22,1,.36,1) slideUp;position:fixed;bottom:0;left:0;right:0}[data-theme=dark] .bottom-sheet{background:var(--surface-container)}.sheet-handle{background:var(--outline-var);opacity:.3;border-radius:2px;width:36px;height:4px;margin:0 auto 20px}.attach-sheet .attach-options{justify-content:space-evenly;display:flex}.attach-option{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;padding:8px;transition:transform .15s;display:flex}.attach-option:active{transform:scale(.95)}.attach-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.attach-option>span:last-child{color:var(--on-surface-var);font-size:12px}.context-overlay{z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.context-scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;animation:.2s fadeIn;position:absolute;inset:0}.context-reaction-bar{z-index:102;background:var(--surface-bright);border-radius:28px;align-items:center;gap:2px;padding:6px;animation:.2s cubic-bezier(.22,1,.36,1) both contextPop;display:flex;position:absolute;box-shadow:0 4px 16px #00000026}[data-theme=dark] .context-reaction-bar{background:var(--surface-container)}.context-reaction-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:26px;transition:all .15s;display:flex}.context-reaction-btn:hover{background:#0000000d}.context-reaction-btn.selected{background:var(--primary-container);opacity:.6}.context-reaction-btn:active{transform:scale(.9)}.context-reaction-btn.plus-btn{background:var(--surface-high);color:var(--on-surface-var);font-size:20px}.context-bubble-clone{z-index:101;position:absolute}.context-action-menu{z-index:102;background:var(--surface-bright);border-radius:16px;min-width:200px;padding:4px 0;animation:.2s cubic-bezier(.22,1,.36,1) 50ms both contextPop;position:absolute;box-shadow:0 4px 16px #00000026}[data-theme=dark] .context-action-menu{background:var(--surface-container)}.menu-item{cursor:pointer;width:100%;color:var(--on-surface);background:0 0;border:none;align-items:center;gap:14px;padding:12px 16px;font-family:inherit;font-size:15px;font-weight:500;transition:background .15s;display:flex}.menu-item:hover{background:#0000000a}.menu-item:active{background:#00000014}.menu-item.destructive{color:var(--error)}.menu-item svg{flex-shrink:0;width:22px;height:22px}@keyframes contextPop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.dialog-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.dialog{background:var(--surface-bright);border-radius:24px;min-width:280px;max-width:340px;padding:24px;animation:.25s cubic-bezier(.22,1,.36,1) both contextPop;box-shadow:0 8px 32px #0003}[data-theme=dark] .dialog{background:var(--surface-container)}.dialog h3{margin-bottom:8px;font-size:18px;font-weight:600}.dialog p{color:var(--on-surface-var);margin-bottom:20px;font-size:14px;line-height:1.5}.dialog-actions{flex-direction:column;gap:4px;display:flex}.dialog-btn{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;padding:12px 16px;font-family:inherit;font-size:15px;font-weight:500;transition:background .15s}.dialog-btn:hover{background:#0000000a}.dialog-btn.cancel{color:var(--on-surface-var)}.dialog-btn.danger{color:var(--error)}.voice-recorder{align-items:center;gap:12px;padding:4px 0;display:flex}.voice-cancel-btn{cursor:pointer;color:var(--error);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:8px;display:flex}.voice-cancel-btn:active{background:#ba1a1a14}.voice-cancel-btn svg{width:24px;height:24px}.voice-recording-indicator{background:var(--surface-high);border-radius:24px;flex:1;align-items:center;gap:10px;min-height:44px;padding:10px 16px;display:flex}.voice-recording-dot{background:var(--error);border-radius:50%;width:10px;height:10px;animation:1s ease-in-out infinite recordPulse}@keyframes recordPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.voice-timer{font-variant-numeric:tabular-nums;color:var(--on-surface);flex:1;font-size:15px}.voice-waveform{align-items:center;gap:2px;height:24px;display:flex}.voice-waveform-bar{background:var(--primary);border-radius:2px;width:3px;animation:.8s ease-in-out infinite alternate waveformAnimate}.voice-waveform-bar:nth-child(2){animation-delay:.1s}.voice-waveform-bar:nth-child(3){animation-delay:.2s}.voice-waveform-bar:nth-child(4){animation-delay:.3s}.voice-waveform-bar:nth-child(5){animation-delay:.4s}.voice-waveform-bar:nth-child(6){animation-delay:.5s}.voice-waveform-bar:nth-child(7){animation-delay:.6s}@keyframes waveformAnimate{0%{height:4px}to{height:20px}}.voice-send-btn{background:var(--primary);width:42px;height:42px;color:var(--on-primary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.voice-send-btn svg{width:22px;height:22px}.voice-send-btn:active{transform:scale(.9)}.emoji-grid-sheet .emoji-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.emoji-btn{aspect-ratio:1;cursor:pointer;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;font-size:28px;transition:transform .15s;display:flex}.emoji-btn:active{transform:scale(.85)}.emoji-btn.selected{background:var(--primary-container);opacity:.6}.menu-scroll{height:100%;padding:16px 20px calc(var(--nav-h) + var(--safe-b) + 48px);padding-top:calc(var(--safe-t) + 16px);overflow-y:auto}.menu-loading{justify-content:center;align-items:center;min-height:100%;display:flex}.menu-header-block{margin-bottom:28px}.menu-title,.menu-subpage-title{color:var(--on-surface);font-family:Noto Serif,serif;font-size:28px;font-weight:400}.menu-subpage-title{text-align:center;font-size:20px}.menu-subtitle{color:var(--on-surface-var);margin-top:4px;font-size:14px}.menu-section{margin-bottom:24px}.menu-section-title{letter-spacing:.8px;color:var(--on-surface-var);margin-bottom:12px;padding-left:4px;font-size:13px;font-weight:700}.menu-card{border-radius:var(--radius);background:var(--surface-dim);max-width:448px;overflow:hidden;box-shadow:0 4px 16px #00000008}.menu-divider{background:#d4c2c366;height:1px;margin-left:56px}[data-theme=dark] .menu-divider{background:#50444473}.menu-row{text-align:left;width:100%;min-height:72px;color:inherit;background:0 0;border:none;align-items:center;gap:14px;padding:14px 16px;display:flex}.menu-button-row{cursor:pointer;transition:background .2s}.menu-button-row:active{background:var(--surface-high)}.menu-button-row.destructive .menu-row-title,.menu-button-row.destructive .menu-row-subtitle,.menu-text-danger{color:var(--error)}.menu-row-icon{width:40px;height:40px;color:var(--primary);background:#e8b4b84d;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.menu-row-icon.destructive{color:var(--error);background:#ba1a1a1a}.menu-row-icon.success{color:#2e7d32}.menu-row-copy{flex:1;min-width:0}.menu-row-title{color:var(--on-surface);font-size:15px;font-weight:500;display:block}.menu-row-subtitle{color:var(--on-surface-var);margin-top:2px;font-size:12px;display:block}.menu-row-trailing{color:var(--outline);flex-shrink:0;font-size:20px}.menu-row-trailing.text{font-size:13px;font-weight:600}.menu-row-trailing.success{color:#2e7d32}.menu-select{border:1px solid var(--outline-var);background:var(--surface-bright);color:var(--on-surface);border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600}.menu-toggle-row{cursor:pointer}.menu-switch-wrap{flex-shrink:0;width:48px;height:30px;position:relative}.menu-switch-input{opacity:0;cursor:pointer;position:absolute;inset:0}.menu-switch-slider{background:#82747466;border-radius:999px;transition:background .2s;position:absolute;inset:0}.menu-switch-slider:after{content:"";background:#fff;border-radius:50%;width:24px;height:24px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000026}.menu-switch-input:checked+.menu-switch-slider{background:var(--primary-container)}.menu-switch-input:checked+.menu-switch-slider:after{background:var(--primary);transform:translate(18px)}.menu-footer-actions,.menu-brand-footer{flex-direction:column;align-items:center;gap:8px;padding:8px 0 24px;display:flex}.menu-brand-name{color:var(--primary);font-family:Noto Serif,serif;font-size:16px;font-style:italic}.menu-version{color:var(--on-surface-var);opacity:.6;font-size:12px}.menu-text-danger{background:0 0;border:none;font-size:15px;font-weight:600}.menu-topbar{grid-template-columns:40px 1fr 40px;align-items:center;margin-bottom:20px;display:grid}.menu-back,.menu-back-spacer{width:40px;height:40px}.menu-back{background:var(--surface-bright);color:var(--on-surface);border:none;border-radius:999px;font-size:28px;line-height:1}.hero-card{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--grad-1), var(--grad-2));color:#fff;align-items:center;gap:16px;max-width:448px;margin-bottom:24px;padding:24px;display:flex;box-shadow:0 8px 24px -4px #00000014}.hero-avatar,.hero-icon{color:#fff;background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-family:Noto Serif,serif;font-size:28px;font-weight:700;display:flex}.hero-copy h2{font-family:Noto Serif,serif;font-size:20px;font-weight:400}.hero-copy p{color:#ffffffd1;margin-top:4px;font-size:14px}.edit-panel{padding:16px}.edit-panel-title{color:var(--on-surface);margin-bottom:12px;font-size:15px;font-weight:500}.menu-input{margin-bottom:12px}.menu-error{color:var(--error);margin-top:-2px;margin-bottom:12px;font-size:12px}.edit-panel-actions{justify-content:flex-start;gap:8px;display:flex}.faq-item{width:100%}.faq-trigger{text-align:left;width:100%;color:var(--on-surface);background:0 0;border:none;justify-content:space-between;align-items:center;gap:16px;padding:16px;font-size:15px;font-weight:500;display:flex}.faq-chevron{color:var(--on-surface-var);transition:transform .2s}.faq-chevron.expanded{transform:rotate(180deg)}.faq-content{color:var(--on-surface-var);padding:0 16px 16px;font-size:13px;line-height:1.5}.menu-overlay{z-index:85;color:#fff;background:#0000004d;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;font-weight:600;display:flex;position:fixed;inset:0}.menu-dialog{max-width:360px}.menu-dialog-body{flex-direction:column;gap:12px;display:flex}.pairing-status{flex-direction:column;align-items:center;gap:6px;margin-bottom:12px;display:flex}.pairing-status-heart{width:64px;height:64px;color:var(--primary);background:#e8b4b84d;border-radius:50%;justify-content:center;align-items:center;font-size:28px;display:flex}.pairing-status h3{color:var(--on-surface);font-family:Noto Serif,serif;font-size:20px;font-weight:400}.pairing-status p{color:#2e7d32;font-size:14px;font-weight:500}.pairing-message{margin-bottom:0}@media (width<=380px){.menu-scroll{padding-left:16px;padding-right:16px}.menu-title{font-size:24px}.hero-card{padding:20px}}.session-row{position:relative}.session-row.inactive{opacity:.55}.session-platform-icon{font-size:22px}.session-badge{letter-spacing:.3px;vertical-align:middle;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.session-badge.current{color:#2e7d32;background:#2e7d321f}[data-theme=dark] .session-badge.current{color:#81c784;background:#4caf5033}.session-terminate-btn{width:32px;height:32px;color:var(--error);cursor:pointer;background:#ba1a1a14;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;transition:background .2s,transform .15s;display:flex}.session-terminate-btn:hover{background:#ba1a1a29}.session-terminate-btn:active{transform:scale(.9)}.session-terminate-btn:disabled{opacity:.5;cursor:not-allowed}.session-terminate-all{border:1.5px solid var(--error);border-radius:var(--radius);color:var(--error);cursor:pointer;background:0 0;width:fit-content;margin:12px 0 0;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s;display:block}.session-terminate-all:hover{background:#ba1a1a0f}.session-terminate-all:active{background:#ba1a1a1f}.starred-screen{background:var(--bg);flex-direction:column;height:100dvh;display:flex}.starred-bar{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:12px;min-height:56px;padding:12px 16px;display:flex}.starred-back{color:var(--on-surface);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex}.starred-back:hover{background:var(--surface-high)}.starred-bar-info{flex-direction:column;display:flex}.starred-bar-title{color:var(--on-surface);font-size:17px;font-weight:600}.starred-bar-subtitle{color:var(--on-surface-variant);font-size:12px}.starred-list{flex:1;padding:8px 0;overflow-y:auto}.starred-loading{justify-content:center;padding:48px;display:flex}.starred-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:64px 32px;display:flex}.starred-empty-icon{margin-bottom:16px;font-size:48px}.starred-empty-title{color:var(--on-surface);margin:0 0 8px;font-size:18px;font-weight:600}.starred-empty-hint{color:var(--on-surface-variant);max-width:260px;margin:0;font-size:14px;line-height:1.4}.starred-item{border-bottom:1px solid var(--border);padding:12px 20px}.starred-item:last-child{border-bottom:none}.starred-item-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.starred-item-sender{color:var(--primary);font-size:13px;font-weight:600}.starred-item-time{color:var(--on-surface-variant);font-size:11px}.starred-item-body{align-items:flex-start;gap:12px;display:flex}.starred-item-content{flex:1;min-width:0}.starred-item-media{color:var(--on-surface-variant);margin-bottom:4px;font-size:13px;display:block}.starred-item-thumb{object-fit:cover;border-radius:8px;width:80px;height:80px;margin-bottom:4px}.starred-item-text{color:var(--on-surface);word-break:break-word;font-size:15px;line-height:1.4}.starred-item-text.empty{color:var(--on-surface-variant);font-style:italic}.starred-item-unstar{color:#f5a623;cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:background .15s;display:flex}.starred-item-unstar:hover{background:#f5a6231f}.shell{flex-direction:column;height:100dvh;display:flex;position:relative}.shell-content{flex:1;position:relative;overflow:hidden}.shell-page{transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1),visibility;position:absolute;inset:0;overflow:hidden auto}.shell-page--active{opacity:1;z-index:1;pointer-events:auto;visibility:visible;transform:translateY(0)scale(1)}.shell-page--hidden{opacity:0;z-index:0;pointer-events:none;visibility:hidden;transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1),visibility 0s .25s;transform:translateY(6px)scale(.985)}.glass-nav{bottom:calc(var(--safe-b) + 16px);height:var(--nav-h);-webkit-backdrop-filter:blur(32px)saturate(180%);backdrop-filter:blur(32px)saturate(180%);z-index:50;isolation:isolate;background:#ffffffa6;border:1px solid #fffc;border-radius:28px;justify-content:space-evenly;align-items:center;display:flex;position:fixed;left:48px;right:48px;transform:translateZ(0);box-shadow:0 8px 24px #00000014,inset 0 0 0 .5px #ffffff4d}[data-theme=dark] .glass-nav{background:#1e1e1e8c;border-color:#ffffff1a;box-shadow:0 8px 24px #00000059,inset 0 0 0 .5px #ffffff14}.nav-tab{color:var(--on-surface);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:20px;align-items:center;gap:0;padding:8px 20px;font-size:13px;font-weight:600;transition:background .25s,padding .25s,gap .25s;display:flex}.nav-tab:not(.active){opacity:1}.nav-tab.active{color:var(--primary);background:#7c53571f;gap:8px}[data-theme=dark] .nav-tab.active{background:#eeb9bd1f}.nav-icon-wrap{color:var(--on-surface);opacity:.5;flex-shrink:0;justify-content:center;align-items:center;transition:transform .2s,color .25s,opacity .25s;display:flex;transform:scale(1)}.nav-icon-wrap--active{color:var(--primary);opacity:1;transform:scale(1.1)}.nav-label-wrap{grid-template-columns:0fr;transition:grid-template-columns .25s;display:grid;overflow:hidden}.nav-label-wrap--active{grid-template-columns:1fr}.nav-label{white-space:nowrap;min-width:0;color:var(--primary);opacity:0;font-size:13px;font-weight:600;transition:opacity .2s;overflow:hidden}.nav-label-wrap--active .nav-label{opacity:1;transition-delay:80ms}.nav-tab:active{transition:transform .1s;transform:scale(.95)}@media (width<=380px){.glass-nav{left:24px;right:24px}}.in-app-toast{top:calc(var(--safe-t) + 16px);opacity:0;pointer-events:none;z-index:100;background:var(--surface-bright);border:1px solid var(--outline-var);cursor:pointer;border-radius:16px;align-items:center;gap:12px;width:max-content;max-width:calc(100vw - 32px);padding:12px 16px;transition:transform .4s,opacity .4s;display:flex;position:fixed;left:50%;transform:translate(-50%)translateY(-20px)scale(.95);box-shadow:0 12px 32px #0000001f,inset 0 0 0 1px #ffffff80}[data-theme=dark] .in-app-toast{background:var(--surface-dim);border-color:#ffffff14;box-shadow:0 12px 32px #0006,inset 0 0 0 1px #ffffff0d}.in-app-toast.active{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)scale(1)}.in-app-toast:active{transition:transform .1s;transform:translate(-50%)translateY(0)scale(.97)}.in-app-toast-icon{width:36px;height:36px;color:var(--primary);background:#e8b4b833;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.in-app-toast-content{flex-direction:column;min-width:0;display:flex}.in-app-toast-title{color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;font-family:Noto Serif,serif;font-size:14px;font-weight:600;overflow:hidden}.in-app-toast-body{color:var(--on-surface-var);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.splash{background:var(--surface);flex-direction:column;justify-content:center;align-items:center;gap:4px;height:100dvh;display:flex}.splash-heart{color:var(--primary);font-size:36px;animation:1.5s ease-in-out infinite pulse}.splash-brand{color:var(--primary);letter-spacing:-.5px;font-family:Noto Serif,serif;font-size:28px;font-style:italic}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#7c5357;--on-primary:#fff;--primary-container:#e8b4b8;--on-primary-container:#6b4448;--secondary-container:#fdd7a3;--error:#ba1a1a;--error-container:#ffdad6;--surface:#fbf9f8;--surface-dim:#f6f3f2;--surface-container:#efecea;--surface-bright:#fff;--surface-high:#e4e2e1;--on-surface:#1b1c1c;--on-surface-var:#605e5c;--outline:#827474;--outline-var:#d4c2c3;--grad-1:#7c5357;--grad-2:#9b6f72;--radius:16px;--radius-lg:24px;--radius-full:9999px;--safe-b:env(safe-area-inset-bottom,0px);--safe-t:env(safe-area-inset-top,0px);--nav-h:64px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--primary:#eeb9bd;--on-primary:#4a2c30;--primary-container:#6b4448;--on-primary-container:#ffd9dd;--secondary-container:#5c4522;--error:#ffb4ab;--error-container:#93000a;--surface:#1a1a1a;--surface-dim:#212121;--surface-container:#2c2c2c;--surface-bright:#2c2c2c;--surface-high:#3a3736;--on-surface:#e6e1e1;--on-surface-var:#c3c0be;--outline:#9e8c8d;--outline-var:#504444;--grad-1:#6b4448;--grad-2:#8b5e62;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}html{color:var(--on-surface);background:var(--surface);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px}body{min-height:100dvh;overflow:hidden}#root{width:100%;height:100dvh;position:relative;overflow:hidden}a{color:var(--primary);text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}.btn{border-radius:var(--radius-full);border:none;justify-content:center;align-items:center;gap:10px;padding:14px 28px;font-size:15px;font-weight:600;transition:all .25s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--grad-2), var(--grad-1));color:#fff;box-shadow:0 4px 16px #7c535733}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{color:var(--primary);border:1.5px solid var(--outline-var);background:0 0}.btn-text{color:var(--primary);background:0 0;border:none;padding:8px 16px}.btn-danger{color:var(--error);background:0 0;border:none;padding:8px 16px}.btn-full{width:100%}.btn-lg{padding:18px 36px;font-size:17px}.input-field{background:var(--surface-bright);color:var(--on-surface);border:none;border-radius:12px;outline:none;width:100%;padding:16px;font-size:15px;transition:box-shadow .25s}.input-field::placeholder{color:var(--outline-var);opacity:.6}.input-field:focus{box-shadow:0 0 0 2px var(--primary)}.input-label{color:var(--on-surface-var);margin-bottom:6px;font-size:13px;display:block}.spinner{border:3px solid var(--outline-var);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.spinner-white{border-color:#fff #ffffff4d #ffffff4d}.toast{bottom:calc(var(--nav-h) + var(--safe-b) + 48px);background:var(--on-surface);color:var(--surface);border-radius:var(--radius-full);z-index:90;padding:12px 24px;font-size:14px;font-weight:500;animation:.3s cubic-bezier(.34,1.56,.64,1) toastIn;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0003}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(16px)scale(.9)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@keyframes msgAppear{0%{opacity:0;transform:translateY(8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=380px){.btn-lg{padding:14px 24px;font-size:15px}}
