:root{--bg-page:#f5f5f5;--bg-container:#ffffff;--bg-card:#ffffff;--bg-secondary:#f8f9fa;--bg-input:#ffffff;--bg-badge:#f0f0f0;--bg-badge-hover:#e0e0e0;--bg-reply-badge:#e7eaff;--text-primary:#333333;--text-secondary:#666666;--text-muted:#999999;--text-content:#24292e;--border-color:#e1e4e8;--border-light:#dee2e6;--accent:#667eea;--accent-hover:#5568d3;--accent-secondary:#764ba2;--accent-bg:#e7eaff;--accent-bg-hover:#d9dfff;--success:#2e7d32;--success-bg:#28a745;--success-hover:#218838;--link-preview-bg:#fafbfc;--quoted-bg:#f8f9fa;--error-bg:#fff5f5;--error-border:#fecaca;--error-accent:#dc2626;--ref-event-bg:#e8f4fd;--ref-event-border:#b8daff;--ref-event-color:#0056b3;--ref-event-hover:#d1e9fc;--ref-addr-bg:#fff3e0;--ref-addr-border:#ffcc80;--ref-addr-color:#e65100;--ref-addr-hover:#ffe0b2;--shadow:rgba(0,0,0,0.1);--shadow-accent:rgba(102,126,234,0.15)}
@media (prefers-color-scheme:dark){:root:not(.light){--bg-page:#121212;--bg-container:#1e1e1e;--bg-card:#1e1e1e;--bg-secondary:#252525;--bg-input:#2a2a2a;--bg-badge:#2a2a2a;--bg-badge-hover:#3a3a3a;--bg-reply-badge:#2d2d4a;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-muted:#71717a;--text-content:#e4e4e7;--border-color:#333333;--border-light:#333333;--accent:#818cf8;--accent-hover:#6366f1;--accent-secondary:#a78bfa;--accent-bg:#2d2d4a;--accent-bg-hover:#3d3d5a;--success:#4ade80;--success-bg:#22c55e;--success-hover:#16a34a;--link-preview-bg:#252525;--quoted-bg:#252525;--error-bg:#2d1f1f;--error-border:#7f1d1d;--error-accent:#f87171;--ref-event-bg:#1e2a3a;--ref-event-border:#3b5998;--ref-event-color:#60a5fa;--ref-event-hover:#253545;--ref-addr-bg:#2a2518;--ref-addr-border:#92400e;--ref-addr-color:#fbbf24;--ref-addr-hover:#352f1e;--shadow:rgba(0,0,0,0.3);--shadow-accent:rgba(129,140,248,0.2)}
}
html.dark{--bg-page:#121212;--bg-container:#1e1e1e;--bg-card:#1e1e1e;--bg-secondary:#252525;--bg-input:#2a2a2a;--bg-badge:#2a2a2a;--bg-badge-hover:#3a3a3a;--bg-reply-badge:#2d2d4a;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-muted:#71717a;--text-content:#e4e4e7;--border-color:#333333;--border-light:#333333;--accent:#818cf8;--accent-hover:#6366f1;--accent-secondary:#a78bfa;--accent-bg:#2d2d4a;--accent-bg-hover:#3d3d5a;--success:#4ade80;--success-bg:#22c55e;--success-hover:#16a34a;--link-preview-bg:#252525;--quoted-bg:#252525;--error-bg:#2d1f1f;--error-border:#7f1d1d;--error-accent:#f87171;--ref-event-bg:#1e2a3a;--ref-event-border:#3b5998;--ref-event-color:#60a5fa;--ref-event-hover:#253545;--ref-addr-bg:#2a2518;--ref-addr-border:#92400e;--ref-addr-color:#fbbf24;--ref-addr-hover:#352f1e;--shadow:rgba(0,0,0,0.3);--shadow-accent:rgba(129,140,248,0.2)}
html.light{--bg-page:#f5f5f5;--bg-container:#ffffff;--bg-card:#ffffff;--bg-secondary:#f8f9fa;--bg-input:#ffffff;--bg-badge:#f0f0f0;--bg-badge-hover:#e0e0e0;--bg-reply-badge:#e7eaff;--text-primary:#333333;--text-secondary:#666666;--text-muted:#999999;--text-content:#24292e;--border-color:#e1e4e8;--border-light:#dee2e6;--accent:#667eea;--accent-hover:#5568d3;--accent-secondary:#764ba2;--accent-bg:#e7eaff;--accent-bg-hover:#d9dfff;--success:#2e7d32;--success-bg:#28a745;--success-hover:#218838;--link-preview-bg:#fafbfc;--quoted-bg:#f8f9fa;--error-bg:#fff5f5;--error-border:#fecaca;--error-accent:#dc2626;--ref-event-bg:#e8f4fd;--ref-event-border:#b8daff;--ref-event-color:#0056b3;--ref-event-hover:#d1e9fc;--ref-addr-bg:#fff3e0;--ref-addr-border:#ffcc80;--ref-addr-color:#e65100;--ref-addr-hover:#ffe0b2;--shadow:rgba(0,0,0,0.1);--shadow-accent:rgba(102,126,234,0.15)}
*{box-sizing:border-box;margin:0;padding:0}
img{max-width:100%;height:auto}
.scroll-top{position:fixed;bottom:20px;right:max(20px,calc((100vw - 840px) / 2 - 60px));width:44px;height:44px;background:var(--accent);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:20px;font-weight:bold;box-shadow:0 2px 8px var(--shadow);opacity:0.8;transition:opacity 0.2s,background 0.2s;z-index:1000}
.scroll-top:hover{opacity:1;background:var(--accent-hover)}
@media (max-width:600px){.scroll-top{width:40px;height:40px;font-size:18px;bottom:16px;right:16px}
}
@keyframes flashFadeOut{0%,60%{opacity:1;max-height:100px;padding:12px;margin-bottom:16px}
100%{opacity:0;max-height:0;padding:0;margin-bottom:0;overflow:hidden}
}
.flash-message{background:var(--success-bg);color:white;border:1px solid var(--success);border-radius:4px;animation:flashFadeOut 3s ease-out forwards}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:var(--text-primary);background:var(--bg-page);padding:20px}
.container{max-width:800px;margin:0 auto;background:var(--bg-container);border-radius:8px;box-shadow:0 2px 8px var(--shadow)}
.sticky-section{position:sticky;top:0;z-index:100;background:var(--bg-container)}
nav{padding:12px 15px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.form-error{padding:12px 16px;background:var(--error-bg);color:var(--error-accent);border-bottom:1px solid var(--error-border);font-size:14px}
.form-error:empty{display:none}
.post-form-container{background:var(--bg-secondary);border-bottom:1px solid var(--border-light)}
.post-form{padding:12px 16px}
.post-form textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;font-family:inherit;height:36px;min-height:36px;resize:none;margin-bottom:0;background:var(--bg-input);color:var(--text-primary);box-sizing:border-box;transition:height 0.15s ease,min-height 0.15s ease;overflow:hidden}
.post-form-container:focus-within .post-form textarea{height:80px;min-height:80px;resize:vertical;margin-bottom:10px;overflow:auto}
.post-form button[type="submit"]{display:none;height:36px;padding:0 16px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);color:white;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer}
.post-form-container:focus-within button[type="submit"]{display:inline-flex;align-items:center;justify-content:center}
.post-form .btn-primary.post-gif{display:none !important}
.post-form-container:focus-within .btn-primary.post-gif{display:inline-flex !important}
.post-form-container #gif-panel-post{display:none}
.post-form-container:focus-within #gif-panel-post{display:block}
.post-form .cw-dropdown{display:none}
.post-form-container:focus-within .cw-dropdown{display:inline-flex}
.nav-tab{padding:8px 16px;background:var(--bg-badge);color:var(--text-secondary);text-decoration:none;border-radius:4px;font-size:14px;transition:background 0.2s,color 0.2s}
.nav-tab:hover{background:var(--bg-badge-hover)}
.nav-tab.active{background:var(--accent);color:white}
.nav-tab.active:hover{background:var(--accent-hover)}
.feed-dropdown{position:relative;display:inline-block}
.feed-dropdown > summary{cursor:pointer;list-style:none}
.feed-dropdown > summary::-webkit-details-marker{display:none}
.feed-dropdown > summary::after{content:" ▾";font-size:10px;opacity:0.7}
.feed-dropdown[open] > summary::after{content:" ▴"}
.feed-dropdown-menu{position:absolute;left:0;top:100%;margin-top:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:4px;box-shadow:0 10px 40px rgba(0,0,0,0.3),0 2px 8px rgba(0,0,0,0.15);z-index:100;min-width:120px;display:flex;flex-direction:column;gap:2px}
.feed-dropdown-item{display:block;padding:8px 12px;color:var(--text-secondary);text-decoration:none;border-radius:4px;font-size:13px;white-space:nowrap}
.feed-dropdown-item:hover{background:var(--bg-badge-hover);color:var(--text-primary)}
.feed-dropdown-item.active{background:var(--accent);color:white}
#feed-tabs{display:contents}
#page-content > [h-oob]{display:none !important}
.kind-filter{display:flex;gap:16px;padding:6px 20px;font-size:12px;border-bottom:1px solid var(--border-color)}
.kind-filter a{color:var(--text-muted);text-decoration:none;padding:2px 0;border-bottom:2px solid transparent}
.kind-filter a:hover{color:var(--text-primary)}
.kind-filter a.active{color:var(--text-primary);border-bottom-color:var(--accent)}
.kind-filter-dropdown{position:relative}
.kind-filter-dropdown > summary{color:var(--text-muted);cursor:pointer;list-style:none;padding:2px 0;border-bottom:2px solid transparent}
.kind-filter-dropdown > summary::-webkit-details-marker{display:none}
.kind-filter-dropdown > summary::after{content:" ▾";font-size:10px}
.kind-filter-dropdown > summary:hover{color:var(--text-primary)}
.kind-filter-dropdown.active > summary{color:var(--text-primary);border-bottom-color:var(--accent)}
.kind-filter-dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,0.15);min-width:140px;z-index:100;display:flex;flex-direction:column;padding:4px 0}
.kind-filter-dropdown-menu a{padding:8px 12px;border-bottom:none}
.kind-filter-dropdown-menu a:hover{background:var(--bg-hover)}
.kind-filter-dropdown-menu a.active{background:var(--bg-hover);border-bottom:none}
main{padding:12px 20px 20px 20px;min-height:400px}
.note{background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:12px}
.note:last-child{border-bottom:none}
.note-content{font-size:15px;line-height:1.6;margin:8px 0;color:var(--text-content);white-space:pre-wrap;word-wrap:break-word}
.note-content img{max-width:100%;border-radius:8px;margin-top:8px;display:block}
.image-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}
.image-gallery img{width:100%;max-height:400px;object-fit:cover;border-radius:8px}
.image-gallery:has(> img:only-child){grid-template-columns:1fr}
.image-gallery > img:only-child{max-height:500px;object-fit:contain}
.image-gallery > img:last-child:nth-child(odd){grid-column:span 2;max-height:500px;object-fit:contain}
.note-content a{color:var(--accent);text-decoration:none}
.note-content a:hover{text-decoration:underline}
.link-preview{display:flex;border:1px solid var(--border-color);border-radius:8px;margin:12px 0;overflow:hidden;text-decoration:none;color:inherit;background:var(--link-preview-bg);transition:border-color 0.2s,box-shadow 0.2s}
.link-preview:hover{border-color:var(--accent);box-shadow:0 2px 8px var(--shadow-accent);text-decoration:none}
.link-preview-image{width:120px;min-width:120px;max-height:120px;object-fit:contain;margin:0;border-radius:0;background:var(--bg-secondary)}
.link-preview-content{padding:10px 14px;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.link-preview-site{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:2px}
.link-preview-title{font-size:14px;font-weight:600;color:var(--text-content);line-height:1.3;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.link-preview-desc{font-size:12px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.wavlake-player{display:flex;flex-direction:column;gap:8px;border:1px solid var(--border-color);border-radius:8px;padding:12px;margin:12px 0;background:var(--link-preview-bg)}
.wavlake-info{display:flex;align-items:center;gap:10px}
.wavlake-icon{font-size:20px;flex-shrink:0}
.wavlake-meta{display:flex;flex-direction:column;gap:2px;overflow:hidden}
.wavlake-title{font-size:14px;font-weight:600;color:var(--text-content);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wavlake-title:hover{text-decoration:underline}
.wavlake-creator{font-size:12px;color:var(--text-muted)}
.wavlake-audio{width:100%;height:32px}
.nostr-ref{display:inline-block;padding:4px 10px;margin:4px 0;border-radius:4px;font-size:13px;text-decoration:none;transition:background 0.2s}
.nostr-ref-event{background:var(--ref-event-bg);border:1px solid var(--ref-event-border);color:var(--ref-event-color)}
.nostr-ref-event:hover{background:var(--ref-event-hover)}
.quoted-note .nostr-ref-event{display:none}
.nostr-ref-profile{display:inline;padding:0;margin:0;border:none;border-radius:0;background:none;color:var(--success);font-weight:500}
.nostr-ref-profile:hover{background:none;text-decoration:underline}
.nostr-ref-addr{background:var(--ref-addr-bg);border:1px solid var(--ref-addr-border);color:var(--ref-addr-color)}
.nostr-ref-addr:hover{background:var(--ref-addr-hover)}
.note-author{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.muted-user .note-author{margin-bottom:0}
.muted-user .author-info{flex:1}
.mute-action{display:flex}
.btn-unmute{padding:8px 16px !important;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%) !important;color:white !important;border:none !important;border-radius:4px !important;font-size:14px !important;font-weight:600;cursor:pointer}
.btn-unmute:hover{opacity:0.9}
.author-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}
.author-info{display:flex;flex-direction:row;align-items:baseline;gap:6px;flex-wrap:wrap}
.author-name{font-weight:600;font-size:15px;color:var(--text-content)}
.author-nip05{font-size:12px;color:var(--accent)}
.author-nip05::before{content:"·";margin-right:6px;color:var(--text-secondary)}
.nip05-verified{color:var(--accent);text-decoration:none;cursor:help}
.nip05-verified:hover{text-decoration:underline}
.author-time{font-size:12px;color:var(--text-secondary)}
.author-time::before{content:"·";margin-right:6px;color:var(--text-secondary)}
.audio-note{margin:12px 0}
.audio-track{display:flex;flex-direction:column;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:8px}
.audio-artwork{flex-shrink:0;width:120px;height:120px;border-radius:6px;overflow:hidden;background:var(--bg-tertiary)}
.audio-artwork-img{width:100%;height:100%;object-fit:cover}
.audio-info{display:flex;flex-direction:column;gap:4px;min-width:0}
.audio-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}
.audio-title a{color:inherit;text-decoration:none}
.audio-title a:hover{color:var(--accent)}
.audio-creator{font-size:14px;color:var(--text-muted)}
.audio-player{width:100%;height:36px;border-radius:4px}
.audio-placeholder{display:flex;align-items:center;justify-content:center;padding:16px;background:var(--bg-tertiary);border-radius:4px;color:var(--text-muted);font-size:14px}
@media (min-width:480px){.audio-track{flex-direction:row;flex-wrap:wrap;align-items:flex-start}
.audio-info{flex:1}
.audio-player{width:100%;flex-basis:100%}
}
.badge-card{display:flex;align-items:center;gap:16px;background:var(--bg-secondary);border-radius:8px;padding:16px;margin:12px 0}
.badge-image{width:64px;height:64px;border-radius:8px;object-fit:contain}
.badge-placeholder{width:64px;height:64px;background:var(--bg-badge);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:32px}
.badge-info{flex:1;min-width:0}
.badge-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px 0}
.badge-description{font-size:14px;color:var(--text-secondary);line-height:1.4}
.badge-award-card{background:var(--bg-secondary);border-radius:8px;padding:16px;margin:12px 0}
.badge-award-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.badge-award-icon{font-size:20px}
.badge-award-text{font-size:14px;font-weight:600;color:var(--text-primary)}
.badge-awardees{font-size:13px;color:var(--text-secondary)}
.bookmarks{padding:16px 20px}
.bookmarks-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.bookmarks-icon{font-size:18px}
.bookmarks-title{font-size:16px;font-weight:600;color:var(--text-primary)}
.bookmarks-count{font-size:13px;color:var(--text-muted);margin-left:auto}
.bookmarks-section{margin-bottom:16px}
.bookmarks-section:last-child{margin-bottom:0}
.bookmarks-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;margin-bottom:8px;letter-spacing:0.5px}
.bookmarks-list{display:flex;flex-direction:column;gap:6px}
.bookmark-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;font-size:13px;color:var(--text-content);text-decoration:none;transition:background 0.15s ease}
.bookmark-item:hover{background:var(--bg-badge-hover)}
.bookmark-item-icon{font-size:14px;opacity:0.7}
.bookmark-item-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bookmark-hashtag{color:var(--accent)}
.calendar-event{padding:0;overflow:hidden}
.calendar-event-header{display:flex;gap:16px;padding:16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}
.calendar-date-badge{flex-shrink:0;width:56px;height:56px;background:var(--accent);color:white;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.calendar-month{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;opacity:0.9}
.calendar-day{font-size:22px;font-weight:700;line-height:1}
.calendar-icon{font-size:28px}
.calendar-event-info{flex:1;min-width:0}
.calendar-event-title{font-size:17px;font-weight:600;color:var(--text-primary);margin:0 0 4px 0;line-height:1.3}
.calendar-event-time{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}
.calendar-all-day{background:var(--accent-bg);color:var(--accent);padding:2px 8px;border-radius:4px;font-weight:500}
.calendar-time{font-weight:500}
.calendar-end-date{color:var(--text-muted)}
.calendar-event-image{width:100%;max-height:300px;overflow:hidden}
.calendar-event-image img{width:100%;height:auto;object-fit:contain}
.calendar-event-body{padding:16px}
.calendar-event-summary{font-size:14px;color:var(--text-secondary);margin:0 0 12px 0;line-height:1.5}
.calendar-event-description{font-size:14px;color:var(--text-content);margin-bottom:12px;line-height:1.6}
.calendar-event-location{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary);margin-bottom:12px}
.calendar-location-icon{font-size:14px}
.calendar-event-participants{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;font-size:13px}
.calendar-participants-label{color:var(--text-muted)}
.calendar-participant{display:flex;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none}
.calendar-participant:hover{color:var(--accent)}
.calendar-participant-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}
.calendar-event-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.calendar-hashtag{color:var(--accent);font-size:13px;text-decoration:none}
.calendar-hashtag:hover{text-decoration:underline}
.calendar-event-meta{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border-color)}
.calendar-event-author{display:flex;align-items:center;gap:8px}
.calendar-author-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}
.calendar-author-name{color:var(--text-secondary);text-decoration:none;font-size:13px}
.calendar-author-name:hover{color:var(--accent)}
.calendar-posted-time{font-size:12px;color:var(--text-muted)}
.classified-listing{padding:0}
.classified-sold{opacity:0.7}
.classified-images{display:flex;flex-direction:column;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color)}
.classified-image{width:100%;max-height:400px;object-fit:contain;border-radius:8px}
.classified-body{padding:16px 20px}
.classified-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px}
.classified-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}
.classified-price{font-size:18px;font-weight:700;color:var(--accent);white-space:nowrap}
.classified-status{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:4px;margin-bottom:8px}
.classified-status-active{background:var(--success-bg,rgba(34,197,94,0.1));color:var(--success,#22c55e)}
.classified-status-sold{background:var(--warning-bg,rgba(234,179,8,0.1));color:var(--warning,#eab308)}
.classified-summary{font-size:14px;color:var(--text-muted);margin-bottom:12px;line-height:1.5}
.classified-description{font-size:14px;color:var(--text-content);margin-bottom:12px;line-height:1.6}
.classified-location{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);margin-bottom:12px}
.classified-location-icon{font-size:14px}
.comment-context{display:flex;align-items:center;gap:6px;margin-top:12px;padding:10px 12px;background:var(--bg-secondary);border-radius:6px;font-size:13px;color:var(--text-muted)}
.comment-context-icon{font-size:14px}
.comment-context-link{color:var(--accent);text-decoration:none}
.comment-context-link:hover{text-decoration:underline}
.community-card{background:var(--bg-secondary);border-radius:8px;overflow:hidden;margin:12px 0}
.community-image{width:100%;height:150px;object-fit:cover}
.community-info{padding:16px}
.community-name{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 8px 0}
.community-description{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:12px}
.community-meta{font-size:13px;color:var(--text-muted)}
.community-note .note-author{padding:0 16px 16px}
.unknown-kind-info{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:8px;margin:12px 0}
.unknown-kind-badge{background:var(--bg-tertiary);color:var(--text-secondary);padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;font-family:monospace}
.unknown-kind-message{color:var(--text-secondary);font-size:14px}
.handler-links{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.handler-link{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);text-decoration:none;font-size:14px;transition:background 0.15s,border-color 0.15s}
.handler-link:hover{background:var(--bg-tertiary);border-color:var(--accent)}
.handler-link.handler-recommended{border-color:var(--accent);background:var(--accent-bg,rgba(var(--accent-rgb,99,102,241),0.1))}
.handler-recommended-badge{font-size:11px;color:var(--accent);margin-left:4px;opacity:0.9}
.handler-icon{width:20px;height:20px;border-radius:4px;object-fit:contain}
.unknown-kind-content{margin:12px 0}
.unknown-kind-content summary{cursor:pointer;color:var(--text-secondary);font-size:13px;padding:8px 0}
.unknown-kind-content summary:hover{color:var(--text-primary)}
.raw-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:12px;margin-top:8px;font-size:12px;font-family:monospace;white-space:pre-wrap;word-break:break-all;overflow-x:auto;max-height:300px;color:var(--text-secondary)}
.file-card{display:flex;gap:16px;align-items:flex-start;margin:12px 0}
.file-preview-link{display:block;flex-shrink:0}
.file-preview-image{max-width:200px;max-height:200px;border-radius:8px;object-fit:contain}
.file-video-container,.file-audio-container{flex-shrink:0;width:200px}
.file-video{width:100%;border-radius:8px}
.file-audio{width:100%}
.file-generic{width:80px;height:80px;background:var(--bg-secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.file-icon{font-size:32px}
.file-info{flex:1;min-width:0}
.file-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.file-description{font-size:14px;color:var(--text-secondary);margin-bottom:8px;line-height:1.4}
.file-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--text-muted);margin-bottom:8px}
.file-download-link{display:inline-block;padding:6px 12px;background:var(--accent);color:white;border-radius:4px;text-decoration:none;font-size:13px}
.file-download-link:hover{background:var(--accent-hover)}
.handler-card .handler-info{display:flex;align-items:flex-start;gap:16px;margin:12px 0}
.handler-app-icon{width:64px;height:64px;border-radius:12px;object-fit:contain;background:var(--bg-secondary);flex-shrink:0}
.handler-details{flex:1;min-width:0}
.handler-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px 0}
.handler-about{font-size:14px;color:var(--text-secondary);line-height:1.4;margin:0}
.handler-kinds{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:12px 0}
.handler-kinds-label{font-size:13px;color:var(--text-secondary);font-weight:500}
.handler-kind-badge{background:var(--bg-tertiary);color:var(--text-secondary);padding:4px 8px;border-radius:4px;font-size:12px;font-family:monospace}
.handler-website-link{display:inline-block;color:var(--accent);font-size:14px;text-decoration:none;margin:8px 0}
.handler-website-link:hover{text-decoration:underline}
.highlight{padding:16px 20px}
.highlight-blockquote{border-left:4px solid var(--accent);padding-left:16px;margin:0 0 12px 0;font-style:italic;font-size:15px;line-height:1.6;color:var(--text-content)}
.highlight-context{margin-top:8px;padding:12px;background:var(--bg-secondary);border-radius:6px;font-size:13px;color:var(--text-secondary);font-style:normal;line-height:1.5}
.highlight-comment{margin-top:12px;font-size:14px;color:var(--text-primary);font-style:normal}
.highlight-source{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);font-size:13px}
.highlight-source-link{color:var(--accent);text-decoration:none;word-break:break-all}
.highlight-source-link:hover{text-decoration:underline}
.label-card{background:var(--bg-secondary);border-radius:8px;padding:12px 16px;margin:8px 0}
.label-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.label-icon{font-size:16px}
.label-title{font-size:14px;font-weight:600;color:var(--text-primary)}
.label-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.label-tag{display:inline-flex;align-items:center;padding:4px 10px;background:var(--accent-bg);border-radius:14px;font-size:13px}
.label-namespace{color:var(--text-muted);margin-right:2px}
.label-value{color:var(--accent);font-weight:500}
.label-targets{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;font-size:13px}
.label-targets-title{color:var(--text-muted)}
.label-target-link{color:var(--accent);text-decoration:none;padding:2px 8px;background:var(--bg-primary);border-radius:4px}
.label-target-link:hover{text-decoration:underline}
.label-description{font-size:14px;color:var(--text-secondary);line-height:1.5;padding-top:10px;border-top:1px solid var(--border-color)}
.live-chat-message{padding:8px 0}
.live-chat-content{font-size:14px;color:var(--text-content);line-height:1.5}
.live-chat-context{display:flex;align-items:center;gap:6px;margin-top:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;font-size:13px;color:var(--text-muted)}
.live-chat-icon{font-size:14px}
.live-chat-event-link{color:var(--accent);text-decoration:none;font-weight:500}
.live-chat-event-link:hover{text-decoration:underline}
.live-chat-reply-indicator{display:flex;align-items:center;gap:4px;margin-top:6px;font-size:12px;color:var(--text-muted)}
.live-chat-reply-icon{font-size:12px}
.live-chat-reply-link{color:var(--accent);text-decoration:none}
.live-chat-reply-link:hover{text-decoration:underline}
.live-event{padding:0;overflow:hidden}
.live-event-thumbnail{position:relative;width:100%;aspect-ratio:16 / 9;background:var(--bg-secondary);overflow:hidden}
.live-event-thumbnail img{width:100%;height:auto;object-fit:contain}
.live-event-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-badge) 0%,var(--bg-secondary) 100%)}
.live-event-thumbnail-placeholder span{font-size:48px;opacity:0.3}
.live-event-overlay{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:8px}
.live-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;background:rgba(0,0,0,0.7);color:white;backdrop-filter:blur(4px)}
.live-badge.live{background:#dc2626;animation:pulse 2s ease-in-out infinite}
.live-badge.live::before{content:"";width:8px;height:8px;background:white;border-radius:50%}
@keyframes pulse{0%,100%{opacity:1}
50%{opacity:0.8}
}
.live-badge.planned{background:#2563eb}
.live-badge.ended{background:rgba(0,0,0,0.6)}
.live-viewers{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;background:rgba(0,0,0,0.7);color:white;backdrop-filter:blur(4px)}
.live-event-body{padding:16px}
.live-event-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px 0;line-height:1.3}
.live-event-summary{font-size:14px;color:var(--text-secondary);margin:0 0 12px 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.live-event-host{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:14px}
.host-label{color:var(--text-muted)}
.host-link{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:var(--text-primary)}
.host-link:hover{color:var(--accent)}
.host-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}
.host-name{font-weight:500}
.live-event-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--text-muted);margin-bottom:12px}
.live-event-meta-item{display:flex;align-items:center;gap:4px}
.live-event-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.live-hashtag{font-size:12px;color:var(--accent);background:var(--bg-secondary);padding:4px 10px;border-radius:14px;text-decoration:none}
.live-hashtag:hover{background:var(--bg-badge-hover)}
.live-event-actions{padding:12px 16px;display:flex;gap:10px;background:var(--bg-secondary)}
.live-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;transition:all 0.15s ease;flex:1}
.stream-btn{background:#dc2626;color:white}
.stream-btn:hover{background:#b91c1c}
.recording-btn{background:var(--bg-badge);color:var(--text-primary);border:1px solid var(--border-color)}
.recording-btn:hover{background:var(--bg-badge-hover)}
.live-event .note-meta{padding:12px 16px;border-top:1px solid var(--border-color)}
.article-preview{margin:12px 0}
.article-preview-image{width:100%;max-height:400px;object-fit:cover;border-radius:8px;margin-bottom:12px}
.article-preview-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1.3}
.article-preview-summary{font-size:14px;color:var(--text-muted);margin-bottom:12px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.long-form-article{margin:12px 0}
.article-header-image{width:100%;max-height:500px;object-fit:cover;border-radius:8px;margin-bottom:16px}
.article-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:12px;line-height:1.3}
.article-summary{font-size:16px;color:var(--text-muted);margin-bottom:12px;font-style:italic;line-height:1.5}
.article-published{font-size:13px;color:var(--text-muted);margin-bottom:16px}
.article-content{font-size:15px;line-height:1.8;color:var(--text-primary)}
.article-content h1,.article-content h2,.article-content h3{margin-top:24px;margin-bottom:12px;color:var(--text-primary)}
.article-content h1{font-size:22px}
.article-content h2{font-size:20px}
.article-content h3{font-size:18px}
.article-content p{margin-bottom:16px}
.article-content ul,.article-content ol{margin-bottom:16px;padding-left:24px}
.article-content li{margin-bottom:8px}
.article-content blockquote{border-left:4px solid var(--border-color);padding-left:16px;margin:16px 0;color:var(--text-muted);font-style:italic}
.article-content code{background:var(--bg-secondary);padding:2px 6px;border-radius:4px;font-family:monospace;font-size:14px}
.article-content pre{background:var(--bg-secondary);padding:16px;border-radius:8px;overflow-x:auto;margin-bottom:16px}
.article-content pre code{background:none;padding:0}
.article-content a{color:var(--accent)}
.article-content img{max-width:100%;border-radius:8px;margin:16px 0}
.stall-card{background:var(--bg-secondary);border-radius:8px;padding:16px;margin:12px 0}
.stall-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.stall-icon{font-size:24px}
.stall-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}
.stall-description{font-size:14px;color:var(--text-secondary);margin-bottom:12px;line-height:1.5}
.stall-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text-muted)}
.stall-shipping summary{cursor:pointer;color:var(--accent)}
.stall-shipping-list{margin:8px 0 0 0;padding-left:20px;font-size:12px}
.product-card{display:flex;gap:16px;margin:12px 0}
.product-images{flex-shrink:0;width:150px}
.product-image-main{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:1}
.product-image-thumbs{display:flex;gap:4px;margin-top:4px}
.product-image-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover}
.product-info{flex:1;min-width:0}
.product-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px 0}
.product-price{font-size:20px;font-weight:700;color:var(--accent);margin-bottom:8px}
.product-price-currency{font-size:14px;font-weight:400;color:var(--text-secondary);margin-left:4px}
.product-description{font-size:14px;color:var(--text-secondary);margin-bottom:8px;line-height:1.5}
.product-quantity{font-size:13px;color:var(--success);margin-bottom:8px}
.product-specs{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:13px;margin-bottom:8px}
.product-specs dt{color:var(--text-muted)}
.product-specs dd{color:var(--text-secondary);margin:0}
.product-categories{display:flex;gap:8px;flex-wrap:wrap}
.product-category{font-size:12px;color:var(--accent);text-decoration:none}
.product-category:hover{text-decoration:underline}
.picture-note{margin:12px 0}
.picture-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}
.picture-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.picture-image{width:100%;max-height:400px;object-fit:cover;border-radius:8px;display:block}
.picture-gallery.single-image{display:block}
.picture-single{width:100%;min-width:100%;max-width:none;height:auto;max-height:none}
.picture-gallery:not(.single-image) > img:last-child:nth-child(odd){grid-column:span 2;max-height:500px;object-fit:contain}
.picture-caption{font-size:14px;color:var(--text-muted);margin-top:12px;line-height:1.5}
.recommendation-compact{padding:16px;border-bottom:1px solid var(--border-color)}
.recommendation-line{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:14px;line-height:1.4}
.recommendation-author{display:inline-flex;align-items:center;gap:6px;color:var(--text-primary);text-decoration:none}
.recommendation-author:hover .recommendation-author-name{text-decoration:underline}
.recommendation-author-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}
.recommendation-author-name{font-weight:600}
.recommendation-verb{color:var(--text-secondary)}
.recommendation-handler-link{display:inline-flex;align-items:center;gap:4px;color:var(--accent);text-decoration:none;font-weight:600}
.recommendation-handler-link:hover{text-decoration:underline}
.recommendation-handler-icon{width:18px;height:18px;border-radius:4px;object-fit:contain}
.recommendation-handler-unknown{color:var(--text-muted);font-style:italic}
.recommendation-for-label{color:var(--text-secondary)}
.recommendation-kind-badge{background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 6px;border-radius:4px;font-size:12px;font-family:monospace}
.recommendation-time{color:var(--text-muted)}
.recommendation-reason{margin:8px 0 0 26px;font-size:14px;color:var(--text-secondary);line-height:1.5}
.report-card{background:var(--error-bg);border:1px solid var(--error-border);border-radius:8px;padding:12px 16px;margin:12px 0}
.report-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.report-icon{font-size:16px}
.report-type{font-size:14px;font-weight:600;color:var(--error-accent)}
.report-reason{font-size:13px;color:var(--text-secondary);margin:0}
.repo-card{background:var(--bg-secondary);border-radius:8px;padding:16px;margin:12px 0}
.repo-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.repo-icon{font-size:24px}
.repo-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}
.repo-description{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0 0 12px 0}
.repo-links{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.repo-link-group{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px}
.repo-link-label{color:var(--text-muted);min-width:60px}
.repo-link{color:var(--accent);text-decoration:none;word-break:break-all}
.repo-link:hover{text-decoration:underline}
.repo-clone-url{font-family:monospace;font-size:12px;background:var(--bg-primary);padding:4px 8px;border-radius:4px;color:var(--text-secondary);word-break:break-all}
.repo-maintainers{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;font-size:13px}
.repo-maintainers-label{color:var(--text-muted)}
.repo-maintainer{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none}
.repo-maintainer:hover{color:var(--accent)}
.repo-maintainer-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}
.repo-maintainer-name{font-weight:500}
.repo-tags{display:flex;flex-wrap:wrap;gap:8px}
.repo-hashtag{color:var(--accent);font-size:13px;text-decoration:none}
.repo-hashtag:hover{text-decoration:underline}
.repost-indicator{font-size:12px;color:var(--text-muted);margin-bottom:8px}
.reposted-note{border:1px solid var(--border-color);border-radius:8px;padding:12px;background:var(--bg-secondary)}
.reposted-note .note-author{margin-bottom:8px}
.reposted-note .author-avatar{width:32px;height:32px}
.repost-empty{font-style:italic;color:var(--text-muted)}
.view-note-link{display:block;margin-top:8px;color:var(--accent);text-decoration:none;font-size:0.9em}
.view-note-link:hover{text-decoration:underline}
.quoted-note{background:var(--quoted-bg);border:1px solid var(--border-color);border-left:3px solid var(--accent);border-radius:4px;padding:12px;margin:12px 0;font-size:14px}
.quoted-note img{max-width:100%;height:auto}
.quoted-note .note-author{margin-bottom:8px}
.quoted-note .author-avatar{width:32px;height:32px}
.quoted-note-fallback{font-style:italic;color:var(--text-muted)}
.quoted-note .quoted-author{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px}
.quoted-note .quoted-author img{width:24px;height:24px;border-radius:50%;margin:0}
.quoted-note .quoted-author-name{font-weight:600;color:var(--text-content)}
.quoted-note .quoted-article-title{font-weight:600;font-size:15px;margin-bottom:6px;color:var(--text-content)}
.quoted-note .quoted-article-summary{color:var(--text-secondary);font-size:14px;line-height:1.4}
.rsvp-card{background:var(--bg-secondary);border-radius:8px;padding:12px 16px;margin:8px 0;border-left:4px solid var(--text-muted)}
.rsvp-card.rsvp-accepted{border-left-color:var(--success,#22c55e)}
.rsvp-card.rsvp-declined{border-left-color:var(--error,#ef4444)}
.rsvp-card.rsvp-tentative{border-left-color:var(--warning,#eab308)}
.rsvp-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.rsvp-icon{font-size:18px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-primary)}
.rsvp-accepted .rsvp-icon{color:var(--success,#22c55e)}
.rsvp-declined .rsvp-icon{color:var(--error,#ef4444)}
.rsvp-tentative .rsvp-icon{color:var(--warning,#eab308)}
.rsvp-status-text{font-size:15px;font-weight:600;color:var(--text-primary)}
.rsvp-event{display:flex;align-items:center;gap:6px;font-size:14px;margin-bottom:8px}
.rsvp-event-icon{font-size:14px}
.rsvp-event-link{color:var(--accent);text-decoration:none}
.rsvp-event-link:hover{text-decoration:underline}
.rsvp-freebusy{font-size:12px;color:var(--text-muted);margin-bottom:8px}
.rsvp-note{font-size:14px;color:var(--text-secondary);line-height:1.5;padding-top:8px;border-top:1px solid var(--border-color)}
.shortvideo-note{padding:0}
.shortvideo-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px 0;padding:0 20px;line-height:1.4}
.shortvideo-player-container{position:relative;background:#000;max-width:100%}
.shortvideo-player{width:100%;max-height:80vh;display:block}
.shortvideo-thumbnail{width:100%;max-height:80vh;object-fit:contain;display:block}
.shortvideo-placeholder{display:flex;align-items:center;justify-content:center;min-height:200px;background:var(--bg-secondary);color:var(--text-muted);gap:8px}
.shortvideo-caption{font-size:14px;color:var(--text-content);padding:12px 20px 0;line-height:1.5}
.note-video{max-width:100%;border-radius:8px;margin:8px 0;display:block}
.note-audio{width:100%;margin:8px 0;display:block}
.youtube-embed{width:100%;aspect-ratio:16/9;border:none;border-radius:8px;margin:8px 0;display:block}
.status-card{background:var(--bg-secondary);border-radius:8px;padding:12px 16px;margin:8px 0}
.status-content{display:flex;align-items:center;gap:8px}
.status-icon{font-size:18px}
.status-text{font-size:15px;color:var(--text-content)}
.status-link{display:block;margin-top:8px;font-size:13px;color:var(--accent);text-decoration:none;word-break:break-all}
.status-link:hover{text-decoration:underline}
.video-note{margin:12px 0}
.video-title{font-size:17px;font-weight:600;color:var(--text-primary);margin:0 0 12px 0;line-height:1.3}
.video-player-container{width:100%;background:#000;border-radius:8px;overflow:hidden}
.video-player{width:100%;display:block}
.video-thumbnail{width:100%;display:block}
.video-placeholder{width:100%;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-muted);font-size:16px}
.video-duration{margin-top:8px;font-size:13px;color:var(--text-muted)}
.video-description{margin-top:12px;font-size:14px;color:var(--text-content);line-height:1.6}
.video-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.video-hashtag{color:var(--accent);font-size:13px;text-decoration:none}
.video-hashtag:hover{text-decoration:underline}
.zap-content{display:flex;align-items:flex-start;gap:12px}
.zap-icon{font-size:20px;line-height:1}
.zap-info{flex:1}
.zap-header{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:15px}
.zap-sender,.zap-recipient{font-weight:600;color:var(--accent);text-decoration:none}
.zap-sender:hover,.zap-recipient:hover{text-decoration:underline}
.zap-action{color:var(--text-muted)}
.zap-amount{font-weight:600;color:var(--text-primary)}
.zap-comment{margin-top:8px;font-size:14px;color:var(--text-primary)}
.zap-target{margin-top:8px;font-size:13px}
.note-footer{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px;margin-bottom:8px;align-items:center;font-size:13px}
.note-footer.action-error{animation:action-error-flash 0.3s ease-out}
.note-footer.action-error::after{content:"⚠️";font-size:12px;opacity:0.7;animation:action-error-fade 3s ease-out forwards}
@keyframes action-error-flash{0%{background:var(--error-bg,rgba(220,53,69,0.15))}
100%{background:transparent}
}
@keyframes action-error-fade{0%,80%{opacity:0.7}
100%{opacity:0}
}
.note-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.action-pill-form{display:contents}
.action-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-badge);border-radius:16px;font-size:13px;color:var(--text-secondary);text-decoration:none;border:none;cursor:pointer;font:inherit;transition:background 0.15s,color 0.15s}
.action-pill:hover{background:var(--bg-badge-hover);color:var(--accent)}
.action-pill.completed{background:var(--accent-bg);color:var(--accent)}
.action-pill.completed:hover{background:var(--accent-bg-hover)}
.action-pill.disabled{cursor:default;opacity:0.6}
.action-pill.disabled:hover{background:var(--bg-badge);color:var(--text-secondary)}
button.action-pill,button[type="submit"].action-pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-badge);color:var(--text-secondary);padding:4px 10px;margin:0;font-size:13px}
button.action-pill:hover,button[type="submit"].action-pill:hover{background:var(--bg-badge-hover);color:var(--accent)}
button.action-pill.completed,button[type="submit"].action-pill.completed{background:var(--accent-bg);color:var(--accent)}
button.action-pill.completed:hover,button[type="submit"].action-pill.completed:hover{background:var(--accent-bg-hover)}
.pill-count{font-weight:500}
.pill-spinner.h-spinner{display:none;margin-left:4px;margin-right:0}
.action-pill:disabled .pill-spinner.h-spinner{display:inline-block}
.action-pill:disabled .pill-count{display:none}
.action-group{position:relative;display:inline-flex}
.action-group > summary{list-style:none}
.action-group > summary::-webkit-details-marker{display:none}
.action-dropdown{position:absolute;left:0;top:100%;margin-top:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:4px;box-shadow:0 10px 40px rgba(0,0,0,0.4),0 2px 8px rgba(0,0,0,0.2);z-index:100;white-space:nowrap;font-size:13px;min-width:100px}
.dropdown-form{display:contents}
.dropdown-action{display:flex;align-items:center;gap:6px;width:100%;padding:8px 10px;border-radius:6px;color:var(--text-secondary);text-decoration:none;background:none;border:none;font:inherit;cursor:pointer;text-align:left;transition:background 0.15s}
.dropdown-action:hover{background:var(--bg-hover,var(--bg-secondary));color:var(--text-primary)}
button.dropdown-action,button[type="submit"].dropdown-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;margin:0;padding:8px 10px;color:var(--text-secondary);font-size:inherit;line-height:inherit}
button.dropdown-action:hover,button[type="submit"].dropdown-action:hover{background:var(--bg-hover,var(--bg-secondary));color:var(--text-primary)}
.note-stats{display:flex;gap:8px;margin-left:auto}
.stat-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-badge);border-radius:16px;font-size:13px;color:var(--text-secondary)}
.note-meta{display:flex;gap:16px;font-size:12px;color:var(--text-secondary);margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);flex-wrap:wrap}
.pubkey{font-family:monospace;font-size:11px;color:var(--accent)}
.link{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--bg-card);border:1px solid var(--accent);color:var(--accent);text-decoration:none;border-radius:4px;font-size:13px;transition:all 0.2s}
.link:hover{background:var(--accent);color:white}
.pagination{display:flex;justify-content:center;gap:12px;margin:12px 0 0 0;padding:12px 0;border-top:1px solid var(--border-color)}
#new-notes-indicator{position:fixed;top:110px;left:50%;transform:translateX(-50%);z-index:1000;pointer-events:none}
@media (max-width:600px){#new-notes-indicator{top:90px}
}
.new-notes-btn,.new-replies-btn{display:inline-block;padding:8px 16px;background:var(--accent);color:white;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;pointer-events:auto;box-shadow:0 2px 12px rgba(0,0,0,0.3)}
.new-notes-btn:hover,.new-replies-btn:hover{background:var(--accent-secondary);color:white}
.action-form{background:var(--bg-secondary);padding:12px;border-radius:4px;border:1px solid var(--border-light)}
.action-form h4{font-size:14px;margin-bottom:8px;color:var(--text-secondary)}
.action-field{margin:8px 0}
.action-field label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}
.action-field input,.action-field textarea{width:100%;padding:8px;border:1px solid var(--border-light);border-radius:4px;font-size:14px;font-family:inherit;background:var(--bg-input);color:var(--text-primary)}
.action-field textarea{min-height:80px;resize:vertical}
button[type="submit"]{padding:8px 16px;background:var(--success-bg);color:white;border:none;border-radius:4px;cursor:pointer;font-size:14px;margin-top:8px}
button[type="submit"]:hover{background:var(--success-hover)}
.ml-auto{margin-left:auto}
.flex-center{display:flex;align-items:center}
.icon-mobile-only{display:none}
.icon-desktop-only{display:inline}
@media (max-width:600px){.icon-mobile-only{display:inline}
.icon-desktop-only{display:none}
}
.text-link{color:var(--accent);text-decoration:none}
.text-link:hover{text-decoration:underline}
button.text-link{background:none !important;border:none !important;font:inherit;cursor:pointer;padding:0 !important;margin:0 !important;border-radius:0 !important;color:var(--accent) !important}
button.text-link:hover{text-decoration:underline}
.text-muted{color:var(--text-secondary);text-decoration:none}
.text-xs{font-size:12px}
.inline-form{display:inline;margin:0}
.ghost-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-family:inherit;padding:0}
.settings-dropdown{position:relative;margin-left:4px}
.settings-toggle{cursor:pointer;list-style:none;font-size:16px}
.settings-toggle-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;vertical-align:middle;pointer-events:none}
.settings-menu{position:absolute;right:0;top:100%;margin-top:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:6px;box-shadow:0 10px 40px rgba(0,0,0,0.4),0 2px 8px rgba(0,0,0,0.2);z-index:100;white-space:nowrap;font-size:13px;min-width:160px}
.settings-item{padding:8px 10px;border-radius:6px;transition:background 0.15s}
.settings-item:hover{background:var(--bg-hover,var(--bg-secondary))}
.settings-item a,.settings-item button{color:var(--text-secondary)}
.settings-item:hover a,.settings-item:hover button{color:var(--text-primary)}
.settings-item button[type="submit"]{background:none;padding:0;margin-top:0;border-radius:0}
.settings-divider{margin:6px 0;border-top:1px solid var(--border-light)}
.nav-icon{position:relative;text-decoration:none;font-size:16px;color:var(--text-secondary);padding:4px}
.nav-icon:hover{color:var(--text-primary)}
.nav-icon.active{color:var(--accent)}
.notification-badge{position:absolute;top:2px;right:0;width:8px;height:8px;background:var(--accent);border-radius:50%}
.notification-badge-hidden{display:none}
.error-box{background:var(--error-bg);color:var(--error-accent);border:1px solid var(--error-border);padding:12px;border-radius:4px;margin-bottom:16px}
.alert{padding:12px;border-radius:4px;margin-bottom:16px}
.alert-error{background:var(--error-bg);color:var(--error-accent);border:1px solid var(--error-border)}
.alert-success{background:var(--success-bg);color:white;border:1px solid var(--success)}
.reply-form-minimal{margin:16px 0}
.reply-form-minimal .reply-form{padding:0}
.reply-form-minimal .reply-form textarea{height:60px;min-height:60px;resize:vertical;overflow:auto;border-radius:8px}
.reply-form-minimal .reply-form textarea:focus{outline:none;border-color:var(--accent)}
.reply-actions-minimal{display:flex;align-items:center;gap:8px;margin-top:8px}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 16px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);color:white;border:none;border-radius:6px;font-family:inherit;font-size:14px;font-weight:600;line-height:1;box-sizing:border-box;cursor:pointer;text-decoration:none}
.btn-primary:hover{opacity:0.9}
button.btn-primary{height:36px;padding:0 16px;margin-top:0;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%)}
.reply-form-minimal .reply-actions-minimal .btn-primary{display:inline-flex}
.reply-avatar-link{margin-left:auto}
.reply-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}
.reply-form-minimal #gif-panel-reply:not(:empty),.reply-form-minimal #gif-panel-quote:not(:empty){margin-top:8px}
.reply-form{padding:16px}
.reply-form textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;font-family:inherit;height:36px;min-height:36px;resize:none;margin-bottom:0;background:var(--bg-input);color:var(--text-primary);box-sizing:border-box;transition:height 0.15s ease,min-height 0.15s ease;overflow:hidden}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:0;left:0;transform:translateY(-100%);background:var(--accent);color:white;padding:8px 16px;z-index:1000;text-decoration:none;border-radius:0 0 4px 0}
.skip-link:focus{transform:translateY(0)}
.file-link{display:inline-flex;align-items:baseline;gap:6px;padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;text-decoration:none;color:var(--text-primary);font-size:14px;white-space:nowrap;transition:background-color 0.15s ease,border-color 0.15s ease}
.file-link:hover{background:var(--bg-tertiary,var(--bg-secondary));border-color:var(--accent)}
.file-icon{font-size:1.2em}
.file-name{font-family:monospace;font-weight:600}
.file-ext{font-family:monospace;font-weight:600}
.file-size{font-weight:600}
.content-warning{margin:8px 0}
.content-warning-summary{position:relative;display:flex;align-items:center;justify-content:center;min-height:70px;cursor:pointer;list-style:none}
.content-warning-summary::-webkit-details-marker{display:none}
.content-warning-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;padding:12px 0}
.cw-placeholder-line{height:12px;border-radius:4px;margin-bottom:8px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-badge) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.cw-placeholder-line:nth-child(1){width:100%}
.cw-placeholder-line:nth-child(2){width:80%}
.cw-placeholder-line:nth-child(3){width:60%}
.content-warning-label{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg-container);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);font-size:13px;font-weight:500;box-shadow:0 2px 12px rgba(0,0,0,0.15);transition:all 0.15s ease;white-space:nowrap}
.content-warning-label::before{content:"⚠️ Content Warning:"}
.content-warning-label::after{content:"Show";font-size:11px;padding:2px 8px;background:var(--bg-secondary);border-radius:10px;opacity:0.8}
.content-warning-summary:hover .content-warning-label{border-color:var(--accent);box-shadow:0 4px 16px rgba(0,0,0,0.2)}
.content-warning-summary:hover .content-warning-label::after{background:var(--accent);color:#fff;opacity:1}
.content-warning[open]{display:flex;flex-direction:column}
.content-warning[open] .content-warning-summary{order:2;margin-top:12px;min-height:auto;justify-content:flex-start}
.content-warning[open] .content-warning-body{order:1}
.content-warning[open] .content-warning-placeholder{display:none}
.content-warning[open] .content-warning-label{padding:6px 14px;background:var(--bg-secondary);font-size:12px;box-shadow:none;border:none}
.content-warning[open] .content-warning-label::after{content:"Hide"}
.cw-dropdown{position:relative}
.cw-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:16px;list-style:none;transition:background-color 0.15s ease}
.cw-toggle::-webkit-details-marker{display:none}
.cw-toggle:hover{background:var(--bg-tertiary,var(--bg-secondary))}
.cw-dropdown[open] .cw-toggle{background:var(--warning-bg,rgba(255,193,7,0.15));border-color:var(--warning-border,rgba(255,193,7,0.3))}
.cw-options{position:absolute;bottom:100%;left:0;margin-bottom:4px;padding:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,0.15);display:flex;flex-direction:column;gap:6px;min-width:180px;z-index:100}
.cw-select{padding:6px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px}
.cw-custom{padding:6px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:13px}
.cw-custom::placeholder{color:var(--text-secondary);font-size:12px}
.mentions-dropdown{position:relative}
.mentions-panel{position:absolute;left:0;right:0;top:100%;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.15);max-height:200px;overflow-y:auto;z-index:100}
.mention-item{display:flex;align-items:center;gap:8px;padding:8px 12px;text-decoration:none;color:var(--text-primary);cursor:pointer;transition:background 0.15s}
.mention-item:hover,.mention-item:focus{background:var(--bg-badge);outline:none}
.mention-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.mention-name{font-weight:500;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mention-npub{font-size:12px;color:var(--text-secondary);flex-shrink:0}
.login-prompt-box{background:var(--bg-secondary);padding:12px;border-radius:8px;border:1px solid var(--border-light);margin:16px 0;text-align:center;color:var(--text-secondary);font-size:14px}
.relay-item{padding:1px 0;font-family:monospace;font-size:11px;color:var(--text-secondary)}
.dvm-header{display:flex;align-items:flex-start;gap:12px;padding:16px;margin:-12px -20px 12px -20px;background:var(--bg-primary);border-bottom:1px solid var(--border-light)}
.dvm-header-image{width:48px;height:48px;border-radius:8px;object-fit:contain;flex-shrink:0}
.dvm-header-info{flex:1;min-width:0}
.dvm-header-name{font-weight:600;font-size:16px;color:var(--text-primary)}
.dvm-header-description{font-size:14px;color:var(--text-secondary);margin-top:4px;line-height:1.4}
.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}
.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:0.5}
.empty-state-hint{font-size:14px;margin-top:8px}
.empty-state .btn{margin-top:16px;display:inline-block}
.search-form{margin:-12px -20px 0 -20px;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light)}
.search-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;font-family:inherit;background:var(--bg-input);color:var(--text-primary);box-sizing:border-box}
.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--shadow-accent)}
.results-header{font-size:14px;color:var(--text-secondary);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}
.profile-header{display:flex;gap:20px;padding:20px;align-items:flex-start}
.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--border-color)}
.profile-info{flex:1}
.profile-name-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.profile-name{font-size:20px;font-weight:700;color:var(--text-primary)}
.profile-nip05{font-size:14px;color:var(--accent)}
.profile-nip05 .nip05-verified{color:inherit;text-decoration:none}
.profile-nip05 .nip05-verified:hover{text-decoration:underline}
.profile-npub{font-family:monospace;font-size:12px;color:var(--text-muted);margin-bottom:8px}
.profile-about{font-size:14px;color:var(--text-secondary);line-height:1.5;white-space:pre-wrap}
.profile-actions{display:flex;gap:8px;margin-top:12px}
.follow-btn{padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s}
.follow-btn.follow{background:var(--accent);color:white;border:none}
.follow-btn.follow:hover{background:var(--accent-hover)}
.follow-btn.unfollow{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}
.follow-btn.unfollow:hover{border-color:var(--error-accent);color:var(--error-accent)}
.mute-btn{padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s}
.mute-btn.mute{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}
.mute-btn.mute:hover{border-color:var(--warning-accent,#f39c12);color:var(--warning-accent,#f39c12)}
.mute-btn.unmute{background:var(--warning-accent,#f39c12);color:white;border:none}
.mute-btn.unmute:hover{opacity:0.9}
.edit-profile-btn{padding:6px 12px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:13px;cursor:pointer;text-decoration:none}
.edit-profile-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}
.edit-form-section{padding:20px}
.edit-form-group{margin-bottom:20px}
.edit-form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:6px}
.edit-form-group input,.edit-form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-family:inherit;background:var(--bg-input);color:var(--text-primary)}
.edit-form-group textarea{min-height:100px;resize:vertical}
.edit-form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}
.edit-form-buttons{display:flex;gap:12px;padding:20px;border-top:1px solid var(--border-color)}
.edit-form-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}
.edit-form-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}
.edit-form-btn-secondary:hover{border-color:var(--text-secondary)}
.edit-form-error{background:var(--error-bg);color:var(--error-accent);border:1px solid var(--error-border);padding:12px;border-radius:6px;margin:20px;font-size:14px}
.edit-form-preview{margin-top:8px}
.edit-form-preview-img{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}
.notification-list{list-style:none;margin:0;padding:0}
.notification-item{display:block;padding:16px 20px;border-bottom:1px solid var(--border-color);transition:background 0.15s}
.notification-item:hover{background:var(--bg-secondary)}
.notification-item:last-child{border-bottom:none}
.notification-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.notification-icon{font-size:18px}
.notification-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.notification-author{font-weight:600;color:var(--text-primary);text-decoration:none}
.notification-author:hover{color:var(--accent)}
.notification-action{color:var(--text-secondary);font-size:14px}
.notification-time{font-size:12px;color:var(--text-muted)}
.notification-time::before{content:"·";margin-right:6px}
.notification-content{margin-bottom:8px}
.notification-target-content{font-size:14px;color:var(--text-secondary);line-height:1.4;padding:8px 12px;margin-bottom:8px;border-left:3px solid var(--border-color);background:var(--bg-secondary);border-radius:0 4px 4px 0;max-height:200px;overflow:hidden}
.notification-target-content img{max-height:150px;width:auto;object-fit:contain;border-radius:4px;margin-top:8px}
.notification-link{color:var(--accent);text-decoration:none;font-size:13px;display:inline-block}
.notification-link:hover{text-decoration:underline}
.login-section{padding:40px 20px;max-width:400px;margin:0 auto}
.login-form{background:var(--bg-card);padding:24px;border-radius:8px;border:1px solid var(--border-color)}
.login-form h2{font-size:16px;margin-bottom:16px;color:var(--text-primary)}
.qr-container{display:flex;flex-direction:column;align-items:center;padding:20px}
.qr-code{padding:16px;background:white;border-radius:8px;margin-bottom:16px}
.qr-help{font-size:14px;color:var(--text-secondary);text-align:center;max-width:300px}
.url-box{background:var(--bg-secondary);padding:12px;border-radius:6px;font-family:monospace;font-size:12px;word-break:break-all;margin-top:16px}
.url-details{margin-top:8px}
.url-details summary{cursor:pointer;color:var(--text-muted);font-size:13px}
.server-info{background:var(--bg-secondary);padding:16px;border-radius:8px;margin:20px}
.server-info-note{font-size:13px;color:var(--text-muted);margin-top:8px}
.form-group{margin-bottom:16px}
.form-help{font-size:12px;color:var(--text-muted);margin-top:4px}
.submit-btn{padding:12px 24px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%) !important;color:white;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity 0.2s}
.submit-btn:hover{opacity:0.9}
.submit-btn-block{width:100%;display:block}
.info-section{padding:20px;background:var(--bg-secondary);border-radius:8px;margin:20px}
.info-section h2{font-size:16px;margin-bottom:12px;color:var(--text-primary)}
.replies-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}
.replies-section h3{font-size:16px;color:var(--text-primary);margin-bottom:16px}
.replies-empty{color:var(--text-secondary);font-size:14px;margin:0}
.reply-context{margin:-4px 0 8px 0}
.reply-context-link{font-size:13px;color:var(--text-muted);text-decoration:none}
.reply-context-link:hover{color:var(--accent);text-decoration:underline}
.reply-group{margin-bottom:0}
.reply-group > .reply{border-bottom:none}
.reply-children{margin-left:1rem;padding-left:0.75rem;border-left:1px solid rgba(128,128,128,0.2)}
.reply-nested{margin-top:0;border-bottom:none}
.divider{border:none;border-top:1px solid var(--border-color);margin:20px 0}
.h-loading{opacity:0.6;pointer-events:none}
.h-disabled{opacity:0.5;pointer-events:none;cursor:not-allowed}
.h-indicator{display:none}
.h-loading .h-indicator,.h-indicator.h-loading{display:inline-block}
@keyframes h-spin{to{transform:rotate(360deg)}
}
.h-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:h-spin 0.6s linear infinite;vertical-align:middle;margin-right:6px}
.load-more-btn .load-more-text{display:inline}
.load-more-btn .load-more-loading{display:none}
.load-more-btn.h-disabled .load-more-text{display:none}
.load-more-btn.h-disabled .load-more-loading{display:inline}
@keyframes shimmer{0%{background-position:200% 0}
100%{background-position:-200% 0}
}
.skeleton-cards{display:none}
.h-loading .skeleton-cards{display:block}
.h-loading .skeleton-cards-hide{display:none}
.skeleton-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:16px;margin:12px 0}
.skeleton-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.skeleton-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-badge) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton-name{height:14px;width:120px;border-radius:4px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-badge) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton-time{height:12px;width:60px;border-radius:4px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-badge) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton-content{margin:12px 0}
.skeleton-line{height:14px;border-radius:4px;margin-bottom:8px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-badge) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton-line:nth-child(1){width:100%}
.skeleton-line:nth-child(2){width:85%}
.skeleton-line:nth-child(3){width:70%}
.skeleton-footer{height:12px;width:80px;border-radius:4px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-badge) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.post-actions{display:flex;align-items:center;gap:8px;margin-top:10px}
.gif-panel{position:relative;margin:0;padding:0 16px 12px 16px}
.gif-panel-header{display:flex;align-items:center;margin-bottom:10px}
.gif-search-form{flex:1}
.gif-search-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:0.9rem;box-sizing:border-box}
.gif-close-btn{position:absolute;top:8px;right:8px;padding:2px 6px;color:var(--text-muted);text-decoration:none;font-size:1rem;line-height:1;opacity:0.6}
.gif-close-btn:hover{color:var(--text-primary);opacity:1}
.gif-results{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-height:300px;overflow-y:auto}
.gif-item{display:block;aspect-ratio:1;overflow:hidden;border-radius:4px;cursor:pointer;transition:transform 0.15s ease,opacity 0.15s ease}
.gif-item:hover{transform:scale(1.05);opacity:0.9}
.gif-item img{width:100%;height:100%;object-fit:contain}
.gif-empty{grid-column:1 / -1;text-align:center;padding:20px;color:var(--text-secondary)}
.gif-empty p{margin:0}
.gif-empty-hint{font-size:0.85rem;margin-top:8px}
.gif-preview{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin:10px 0}
.gif-preview img{max-width:80px;max-height:60px;border-radius:4px;object-fit:contain}
.gif-url{flex:1;font-size:0.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gif-remove-btn{padding:4px 8px;color:var(--text-secondary);text-decoration:none;font-size:1rem}
.gif-remove-btn:hover{color:var(--error-color)}
.gifs-page{padding:20px}
.gifs-page h2{margin:0 0 16px 0}
.gifs-page .gif-search-form{margin-bottom:20px}
.gifs-page .gif-results{max-height:none}
.compose-page{padding:20px}
.compose-page h2{margin:0 0 16px 0}
.compose-media-preview{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:16px}
.compose-media-preview img{max-width:100px;max-height:80px;border-radius:4px;object-fit:contain}
.compose-media-url{flex:1;font-size:0.85rem;color:var(--text-secondary)}
.compose-form textarea{width:100%;min-height:100px;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;resize:vertical;margin-bottom:12px}
.compose-actions{display:flex;align-items:center;gap:12px}
.compose-change-media{color:var(--accent);text-decoration:none;font-size:0.9rem}
.compose-change-media:hover{text-decoration:underline}
.compose-actions button{margin-left:auto;padding:10px 20px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);color:white;border:none;border-radius:4px;cursor:pointer;font-weight:500}
.wallet-page{padding:0}
.wallet-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin-bottom:16px}
.wallet-card-connected{border-color:var(--border-color)}
.wallet-connection-status{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:13px;color:var(--text-secondary)}
.wallet-connection-indicator{width:8px;height:8px;background:var(--success);border-radius:50%}
.wallet-connection-text{font-family:inherit}
.wallet-status{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.wallet-status-icon{font-size:32px;line-height:1}
.wallet-status-disconnected .wallet-status-icon{opacity:0.5}
.wallet-status-label{font-size:18px;font-weight:600;color:var(--text-primary)}
.wallet-intro-text{color:var(--text-secondary);font-size:14px;margin-bottom:20px;line-height:1.5}
.wallet-connect-form,.wallet-disconnect-form{margin-top:8px}
.wallet-input-group{margin-bottom:16px}
.wallet-input-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}
.wallet-input{width:100%;padding:14px 16px;font-size:15px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);transition:border-color 0.2s}
.wallet-input:focus{outline:none;border-color:var(--accent)}
.wallet-input::placeholder{color:var(--text-tertiary)}
.wallet-input-help{font-size:13px;color:var(--text-tertiary);margin-top:8px}
.btn-secondary{padding:12px 24px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background 0.2s}
.btn-secondary:hover{background:var(--bg-tertiary)}
.btn-block{width:100%;display:block}
.wallet-info-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:16px 20px;margin-bottom:12px}
.wallet-info-heading{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 8px 0}
.wallet-info-section p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}
.wallet-list{margin:0;padding:0;list-style:none}
.wallet-list li{padding:8px 0;border-bottom:1px solid var(--border-light)}
.wallet-list li:last-child{border-bottom:none;padding-bottom:0}
.wallet-list a{color:var(--accent);text-decoration:none;font-weight:500}
.wallet-list a:hover{text-decoration:underline}
.wallet-list-desc{color:var(--text-tertiary);font-size:13px}
.wallet-info-container{margin:1rem 0;min-height:60px}
.wallet-loading{display:flex;align-items:center;gap:0.5rem;color:var(--text-secondary);font-size:14px}
.wallet-balance{display:flex;align-items:baseline;gap:0.25rem;margin-bottom:1rem}
.wallet-balance-icon{font-size:1.5rem}
.wallet-balance-amount{font-size:2rem;font-weight:600;color:var(--text-primary)}
.wallet-balance-unit{font-size:1rem;color:var(--text-secondary)}
.wallet-transactions{border-top:1px solid var(--border);padding-top:1rem}
.wallet-transactions-title{font-size:14px;font-weight:500;color:var(--text-secondary);margin:0 0 0.5rem 0;text-transform:uppercase;letter-spacing:0.05em}
.wallet-transaction-list{display:flex;flex-direction:column;gap:0}
.wallet-transaction{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-light);font-size:14px}
.wallet-transaction:last-child{border-bottom:none}
.wallet-transaction-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.wallet-transaction-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.wallet-transaction-icon{font-size:14px;flex-shrink:0}
.wallet-transaction-incoming .wallet-transaction-icon{color:var(--success)}
.wallet-transaction-outgoing .wallet-transaction-icon{color:var(--warning,#f59e0b)}
.wallet-transaction-desc{color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wallet-transaction-amount{font-weight:600;white-space:nowrap}
.wallet-transaction-incoming .wallet-transaction-amount{color:var(--success)}
.wallet-transaction-outgoing .wallet-transaction-amount{color:var(--text-secondary)}
.wallet-transaction-time{color:var(--text-tertiary);font-size:12px}
.wallet-transactions-empty{color:var(--text-tertiary);font-size:14px;padding:16px 0;margin:0}
.wallet-info-error{color:var(--error);font-size:14px;padding:0.5rem 0}
.report-page{max-width:800px;padding:16px 0}
.report-page h1{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}
.mutes-page{max-width:800px;padding:16px 0}
.mutes-page h1{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}
.notifications-page{max-width:800px;padding:16px 0}
.notifications-page h1{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}
.reported-note{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;padding:16px;margin-bottom:24px}
.reported-note .quoted-author{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.reported-note .quoted-author img{width:32px;height:32px;border-radius:50%;object-fit:cover}
.reported-note .quoted-author-name{font-size:14px;font-weight:500;color:var(--text-primary)}
.reported-note .note-content{font-size:14px;color:var(--text-secondary);word-break:break-word}
.report-form fieldset{border:1px solid var(--border-light);border-radius:8px;padding:16px;margin:0 0 20px 0}
.report-form legend{font-size:14px;font-weight:600;color:var(--text-primary);padding:0 8px}
.report-form .radio-label{display:inline-flex;align-items:center;gap:6px;margin-right:16px;margin-bottom:8px;font-size:14px;color:var(--text-secondary);cursor:pointer}
.report-form .radio-label input[type="radio"]{accent-color:var(--accent)}
.report-form .checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary);cursor:pointer}
.report-form .checkbox-label input[type="checkbox"]{accent-color:var(--accent)}
.report-form textarea{width:100%;min-height:80px;padding:12px;border:1px solid var(--border-light);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;resize:vertical}
.report-form textarea:focus{outline:none;border-color:var(--accent)}
.report-form .form-actions{display:flex;gap:12px;margin-top:20px}
@media (max-width:600px){body{padding:0}
.container{border-radius:0;box-shadow:none}
.gif-results{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
.skeleton-card,.skeleton-avatar,.skeleton-name,.skeleton-time,.skeleton-line,.skeleton-footer{animation:none;background:var(--bg-tertiary)}
}
