*{margin:0;padding:0;box-sizing:border-box}:root{--emoji-tile-size: 32px;--bg-deep: #070604;--bg-panel: #10100e;--bg-panel-top: #0c0c0a;--border-subtle: rgba(255, 176, 72, .12);--text-primary: #f2ede4;--text-muted: #8a8478;--accent: #e8890c;--accent-soft: rgba(232, 137, 12, .14)}body{font-family:DM Sans,system-ui,sans-serif;font-optical-sizing:auto;background:var(--bg-deep);color:var(--text-primary);height:100vh;overflow:hidden;margin:0;padding:0;touch-action:manipulation}.ambient{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 120% 80% at 15% 10%,rgba(232,137,12,.09),transparent 55%),radial-gradient(ellipse 90% 70% at 85% 75%,rgba(120,90,40,.12),transparent 50%),radial-gradient(ellipse 60% 50% at 50% 100%,rgba(232,137,12,.05),transparent 45%)}.ambient:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.35;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");mix-blend-mode:overlay}body.is-authenticated .ambient{opacity:.65}.container{position:relative;z-index:1;display:flex;height:100vh;width:100vw;max-width:100vw;overflow:hidden}body:not(.is-authenticated) .container{justify-content:center}.sidebar{position:relative;width:320px;min-height:0;background:var(--bg-panel);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column}body:not(.is-authenticated) .sidebar{width:100%;max-width:680px;margin:0 auto;border-right:none;background:transparent}body.is-authenticated .sidebar{width:320px;max-width:none;background:var(--bg-panel);border-right:1px solid var(--border-subtle)}.sidebar-header{position:relative;flex-shrink:0;padding:20px;border-bottom:1px solid var(--border-subtle);background:var(--bg-panel-top)}body:not(.is-authenticated) .sidebar-header{border-bottom:none;background:transparent;padding-bottom:12px}.app-title{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;font-family:Fraunces,Georgia,serif;font-size:26px;font-weight:600;color:var(--accent);margin-bottom:4px;line-height:1.2}.app-name{color:var(--accent)}.app-version{font-size:12px;font-weight:500;color:#555;letter-spacing:.02em}.sidebar-settings-btn{position:absolute;top:14px;right:14px;width:34px;height:34px;border:none;background:#ffffff0a;color:#9a9387;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.sidebar-settings-btn svg{width:18px;height:18px;fill:currentColor}.sidebar-settings-btn:hover,.sidebar-settings-btn:focus-visible{color:#d8d0c6;background:#ffffff14;outline:none}body:not(.is-authenticated) .sidebar-settings-btn{display:none!important}.status-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);position:relative}body:not(.is-authenticated) .status-indicator--compact{font-size:12px;color:#6d685e}.status-indicator:has(.status-dot.connected){outline:none}.status-relay-popover{position:absolute;left:0;top:calc(100% + 6px);z-index:50;min-width:220px;max-width:min(92vw,380px);max-height:240px;overflow-y:auto;padding:10px 12px;background:#1e1e1e;border:1px solid #333;border-radius:8px;font-size:12px;line-height:1.45;color:#c8c8c8;white-space:pre-line;box-shadow:0 10px 28px #0000008c;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s ease,visibility .12s ease}.status-indicator:hover .status-relay-popover:not(:empty),.status-indicator:focus-visible .status-relay-popover:not(:empty){opacity:1;visibility:visible}.status-dot{width:8px;height:8px;border-radius:50%;background:#666;animation:pulse 2s ease-in-out infinite}.status-dot.connected{background:#4ade80;box-shadow:0 0 8px #4ade80}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.connection-setup{flex-shrink:0;padding:8px 24px 40px}.landing-hero{margin-bottom:28px}.landing-eyebrow{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:#a89f8f;margin-bottom:12px;animation:landing-rise .7s ease-out both}.landing-headline{font-family:Fraunces,Georgia,serif;font-size:clamp(1.45rem,4.2vw,1.85rem);font-weight:600;line-height:1.18;color:var(--text-primary);margin-bottom:8px;animation:landing-rise .75s ease-out .06s both}.landing-lede{font-size:15px;line-height:1.6;color:#9a9488;max-width:52ch;animation:landing-rise .8s ease-out .12s both}@keyframes landing-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.btn-landing{width:100%;padding:14px 18px;font-size:15px;font-weight:600;border-radius:12px;box-shadow:0 1px #ffffff1f inset,0 12px 40px #e8890c2e;animation:landing-rise .85s ease-out .18s both}.landing-extensions{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.06);font-size:12px;line-height:1.5;color:#6d675c;animation:landing-rise .9s ease-out .22s both}.landing-extensions-label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#5c574e;margin-bottom:6px}.landing-extensions-list{color:#8a8478}.landing-extensions-list a{color:var(--accent);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(232,137,12,.35);transition:color .15s ease,border-color .15s ease}.landing-extensions-list a:hover{color:#f5b84a;border-bottom-color:#f5b84a8c}.landing-extensions-sep{margin:0 .35em;color:#5c574e;font-weight:400}.security-callout{margin-top:20px;padding:14px 16px;background:#ffffff08;border:1px solid rgba(255,176,72,.15);border-radius:12px;display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.5;color:#b5aea2;animation:landing-rise .95s ease-out .26s both}.security-callout-icon{font-size:16px;line-height:1.2;flex-shrink:0}.security-callout strong{color:var(--text-primary);font-weight:600}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:#aaa}.input-group input{width:100%;padding:10px 12px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;color:#e0e0e0;font-size:14px;transition:all .2s}.input-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.btn{width:100%;padding:12px;background:linear-gradient(180deg,#f0a020 0%,var(--accent) 100%);color:#140c02;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,filter .2s,box-shadow .2s}.btn:hover{filter:brightness(1.06);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:#2a2a2a;color:#e0e0e0;margin-top:8px}.btn-secondary:hover{background:#333}.conversations-list{flex:1 1 0;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}body:not(.is-authenticated) .conversations-list{display:none}body.is-authenticated .conversations-list{padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}.inbox-loading{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:12px;color:#8d877b;border-top:1px solid rgba(255,255,255,.05);background:#11110f}.inbox-loading[hidden]{display:none!important}.conversation-item{padding:16px 20px;border-bottom:1px solid #1a1a1a;cursor:pointer;transition:background .2s}.conversation-item-main{display:flex;align-items:flex-start;gap:12px}.avatar{width:40px;height:40px;flex-shrink:0;border-radius:999px;object-fit:cover;background:radial-gradient(circle at 30% 25%,#2c2a25,#1c1b18 65%,#121110);color:#d9c8ad;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;letter-spacing:.02em;border:1px solid rgba(232,137,12,.28);box-shadow:inset 0 1px #ffffff0f,0 3px 10px #00000059;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.avatar-image{opacity:0;transition:opacity .18s ease-out,transform .18s ease,box-shadow .18s ease,border-color .18s ease}.avatar-image.is-loaded{opacity:1}.conversation-item:hover .avatar{transform:translateY(-1px);border-color:#e8890c80;box-shadow:inset 0 1px #ffffff14,0 8px 16px #0006}.conversation-item.active .avatar{border-color:#e8890cb8;box-shadow:inset 0 1px #ffffff1f,0 0 0 1px #e8890c3d,0 8px 18px #00000073}.conversation-item-content{min-width:0;flex:1}.conversation-item-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px;gap:8px}.conversation-item:hover{background:#1a1a1a}.conversation-item.active{background:#1f1f1f;border-left:3px solid var(--accent)}.conversation-pubkey{font-size:13px;font-weight:500;color:var(--accent);flex:1}.conversation-date{font-size:11px;color:#666;margin-left:8px;white-space:nowrap}.conversation-preview{font-size:13px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-deep);min-height:0;min-width:0;overflow:hidden;height:100vh;width:100%}#chatArea[hidden]{display:none!important}#chatView{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.chat-header{padding:16px 20px;border-bottom:1px solid #1f1f1f;background:#0f0f0f;flex-shrink:0;display:flex;align-items:center;gap:12px}.chat-header-avatar{width:50px;height:50px;flex-shrink:0}.chat-header-avatar .avatar{width:100%;height:100%;border-color:#e8890c9e;box-shadow:inset 0 1px #ffffff1a,0 0 0 1px #e8890c33,0 6px 16px #0006}.chat-back-btn{display:none;flex-shrink:0;align-items:center;justify-content:center;width:40px;height:40px;padding:0;margin:0;border:none;border-radius:10px;background:#1a1a1a;color:#e0e0e0;cursor:pointer;transition:background .2s}.chat-back-btn:hover{background:#2a2a2a}.chat-back-btn svg{fill:currentColor}.chat-header-text{min-width:0;flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px;min-height:50px}.chat-pubkey{font-size:16px;font-weight:600;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:0}.chat-npub-row{display:flex;align-items:center;gap:0;min-width:0;width:fit-content;min-width:225px;border:1px solid rgba(255,255,255,.16);background:#ffffff0a;border-radius:0;padding:2px 2px 2px 10px;max-width:100%}.chat-npub{min-width:0;flex:1 1 auto;font-size:12px;color:#8d877b;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.chat-npub-copy-btn{width:26px;height:26px;border:none;background:#ffffff1a;color:#d8d0c6;border-radius:0;font-size:13px;line-height:1;padding:0;cursor:pointer;flex-shrink:0}.chat-npub-copy-btn:hover{background:#ffffff1f}.messages-container{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:8px;min-height:0}.message{max-width:70%;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.5;animation:slideIn .3s ease-out;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;position:relative}.message-body,.message-text{white-space:pre-line}.message-text-rich{white-space:pre-line;word-break:break-word}.message-text-rich .message-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px;word-break:break-all}.message.sent .message-text-rich .message-link{color:#3d2400}.message-inline-image-wrap{margin:8px 0;border-radius:10px;overflow:hidden;max-width:min(320px,100%)}.message-inline-image-link{display:block;line-height:0}.message-inline-image{display:block;width:100%;height:auto;max-height:min(360px,50vh);object-fit:contain;background:#00000026;cursor:zoom-in}.invoice-card{margin-top:8px;padding:12px;min-width:200px;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:radial-gradient(circle at 14% 0%,#f4b0493d,#f4b04900 42%),linear-gradient(180deg,#1e1e1efa,#121212f7);box-shadow:inset 0 1px #ffffff0f,0 8px 24px #00000073;color:#f6f2eb}.invoice-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.message.sent .invoice-card{border-color:#ffc36957;background:radial-gradient(circle at 14% 0%,#ffce8457,#ffce8400 44%),linear-gradient(180deg,#32220ec7,#1e1409d1);color:#fff6eb}.invoice-card-header{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#d0c6b8;opacity:1}.invoice-card-amount{margin-top:4px;font-size:17px;font-weight:700;color:#fff}.invoice-card-actions{margin-top:10px;display:flex;justify-content:flex-start}.invoice-copy-icon-btn{width:24px;height:24px;flex-shrink:0;border:1px solid rgba(255,255,255,.26);background:#ffffff14;color:inherit;border-radius:8px;font-size:14px;line-height:1;padding:0;cursor:pointer}.invoice-copy-icon-btn:hover{background:#ffffff2e}.invoice-pay-btn{border:1px solid rgba(255,195,105,.48);background:linear-gradient(180deg,#f7b75c38,#f7b75c1a);color:#fff4e4;border-radius:999px;font-size:12px;font-weight:600;padding:5px 12px;cursor:pointer}.invoice-pay-btn:hover{background:linear-gradient(180deg,#f7b75c57,#f7b75c29)}.invoice-pay-btn:disabled{opacity:.75;cursor:default}.file-message-card{margin-top:8px;padding:12px;min-width:200px;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:radial-gradient(circle at 14% 0%,#78a0ff33,#78a0ff00 42%),linear-gradient(180deg,#1e1e1efa,#121212f7);box-shadow:inset 0 1px #ffffff0f,0 8px 24px #00000073;color:#f0f4ff}.message.sent .file-message-card{border-color:#a0beff59;background:radial-gradient(circle at 14% 0%,#b4c8ff38,#b4c8ff00 44%),linear-gradient(180deg,#282c3ee6,#181a28eb);color:#eef1ff}.file-message-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.file-message-card-header{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#b8c0d8}.file-message-card-meta{margin-top:6px;font-size:14px;font-weight:600;color:#fff;word-break:break-all}.file-message-card-note{margin-top:8px;font-size:12px;line-height:1.45;color:#f0f4ffb8}.file-message-preview{margin-top:8px}.file-message-preview-loading,.file-message-preview-note{font-size:12px;line-height:1.45;color:#f0f4ffb8}.file-message-fallback-bubble{display:inline-block;max-width:100%;padding:8px 10px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#ffffff14}.file-message-fallback-bubble .message-link{font-size:13px;color:#b8d0ff;text-decoration:underline;text-underline-offset:2px;word-break:break-all}.message.sent .file-message-fallback-bubble .message-link{color:#dce6ff}.file-message-card-links{margin-top:8px}.file-message-card-links .message-link{font-size:13px;color:#b8d0ff;text-decoration:underline;text-underline-offset:2px;word-break:break-all}.message.sent .file-message-card-links .message-link{color:#dce6ff}.message.has-reactions .message-body{margin-top:4px}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.sent{align-self:flex-end;background:var(--accent);color:#140c02;border-bottom-right-radius:4px}.message.received{align-self:flex-start;background:#1a1a1a;color:#e0e0e0;border-bottom-left-radius:4px}.message.message-invoice{background:transparent;color:var(--text-primary);border-radius:0;padding:0;max-width:min(420px,85%)}.message.message-invoice .message-body{white-space:normal}.message.message-invoice .message-text{margin:0 0 8px}.message.message-invoice .message-time{margin-top:6px;padding-left:2px}.message-time{font-size:11px;opacity:.7;margin-top:4px}.message-actions{position:absolute;top:3px;right:-21px;z-index:2}.message.received .message-actions{right:auto;left:-21px}.message-react-btn{width:18px;height:18px;border-radius:0;border:none;background:transparent;color:#ece4d6f5;font-size:18px;font-weight:900;line-height:.85;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center}.message-react-btn:hover,.message-react-btn:focus-visible{color:#fff4e5;outline:none}.message-reaction-picker{position:absolute;top:calc(100% + 6px);bottom:auto;right:0;left:auto;z-index:30;display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:6px 8px;max-width:min(calc(100vw - 32px),280px);border-radius:999px;background:#0e0e0ef5;border:1px solid rgba(255,255,255,.16);box-shadow:0 8px 22px #00000080;backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%)}.message-reaction-picker[hidden]{display:none!important}.message-reaction-picker[data-expanded=true]{border-radius:14px;width:186px;max-width:186px}.message.received .message-reaction-picker{right:auto;left:0}.message-reaction-picker-quick{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:flex-end;gap:6px}.message.received .message-reaction-picker-quick{justify-content:flex-start}.message-reaction-option{width:28px;height:28px;border-radius:50%;border:none;background:#ffffff0f;color:inherit;font-size:16px;line-height:1;cursor:pointer;padding:0}.message-reaction-custom-emoji{width:20px;height:20px;object-fit:contain;pointer-events:none}.message-reaction-option:hover{background:#ffffff24}.message-reaction-option--more{font-size:18px;font-weight:700}.message-reaction-expanded{width:100%;display:grid;grid-template-columns:repeat(5,28px);justify-content:center;justify-items:center;align-content:start;gap:6px;padding-top:4px}.message-reaction-expanded[hidden]{display:none!important}.message-reactions{position:absolute;top:-12px;left:-10px;right:auto;display:inline-flex;flex-wrap:nowrap;justify-content:flex-start;gap:0;max-width:calc(100% + 16px);z-index:1;overflow:visible}.message.received .message-reactions{right:-10px;left:auto;justify-content:flex-end}.message.sent .message-reactions{flex-direction:row-reverse}.message.sent .message-reaction-pill{margin-left:-7px}.message.sent .message-reaction-pill:last-child{margin-left:0}.message-reaction-pill{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border-radius:50%;font-size:14px;font-weight:600;line-height:1;background:radial-gradient(circle at 32% 28%,#fff3,#fff0 58%),linear-gradient(180deg,#1c1c1cf5,#0e0e0ef0);border:1px solid rgba(255,255,255,.26);backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);box-shadow:inset 0 1px #ffffff2e,0 5px 14px #0000005c;color:inherit;margin-left:-7px;transform:translate(calc(var(--reaction-index, 0) * 0px))}.message-reaction-pill-emoji{width:16px;height:16px;object-fit:contain;display:block}.message-reaction-pill:first-child{margin-left:0}.message-reaction-pill.is-own-reaction{border-color:#f5a840e6;background:radial-gradient(circle at 32% 28%,#ffd69a59,#ffd69a00 60%),linear-gradient(180deg,#34210cf5,#211307f0);box-shadow:inset 0 1px #ffe0aa73,0 0 0 1px #e8890c52,0 5px 14px #0000005c}.message.received .message-reaction-pill{border-color:#ffffff3d}.message.sent .message-reaction-pill{border-color:#ffe4ba73;box-shadow:inset 0 1px #ffe5b857,0 5px 14px #00000057}.date-separator{text-align:center;margin:20px 0;padding:8px 16px;font-size:12px;color:#666;position:relative}.date-separator:before,.date-separator:after{content:"";position:absolute;top:50%;width:calc(50% - 60px);height:1px;background:#2a2a2a}.date-separator:before{left:0}.date-separator:after{right:0}.chat-input-container{padding:20px 24px;border-top:1px solid #1f1f1f;background:#0f0f0f;flex-shrink:0;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}.chat-input-shell{position:relative;max-width:100%}.chat-input-main{display:flex;align-items:stretch;gap:0;min-height:48px;border:1px solid #2a2a2a;background:#141414;transition:border-color .15s ease,box-shadow .15s ease}.chat-input-main:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft)}.emoji-toggle-btn{flex-shrink:0;width:48px;min-height:48px;padding:0;border:none;border-right:1px solid #2a2a2a;background:#121212;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.emoji-toggle-btn:hover{background:#1a1a1a}.emoji-toggle-btn[aria-expanded=true]{background:#1f1a12;box-shadow:inset 0 -2px 0 var(--accent)}.emoji-toggle-icon{font-size:1.35rem;line-height:1}.chat-input{flex:1;min-width:0;padding:12px 14px;background:transparent;border:none;border-radius:0;color:#e0e0e0;font-size:14px;resize:none;font-family:inherit;line-height:1.45}.chat-input:focus{outline:none}.send-btn{flex-shrink:0;width:48px;min-height:48px;padding:0;background:linear-gradient(180deg,#f0a020 0%,var(--accent) 100%);border:none;border-left:1px solid rgba(0,0,0,.2);border-radius:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:filter .2s,transform .2s}.send-btn:hover:not(:disabled){filter:brightness(1.08);transform:scale(1.05)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.send-btn svg{width:20px;height:20px;fill:#140c02}.emoji-panel{position:absolute;left:0;right:0;bottom:calc(100% + 10px);z-index:40;max-height:min(220px,40vh);overflow-y:auto;overflow-x:hidden;padding:8px;background:#121212;border:1px solid #2a2a2a;border-radius:0;box-shadow:0 -8px 32px #00000073;-webkit-overflow-scrolling:touch}.emoji-grid{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:2px}.emoji-cell{margin:0;padding:0;border:none;background:transparent;border-radius:0;font-size:1.2rem;line-height:1;cursor:pointer;aspect-ratio:1;display:flex;align-items:center;justify-content:center;transition:background .12s ease;min-height:28px}.emoji-cell:hover,.emoji-cell:focus-visible{background:#e8890c26;outline:none}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;padding:32px 24px;text-align:center;max-width:400px;margin:0 auto;color:var(--text-muted)}.empty-state-icon-wrap{width:72px;height:72px;border-radius:20px;background:#e8890c14;border:1px solid rgba(232,137,12,.2);display:flex;align-items:center;justify-content:center;margin-bottom:8px}.empty-state-icon{width:36px;height:36px;fill:#e8890c8c}.empty-state-title{font-family:Fraunces,Georgia,serif;font-size:1.35rem;font-weight:600;color:var(--text-primary)}.empty-state-text{font-size:14px;line-height:1.55;color:#9a9488}.empty-state-hint{font-size:12px;color:#5c574e;margin-top:4px}.sidebar-fab{position:absolute;right:16px;bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:30;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:none}body:not(.is-authenticated) .sidebar-fab,.sidebar-fab[hidden]{display:none!important}body.is-authenticated .sidebar-fab:not([hidden]){display:flex}.sidebar-fab>*{pointer-events:auto}.fab-menu{min-width:200px;padding:6px;background:#161616;border:1px solid var(--border-subtle);border-radius:0;box-shadow:0 12px 40px #0000008c}.fab-menu-item{display:block;width:100%;text-align:left;padding:12px 14px;border:none;border-radius:0;background:transparent;color:var(--text-primary);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:background .12s ease}.fab-menu-item:hover,.fab-menu-item:focus-visible{background:#e8890c1f;outline:none}.fab-plus{width:44px;height:44px;border:none;border-radius:50%;background:linear-gradient(180deg,#f0a020 0%,var(--accent) 100%);color:#140c02;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #e8890c59;transition:filter .15s ease,transform .15s ease}.fab-plus:hover{filter:brightness(1.06)}.fab-plus:active{transform:scale(.97)}.fab-plus-icon{width:22px;height:22px;fill:currentColor}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom));background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-backdrop[hidden]{display:none!important}.modal{width:100%;max-width:420px;max-height:min(90vh,560px);display:flex;flex-direction:column;background:#12100c;border:1px solid var(--border-subtle);border-radius:0;box-shadow:0 24px 80px #000000a6;outline:none}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.modal-title{font-family:Fraunces,Georgia,serif;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{width:40px;height:40px;border:none;border-radius:0;background:transparent;color:var(--text-muted);font-size:24px;line-height:1;cursor:pointer;flex-shrink:0}.modal-close:hover,.modal-close:focus-visible{color:var(--text-primary);outline:none}.modal-label{display:block;padding:14px 18px 6px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#7a7468}.modal-search{margin:0 18px;padding:12px 14px;width:calc(100% - 36px);box-sizing:border-box;border:1px solid #2a2a2a;border-radius:0;background:#0c0c0a;color:var(--text-primary);font-family:inherit;font-size:15px}.modal-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft)}.modal--new-chat .new-chat-suggestions{flex:1;min-height:120px;max-height:280px;margin:12px 18px 0;overflow-y:auto;border:1px solid #222;background:#0a0a08;-webkit-overflow-scrolling:touch}.new-chat-suggestions[hidden]{display:none!important}.new-chat-suggestion{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;border-bottom:1px solid #1a1a1a;background:transparent;color:inherit;text-align:left;cursor:pointer;font-family:inherit;transition:background .1s ease}.new-chat-suggestion:last-child{border-bottom:none}.new-chat-suggestion:hover,.new-chat-suggestion:focus-visible{background:#e8890c14;outline:none}.new-chat-suggestion-avatar{width:40px;height:40px;flex-shrink:0;border-radius:0;object-fit:cover;background:#222}.new-chat-suggestion-text{min-width:0;flex:1}.new-chat-suggestion-name{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-chat-suggestion-nip05{font-size:12px;font-weight:500;color:#8a8274}.new-chat-suggestion-npub{font-size:11px;color:#6d685e;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:ui-monospace,monospace}.new-chat-suggestion-followers{font-size:11px;color:#9a9387;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-chat-suggestion-empty{padding:20px 14px;font-size:13px;color:#6d685e;text-align:center}.modal-footnote{padding:12px 18px 16px;font-size:11px;line-height:1.45;color:#5c574e;flex-shrink:0}.modal--settings{max-width:480px;max-height:min(88vh,620px);overflow:hidden}.settings-scroll{flex:1;min-height:0;overflow-y:auto}.settings-section{padding:16px 18px 18px;display:flex;flex-direction:column;gap:10px}.settings-section+.settings-section{border-top:1px solid rgba(255,255,255,.06)}.settings-section-summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;margin:-2px 0 0}.settings-section-summary::-webkit-details-marker{display:none}.settings-section-summary:after{content:"▸";font-size:13px;color:#918a7d;transform:translateY(-1px)}.settings-section[open] .settings-section-summary:after{content:"▾"}.settings-section-body{display:flex;flex-direction:column;gap:10px;padding-top:4px}.settings-section-title{font-size:13px;font-weight:700;letter-spacing:.04em;color:#d4cec2;text-transform:uppercase}.settings-section-heading{display:inline-flex;align-items:center;gap:8px;min-width:0}.settings-info-tip{position:relative;display:none;width:16px;height:16px;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.22);color:#a89f90;font-size:11px;line-height:1;font-weight:700;cursor:help;flex-shrink:0}.settings-section[open] .settings-info-tip{display:inline-flex}.settings-info-tip:after{content:attr(data-tip);position:absolute;left:0;top:calc(100% + 8px);min-width:220px;max-width:320px;background:#0f0e0b;border:1px solid #2a261f;color:#d8d0c6;font-size:12px;line-height:1.4;padding:8px 9px;pointer-events:none;opacity:0;transform:translateY(-2px);transition:opacity .12s ease,transform .12s ease;z-index:12;text-transform:none;letter-spacing:0;font-weight:500}.settings-info-tip:hover:after,.settings-info-tip:focus-visible:after{opacity:1;transform:translateY(0)}.settings-section-note{font-size:12px;color:#868073;line-height:1.45}.settings-relay-row{display:flex;gap:8px}.settings-relay-input{margin:0;width:auto;flex:1}.settings-add-btn{border:1px solid rgba(255,255,255,.16);background:#ffffff14;color:#d8d0c6;border-radius:0;padding:0 14px;height:44px;cursor:pointer}.settings-add-btn:hover{background:#ffffff1f}.settings-relay-list{min-height:96px;max-height:280px;overflow-y:auto;border:1px solid #24211b;background:#0b0a08}.settings-emoji-discover-list{max-height:320px}.settings-emoji-discover-toolbar{display:flex;align-items:stretch;gap:8px}.settings-emoji-discover-search{flex:1;min-width:0;margin:0}.settings-emoji-discover-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:140px;padding:24px 16px;color:#cbc4b7}.settings-emoji-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:140px;padding:24px 16px;grid-column:1 / -1;color:#cbc4b7}.settings-emoji-loading-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.14);border-top-color:var(--accent);border-radius:50%;animation:settings-emoji-discover-spin .7s linear infinite}.settings-emoji-loading-msg{margin:0;max-width:280px;font-size:13px;line-height:1.45;text-align:center;color:#b6afa2}.settings-emoji-discover-spinner{width:28px;height:28px;border:2px solid rgba(255,255,255,.14);border-top-color:var(--accent);border-radius:50%;animation:settings-emoji-discover-spin .7s linear infinite}@keyframes settings-emoji-discover-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.settings-emoji-loading-spinner,.settings-emoji-discover-spinner{animation:none;border-top-color:#e8890c8c}}.settings-emoji-discover-loading-msg{margin:0;max-width:280px;font-size:13px;line-height:1.45;text-align:center;color:#b6afa2}.settings-emoji-set-item{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid #1a1814;padding:10px 12px}.settings-emoji-set-item:last-child{border-bottom:none}.settings-emoji-set-main{min-width:0}.settings-emoji-set-name{font-size:12px;color:#d8d0c6;font-weight:600}.settings-emoji-set-meta{margin-top:3px;font-size:11px;color:#867f72;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}.settings-emoji-set-preview{--emoji-card-preview-size: clamp(18px, 7vw, var(--emoji-tile-size));margin-top:4px;display:flex;align-items:center;gap:6px;min-height:var(--emoji-card-preview-size);font-size:var(--emoji-card-preview-size);line-height:1}.settings-emoji-set-preview img{width:var(--emoji-card-preview-size);height:var(--emoji-card-preview-size);object-fit:contain;display:block}.settings-emoji-set-preview span{display:inline-flex;align-items:center;justify-content:center;width:var(--emoji-card-preview-size);height:var(--emoji-card-preview-size);font-size:var(--emoji-card-preview-size);line-height:1}.settings-emoji-discover-detail{display:flex;flex-direction:column;gap:8px;min-height:0}.settings-emoji-discover-detail-bar{display:flex;align-items:center;flex-shrink:0}.settings-emoji-discover-back-btn{flex-shrink:0}.settings-emoji-discover-detail-head{flex-shrink:0;padding-bottom:4px;border-bottom:1px solid #1a1814}.settings-emoji-discover-detail-grid{max-height:min(360px,42vh);overflow-y:auto;overflow-x:hidden;display:grid;grid-template-columns:repeat(auto-fill,minmax(calc(var(--emoji-tile-size) + 14px),1fr));gap:10px;padding:10px;border:1px solid #1a1814;background:#0003;justify-items:center}.settings-relay-item{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid #1a1814;padding:10px 12px}.settings-relay-item:last-child{border-bottom:none}.settings-relay-url{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:#cbc4b7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-relay-remove{border:1px solid rgba(255,255,255,.16);background:#ffffff0d;color:#b6afa2;border-radius:0;width:28px;height:28px;cursor:pointer;flex-shrink:0}.settings-relay-remove:hover{color:#f0e7d9;background:#ffffff1f}.settings-actions{display:flex;justify-content:flex-end;margin-top:2px}.settings-save-btn{min-width:130px;border-radius:0}.settings-actions--split{justify-content:space-between;align-items:center}.settings-section--sync .settings-actions--split{justify-content:flex-start;gap:10px}.settings-emoji-actions{gap:10px;margin-top:6px}.settings-emoji-reset-btn,.settings-emoji-save-btn{min-height:40px;padding:0 14px;border-radius:0;font-size:12px;font-weight:600;letter-spacing:.01em}.settings-emoji-reset-btn{border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#d4cec2}.settings-emoji-reset-btn:hover{background:#ffffff1f;color:#f0e7d9}.settings-sync-log-btn{min-height:40px;padding:0 14px;border-radius:0;font-size:12px;font-weight:600;letter-spacing:.01em}.settings-sync-log-btn:disabled{opacity:.55;cursor:not-allowed}.settings-emoji-save-btn{min-width:148px}.settings-emoji-input{width:100%;resize:vertical;min-height:140px;border:1px solid #2a2a2a;background:#0c0c0a;color:var(--text-primary);border-radius:0;padding:10px 12px;font-family:DM Sans,system-ui,sans-serif;font-size:15px;line-height:1.55}.settings-emoji-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft)}.settings-emoji-preview{min-height:48px;border:1px solid #24211b;background:#0b0a08;padding:8px;display:grid;grid-template-columns:repeat(auto-fill,minmax(calc(var(--emoji-tile-size) + 14px),1fr));gap:10px;justify-items:center}.settings-emoji-preview-chip{position:relative;width:var(--emoji-tile-size);height:var(--emoji-tile-size)}.settings-emoji-preview-item{width:var(--emoji-tile-size);height:var(--emoji-tile-size);display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:#efe6d8;font-size:calc(var(--emoji-tile-size) * .88);line-height:1;box-sizing:border-box}.settings-emoji-preview-item img{width:var(--emoji-tile-size);height:var(--emoji-tile-size);object-fit:contain;display:block}.settings-emoji-preview-missing{font-size:calc(var(--emoji-tile-size) * .28);font-weight:700;color:#9a9285}.settings-emoji-preview-remove{position:absolute;top:-2px;right:-2px;width:18px;height:18px;padding:0;line-height:1;font-size:14px;border:1px solid rgba(255,255,255,.2);background:#15130f;color:#b6afa2;border-radius:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.settings-emoji-preview-remove:hover{color:#f0e7d9;background:#ffffff1f}.settings-emoji-preview-add{position:absolute;top:-2px;right:-2px;width:18px;height:18px;padding:0;line-height:1;font-size:15px;font-weight:700;border:1px solid rgba(255,255,255,.2);background:#15130f;color:var(--accent);border-radius:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.settings-emoji-preview-add:hover:not(:disabled){color:#ffd89a;background:#e8890c2e}.settings-emoji-preview-add:disabled{opacity:.38;cursor:default;color:#6d6860}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:260;display:flex;align-items:center;justify-content:center;padding:24px;background:#000000d9;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.image-lightbox[hidden]{display:none!important}.image-lightbox-img{max-width:min(96vw,1200px);max-height:90vh;width:auto;height:auto;object-fit:contain;border-radius:10px;box-shadow:0 24px 70px #0009}.image-lightbox-close{position:absolute;top:max(14px,env(safe-area-inset-top));right:14px;width:44px;height:44px;border:1px solid rgba(255,255,255,.25);background:#00000070;color:#fff;border-radius:999px;font-size:28px;line-height:1;cursor:pointer}.empty-state-fab-hint{color:var(--accent);font-weight:700}.info-text{font-size:12px;color:#666;margin-top:8px}.relay-info{font-size:11px;color:#666;margin-top:8px;padding:8px;background:#1a1a1a;border-radius:6px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#333}.loading{display:inline-block;width:12px;height:12px;border:2px solid #2a2a2a;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){body.is-authenticated .container{height:100dvh;max-height:100dvh}body.is-authenticated .sidebar{width:100%;max-width:100%;flex:1 1 auto;min-width:0}body.is-authenticated .container{justify-content:flex-start}.sidebar{width:100%;max-width:100%;border-right:none}.container:not(.mobile-chat-visible) .chat-area{display:none!important}.container.mobile-chat-visible .sidebar{display:none!important}.container.mobile-chat-visible .chat-area{display:flex!important;flex-direction:column;flex:1 1 auto;width:100%;min-width:0;min-height:0;height:100%;max-height:100dvh}.chat-back-btn{display:flex}.chat-header-avatar{width:44px;height:44px}.message{max-width:85%}.emoji-toggle-btn{display:none}.emoji-grid{grid-template-columns:repeat(8,minmax(0,1fr))}}
