*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333;min-height:100vh}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;font-size:1.2rem;color:#666}.spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#4a90d9;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.load-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#999;gap:.5rem}.load-error-icon{font-size:2rem}.load-error-message{font-size:.95rem}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.auth-container h1{margin-bottom:2rem;font-size:2rem}.auth-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;width:100%;max-width:400px;display:flex;flex-direction:column;gap:1rem}.auth-form h2{text-align:center;margin-bottom:.5rem}.auth-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.auth-form input:focus{outline:none;border-color:#4a90d9}.auth-form button[type=submit]{padding:.75rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.auth-form button[type=submit]:hover{background:#357abd}.auth-form button[type=submit]:disabled{background:#999;cursor:not-allowed}.auth-form .error{color:#d32f2f;font-size:.9rem}.auth-form .message{color:#2e7d32;font-size:.9rem}.auth-form .toggle{text-align:center;font-size:.9rem;color:#666}.auth-form .toggle button{background:none;border:none;color:#4a90d9;cursor:pointer;font-size:.9rem}.app-layout{min-height:100vh}.app-header{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;background:#fff;box-shadow:0 1px 4px #0000001a;position:sticky;top:0;z-index:10}.app-header-right{display:flex;align-items:center;gap:.75rem;margin-left:auto}.app-title{font-size:1.2rem;font-weight:700;color:#4a90d9;text-decoration:none}.app-nav{display:flex;gap:1rem}.app-nav a{color:#555;text-decoration:none;padding:.25rem .5rem;border-radius:4px}.app-nav a:hover{background:#f0f0f0;color:#333}.app-signout-btn{padding:.4rem .8rem;background:#666;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.app-signout-btn:hover{background:#555}.app-user-name{font-size:.9rem;color:#666}.hamburger-btn{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;color:#555}.mobile-nav-link,.mobile-nav-overlay{display:none}.app-main{max-width:640px;margin:1.5rem auto;padding:0 1rem}.feed-container{display:flex;flex-direction:column;gap:1rem}.feed-header{display:flex;align-items:center;justify-content:space-between}.feed-title{font-size:1.4rem;font-weight:700}.app-icon-link{text-decoration:none;color:#666;padding:.4rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.app-icon-link:hover{background:#f0f0f0;color:#333}.notification-bell-wrapper{position:relative}.notification-bell{background:none;border:none;cursor:pointer;padding:.4rem;border-radius:4px;color:#888;display:flex;align-items:center;justify-content:center;position:relative}.notification-bell:hover{background:#f0f0f0;color:#333}.notification-badge{position:absolute;top:-4px;right:-6px;background:#dc3545;color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notification-list{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:320px;max-height:400px;overflow-y:auto;z-index:10}.notification-empty{padding:1.5rem;text-align:center;color:#888;font-size:.9rem}.notification-item{display:block;width:100%;padding:.75rem 1rem;border:none;border-bottom:1px solid #f0f0f0;cursor:pointer;text-align:left;font-size:inherit;font-family:inherit}.notification-item:last-child{border-bottom:none}.notification-item.unclicked{background:#e8f0fa}.notification-item.clicked{background:#fff}.notification-item:hover{background:#f5f5f5}.notification-item-message{font-size:.9rem;color:#333;margin-bottom:2px}.notification-item-time{font-size:.75rem;color:#999}.feed-list{display:flex;flex-direction:column;gap:1rem}.feed-empty{text-align:center;color:#888;padding:2rem}.load-more{padding:.6rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#4a90d9;font-size:.9rem}.load-more:hover{background:#f9f9f9}.load-more:disabled{color:#999;cursor:not-allowed}.post-composer{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:.5rem;position:relative}.post-composer-drop-overlay{position:absolute;inset:0;background:#0006;border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:none}.post-composer-drop-overlay span{color:#fff;font-size:1.2rem;font-weight:600}.post-composer textarea{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;resize:vertical;min-height:60px}.post-composer textarea:focus{outline:none;border-color:#4a90d9}.post-composer-actions{display:flex;justify-content:space-between;align-items:center}.post-composer-add-image{padding:.4rem .8rem;background:none;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.85rem;color:#666}.post-composer-add-image:hover{border-color:#4a90d9;color:#4a90d9}.post-composer-add-image:disabled{opacity:.5;cursor:not-allowed}.post-composer-add-video{padding:.4rem .8rem;background:none;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.85rem;color:#666}.post-composer-add-video:hover:not(:disabled){border-color:#4a90d9;color:#4a90d9}.post-composer-add-video:disabled{opacity:.5;cursor:not-allowed}.post-composer-video-preview{display:flex;align-items:center;gap:.75rem;padding:.6rem .8rem;margin-top:.5rem;background:#f5f7fa;border:1px solid #e1e4e8;border-radius:4px;font-size:.85rem}.post-composer-video-filename{font-weight:500;color:#222;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.post-composer-video-status{color:#666}.post-composer-video-status[data-phase=ready]{color:#2d7a3e}.post-composer-video-status[data-phase=error]{color:#c03030}.post-composer-video-remove{padding:.3rem .6rem;background:none;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#666;font-size:.8rem}.post-card-video{margin-top:.75rem;background:#000;border-radius:6px;overflow:hidden;aspect-ratio:16 / 9}.post-card-video>div{width:100%;height:100%}.post-card-video iframe{display:block;width:100%;height:100%;border:0}.post-composer-topic-label{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:#666}.post-composer-topic-select{padding:.4rem .8rem;background:#fff;border:1px solid #ddd;border-radius:4px;font-size:.85rem;color:#666;cursor:pointer;max-width:180px}.post-composer-topic-select:hover{border-color:#4a90d9;color:#4a90d9}.post-composer-topic-select:disabled{opacity:.5;cursor:not-allowed}.post-composer-file-input{display:none}.post-composer-preview-strip{display:flex;gap:.5rem;padding:.5rem 0;overflow-x:auto;align-items:flex-end}.post-composer-preview-item{position:relative;flex-shrink:0;cursor:grab;border:2px solid transparent;border-radius:8px;transition:border-color .15s}.post-composer-preview-item:hover{border-color:#4a90d9}.post-composer-preview-item.dragging{opacity:.5}.post-composer-preview-number{position:absolute;top:4px;left:4px;background:#0009;color:#fff;font-size:.7rem;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:1}.post-composer-preview-img{width:80px;height:80px;border-radius:6px;object-fit:cover;display:block}.post-composer-preview-slot{display:flex;align-items:stretch;flex-shrink:0}.post-composer-remove-overlay{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:#dc2626;color:#fff;border:2px solid white;font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;line-height:1;padding:0}.post-composer-preview-controls{display:flex;justify-content:center;gap:2px;margin-top:2px}.post-composer-move-btn{background:none;border:1px solid #d1d5db;border-radius:3px;font-size:.75rem;cursor:pointer;padding:0 4px;color:#666;line-height:1.4}.post-composer-move-tap,.post-composer-insert-slot,.post-composer-move-hint,.mobile-only{display:none}.post-composer-preview-item.moving{border-color:#4a90d9;box-shadow:0 0 0 2px #4a90d94d}.post-composer-add-more{flex-shrink:0;width:80px;height:80px;border:2px dashed #d1d5db;border-radius:6px;background:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center}.post-composer-add-more:hover{border-color:#4a90d9;color:#4a90d9}.post-composer button[type=submit]{padding:.5rem 1.5rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.post-composer button[type=submit]:hover{background:#357abd}.post-composer button[type=submit]:disabled{background:#999;cursor:not-allowed}.post-card{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.post-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.post-card-author{font-weight:600;font-size:.95rem}.post-card-time-group{display:flex;align-items:center;gap:.35rem;margin-left:auto}.post-card-time{font-size:.8rem;color:#999}.post-card-content{margin-bottom:.75rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.post-card-footer{display:flex;flex-direction:column;gap:.5rem}.post-card-actions{display:flex;gap:.75rem;align-items:center}.post-card-replies{color:#4a90d9;text-decoration:none;font-size:.9rem}.post-card-replies:hover{text-decoration:underline}.post-card-delete{background:none;border:none;color:#d32f2f;cursor:pointer;font-size:.85rem;padding:0}.post-card-delete:hover{text-decoration:underline}.post-card-edited{font-size:.75rem;color:#999;font-style:italic}.post-card-edit-icon{background:none;border:none;color:#999;cursor:pointer;font-size:.85rem;padding:.1rem .25rem;border-radius:3px}.post-card-edit-icon:hover{color:#4a90d9;background:#f0f0f0}.post-card-edit-form{margin-bottom:.75rem}.post-card-edit-textarea{width:100%;padding:.5rem;border:1px solid #4a90d9;border-radius:4px;font-family:inherit;font-size:inherit;line-height:1.5;resize:vertical;min-height:60px;box-sizing:border-box}.post-card-edit-textarea:focus{outline:none;border-color:#357abd;box-shadow:0 0 0 2px #4a90d933}.post-card-edit-error{color:#d32f2f;font-size:.85rem;margin-top:.25rem}.post-card-edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.post-card-edit-save{padding:.35rem .75rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.post-card-edit-save:hover{background:#357abd}.post-card-edit-save:disabled{background:#999;cursor:not-allowed}.post-card-edit-cancel{padding:.35rem .75rem;background:none;color:#666;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.85rem}.post-card-edit-cancel:hover{background:#f5f5f5}.post-card-image{margin-bottom:.75rem}.post-card-carousel{position:relative;overflow:hidden;border-radius:8px}.post-card-carousel-scroll{display:flex;overflow-x:scroll;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.post-card-carousel-scroll::-webkit-scrollbar{display:none}.post-card-carousel-slide{flex:0 0 100%;scroll-snap-align:start;width:100%;cursor:pointer;display:block}.post-card-carousel-slide:hover{opacity:.95}.post-card-image-thumb{width:100%;border-radius:8px;cursor:pointer;display:block}.post-card-image-thumb:hover{opacity:.95}.post-card-carousel-counter{position:absolute;top:8px;right:8px;background:#0009;color:#fff;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:12px}.post-card-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;color:#fff;border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.post-card-carousel-arrow:hover{background:#000000b3}.post-card-carousel-arrow.left{left:8px}.post-card-carousel-arrow.right{right:8px}.post-card-carousel-dots{display:flex;justify-content:center;gap:6px;padding:8px 0 0}.post-card-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:#d1d5db;cursor:pointer;padding:0}.post-card-carousel-dot.active{background:#4a90d9}.post-image-lightbox{position:fixed;inset:0;background:#000000d9;z-index:100;cursor:pointer}.post-lightbox-scroll{width:100vw;height:100vh;display:flex;overflow-x:scroll;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.post-lightbox-scroll::-webkit-scrollbar{display:none}.post-lightbox-slide{flex:0 0 100vw;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;padding:0 1rem}.post-lightbox-image{max-width:100%;max-height:95vh;object-fit:contain;border-radius:4px;cursor:default;display:block}.post-lightbox-counter{position:absolute;top:16px;right:16px;background:#0009;color:#fff;font-size:.9rem;font-weight:600;padding:4px 12px;border-radius:16px;cursor:default;z-index:1}.post-lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#fff3;color:#fff;border:none;width:48px;height:48px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1}.post-lightbox-arrow:hover{background:#ffffff4d}.post-lightbox-arrow.left{left:16px}.post-lightbox-arrow.right{right:16px}.reaction-bar{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.reaction-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border:1px solid #ddd;border-radius:12px;background:#f9f9f9;cursor:pointer;font-size:.85rem}.reaction-pill:hover{background:#eef}.reaction-pill.active{border-color:#4a90d9;background:#e8f0fe}.reaction-add-wrapper{position:relative}.reaction-add{width:28px;height:28px;border:1px dashed #ccc;border-radius:50%;background:none;cursor:pointer;font-size:1rem;color:#888;display:flex;align-items:center;justify-content:center}.reaction-add:hover{border-color:#4a90d9;color:#4a90d9}.reaction-picker{position:absolute;bottom:100%;left:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:.4rem;display:flex;gap:.2rem;z-index:5}.reaction-picker button{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:4px}.reaction-picker button:hover{background:#f0f0f0}.thread-container{display:flex;flex-direction:column}.thread-scrollable{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem}.thread-composer-sticky{flex-shrink:0;border-top:1px solid #e0e0e0;padding:.75rem 0}.thread-composer-sticky .post-composer{box-shadow:none;border-radius:0;padding:.5rem 0}.thread-back{color:#4a90d9;text-decoration:none;font-size:.9rem}.thread-back:hover{text-decoration:underline}.thread-replies h3{font-size:1rem;color:#666;margin-bottom:.5rem}.thread-replies{display:flex;flex-direction:column;gap:.75rem;padding-left:1rem;border-left:2px solid #e0e0e0}.friends-container{display:flex;flex-direction:column;gap:1.5rem}.friends-container h2{font-size:1.4rem}.friends-search{display:flex;flex-direction:column;gap:.5rem}.friends-search-row{display:flex;gap:.5rem}.friends-search-row input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.friends-search-row input:focus{outline:none;border-color:#4a90d9}.friends-search-row button{padding:.75rem 1.25rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.friends-search-row button:hover{background:#357abd}.friends-search-row button:disabled{background:#999;cursor:not-allowed}.search-results{background:#fff;border:1px solid #ddd;border-radius:4px;overflow:hidden}.friends-section h3{font-size:1.1rem;margin-bottom:.5rem}.friends-empty{color:#888;font-size:.95rem}.friend-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #eee}.friend-item:last-child{border-bottom:none}.friend-item button{padding:.35rem .75rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.friend-item button:hover{background:#357abd}.friend-actions{display:flex;gap:.5rem}.friend-status{font-size:.85rem;color:#888}.btn-danger{padding:.35rem .75rem;background:#d32f2f!important;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.btn-danger:hover{background:#b71c1c!important}.message{color:#2e7d32;font-size:.9rem}.error{color:#d32f2f;font-size:.9rem}.avatar{border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-xs{width:18px;height:18px;font-size:.5rem}.avatar-sm{width:28px;height:28px;font-size:.75rem}.avatar-md{width:36px;height:36px;font-size:.9rem}.avatar-lg{width:80px;height:80px;font-size:2rem}.avatar-initial{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600}.profile-container{display:flex;flex-direction:column;gap:1.5rem}.profile-container h2{font-size:1.4rem}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;gap:.75rem}.profile-avatar-btn{padding:.4rem .8rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.profile-avatar-btn:hover{background:#357abd}.profile-avatar-btn:disabled{background:#999;cursor:not-allowed}.profile-avatar-input{display:none}.profile-form{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:.75rem}.profile-form label{font-weight:600;font-size:.9rem;color:#555}.profile-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.profile-form input:focus{outline:none;border-color:#4a90d9}.profile-form button[type=submit]{align-self:flex-start;padding:.5rem 1.5rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.profile-form button[type=submit]:hover{background:#357abd}.profile-form button[type=submit]:disabled{background:#999;cursor:not-allowed}.profile-email{text-align:center;color:#888;font-size:.9rem}.profile-email-prefs{margin-top:1.5rem}.profile-email-prefs h3{font-size:1rem;margin-bottom:.75rem}.profile-pref-option{display:flex;align-items:flex-start;gap:.75rem;padding:.6rem .75rem;border-radius:6px;cursor:pointer;margin-bottom:.25rem}.profile-pref-option.selected{background:#e8f0fa}.profile-pref-option input[type=radio]{margin-top:3px}.profile-storage-usage{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #e5e7eb}.profile-storage-usage h3{font-size:1rem;margin-bottom:.5rem}.profile-storage-gauge{height:10px;width:100%;background:#eef2f7;border-radius:999px;overflow:hidden;margin-bottom:.5rem}.profile-storage-gauge-bar{height:100%;background:#7ba87b;border-radius:999px;transition:width .3s ease,background-color .3s ease;min-width:1px}.profile-storage-gauge-bar--over{background:#dc2626}.profile-storage-warning{font-size:.8rem;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:.5rem .65rem;margin:.25rem 0 0}.profile-data-export{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #e5e7eb}.profile-data-export h3{font-size:1rem;margin-bottom:.5rem}.profile-export-details{margin:.5rem 0 .75rem;font-size:.85rem}.profile-export-details>summary{cursor:pointer;color:#4a90d9;padding:.25rem 0}.profile-export-details-body{margin-top:.5rem;padding:.75rem 1rem;background:#f8fafc;border-radius:6px;color:#333}.profile-export-details-body p{margin:.5rem 0}.profile-export-details-body ul{margin:.25rem 0 .75rem 1.25rem;padding:0}.profile-export-details-body li{margin-bottom:.25rem}.profile-danger-zone{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #fca5a5}.profile-danger-zone h3{font-size:1rem;color:#dc2626;margin-bottom:.75rem}.profile-delete-btn{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.profile-delete-btn:hover{background:#b91c1c}.profile-delete-confirm{margin-top:.5rem}.profile-delete-confirm p{margin-bottom:.5rem;font-size:.9rem;color:#555}.profile-delete-submit{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.profile-delete-submit:disabled{background:#fca5a5;cursor:not-allowed}.profile-delete-submit:not(:disabled):hover{background:#b91c1c}.profile-deleting-overlay{margin-top:2rem;padding:2rem;text-align:center;color:#555}.profile-deleting-overlay p{margin-top:1rem;font-size:1rem}.profile-deleted-message{margin-top:2rem;padding:2rem;text-align:center}.profile-deleted-message p{font-size:1.1rem;color:#065f46;font-weight:500}.app-user-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:#666}.app-user-link:hover{color:#333}.friend-info{display:flex;align-items:center;gap:.5rem}.search-empty{color:#888;font-size:.95rem;padding:.5rem}.btn-view-profile{color:#4a90d9;text-decoration:none;font-size:.85rem;padding:.25rem .5rem;border-radius:4px}.btn-view-profile:hover{text-decoration:underline}.user-profile-header{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;align-items:center;gap:.5rem}.user-profile-name{font-size:1.4rem;font-weight:700}.user-profile-email{color:#888;font-size:.9rem}.user-profile-stats{display:flex;gap:2rem;margin-top:.25rem}.user-profile-stat{display:flex;flex-direction:column;align-items:center}.user-profile-stat-value{font-weight:700;font-size:1.1rem;color:#333}.user-profile-stat-label{font-size:.8rem;color:#666}.user-profile-member-since{color:#999;font-size:.85rem}.user-profile-edit-link{color:#4a90d9;text-decoration:none;font-size:.9rem}.user-profile-edit-link:hover{text-decoration:underline}.user-profile-relationship{color:#888;font-size:.95rem;text-align:center;padding:2rem 1rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.post-card-author-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit}.post-card-author-link:hover .post-card-author{text-decoration:underline}.post-card-group-header{display:flex;align-items:center;gap:.5rem}.post-card-group-avatar-link{text-decoration:none;flex-shrink:0}.post-card-group-avatar{position:relative;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:600}.post-card-group-user-overlay{position:absolute;bottom:-2px;right:-2px;border:2px solid #fff;border-radius:50%;line-height:0}.post-card-group-names{display:flex;flex-direction:column;gap:0;min-width:0}.post-card-group-name{font-weight:600;font-size:.95rem;color:#333;text-decoration:none;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.post-card-group-name:hover{text-decoration:underline}.post-card-group-author{font-size:.8rem;color:#888;text-decoration:none;font-weight:400;line-height:1.3}.post-card-group-author:hover{text-decoration:underline}.back-link{color:#4a90d9;text-decoration:none;font-size:.9rem;margin-bottom:.5rem}.back-link:hover{text-decoration:underline}.topic-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.topic-card-info{flex:1;min-width:0}.topic-card-name{font-weight:600;font-size:1.05rem;color:#4a90d9;text-decoration:none}.topic-card-name:hover{text-decoration:underline}.topic-card-desc{color:#666;font-size:.85rem;margin-top:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-card-meta{font-size:.8rem;color:#999;margin-top:.25rem}.topic-card-badge{font-size:.7rem;padding:.15rem .5rem;border-radius:12px;background:#e8f0fa;color:#4a90d9;font-weight:600;white-space:nowrap}.topic-list{display:flex;flex-direction:column;gap:.75rem}.topic-header-actions{display:flex;gap:.75rem;margin-top:1rem}.post-card-topic-badge{font-size:.7rem;padding:.1rem .5rem;border-radius:10px;text-decoration:none;font-weight:600;margin-left:auto}.post-card-topic-badge:hover{opacity:.85}.post-card-private-badge{font-size:.65rem;padding:.1rem .4rem;border-radius:8px;background:#f3f4f6;color:#6b7280;font-weight:600;margin-left:.25rem}.topic-private-badge{display:inline-block;font-size:.7rem;padding:.1rem .5rem;border-radius:8px;background:#f3f4f6;color:#6b7280;font-weight:600;vertical-align:middle;margin-left:.4rem}.topic-members-section{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.topic-members-section h3{font-size:1rem;margin:0 0 .75rem;color:#333}.topic-members-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.topic-member-item{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0}.topic-member-info{display:flex;align-items:center;gap:.5rem}.topic-member-role{font-size:.75rem;color:#9ca3af;text-transform:capitalize}.topic-member-role-select{padding:.15rem .4rem;border:1px solid #ddd;border-radius:4px;font-size:.75rem;color:#666;background:#fff;cursor:pointer}.topic-member-actions{display:flex;align-items:center;gap:.4rem}.topic-add-member-btn{padding:.4rem .8rem;background:none;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.85rem;color:#666}.topic-add-member-btn:hover{border-color:#4a90d9;color:#4a90d9}.topic-add-member{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem;border-top:1px solid #e0e0e0}.btn-sm{padding:.25rem .6rem;font-size:.8rem;border-radius:4px;cursor:pointer;border:none}.btn-primary{background:#4a90d9;color:#fff}.btn-primary:hover{background:#357abd}.user-profile-topics{background:#fff;padding:1.25rem 1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem}.user-profile-topics h3{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#333}.user-profile-topics-grid{display:flex;flex-wrap:wrap;gap:.5rem}.topic-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:9999px;text-decoration:none;font-size:.85rem;font-weight:500;transition:opacity .15s;white-space:nowrap}.topic-pill:hover{opacity:.85}.topic-pill-emoji{font-size:1rem;line-height:1}.topic-pill-name{line-height:1.2}.topic-name-edit-btn{background:none;border:none;cursor:pointer;font-size:.85rem;color:#4a90d9;margin-left:.4rem;padding:0;vertical-align:middle;display:inline-block;transform:scaleX(-1) translateY(-2px)}.topic-name-edit-btn:hover{color:#357abd}.topic-name-edit{font-size:1.4rem;font-weight:700;border:1px solid #d1d5db;border-radius:4px;padding:.25rem .5rem;width:100%;box-sizing:border-box}.topic-composer{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1rem;margin-bottom:1rem}.topic-composer textarea{width:100%;min-height:60px;border:1px solid #ddd;border-radius:6px;padding:.5rem;font-family:inherit;font-size:.95rem;resize:vertical;box-sizing:border-box}.topic-composer button{margin-top:.5rem}.bug-status-badge{display:inline-block;padding:.1rem .45rem;border-radius:9999px;font-size:.72rem;font-weight:600;white-space:nowrap}.bug-status-submitted{background:#dbeafe;color:#1d4ed8}.bug-status-accepted{background:#fef3c7;color:#92400e}.bug-status-in_progress{background:#e0e7ff;color:#4338ca}.bug-status-closed_fixed{background:#d1fae5;color:#065f46}.bug-status-closed_duplicate,.bug-status-closed_obe{background:#f3f4f6;color:#6b7280}.bug-status-closed_wontfix{background:#fee2e2;color:#991b1b}.bug-visibility-badge{display:inline-block;padding:.1rem .45rem;border-radius:9999px;font-size:.72rem;font-weight:600;background:#f3f4f6;color:#6b7280}.bug-employee-badge{display:inline-block;padding:.08rem .4rem;border-radius:9999px;font-size:.7rem;font-weight:600;background:#fef3c7;color:#92400e}@media(max-width:768px){.app-header{gap:.75rem;padding:.5rem 1rem}.app-nav{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#fff;box-shadow:0 4px 12px #0000001a;padding:.5rem 0;z-index:20}.app-nav.open{display:flex}.app-nav a,.app-nav button{padding:.75rem 1.5rem;border-radius:0;font-size:1rem}.app-nav a:hover,.app-nav button:hover{background:#f0f0f0}.mobile-nav-link{display:block;text-decoration:none;color:#555}.mobile-signout{background:none;border:none;border-top:1px solid #e5e7eb;text-align:left;cursor:pointer;color:#555;width:100%;font-size:1rem}.hamburger-btn{display:block}.app-header-right .app-icon-link,.app-signout-btn,.app-user-name{display:none}.mobile-nav-overlay{display:block;position:fixed;inset:0;z-index:5}.notification-list{min-width:unset;width:100vw;position:fixed;top:auto;left:0;right:0;border-radius:0;max-height:calc(100vh - 3.5rem)}.app-main{margin:1rem auto;padding:0 .75rem}.post-composer-actions{flex-wrap:wrap;gap:.5rem}.post-composer-topic-label{width:100%;order:-1}.post-composer-topic-select{flex:1;max-width:none}.post-composer-preview-img,.post-composer-add-more{width:100px;height:100px}.post-composer-remove-overlay{width:32px;height:32px;top:-8px;right:-8px;font-size:1.1rem;border-width:2px}.post-composer-preview-item{cursor:default}.post-composer-preview-controls.desktop-only{display:none}.mobile-only{display:block}.post-composer-move-tap{display:block;width:100%;padding:4px 0;margin-top:4px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;font-size:.75rem;color:#555;cursor:pointer;text-align:center}.post-composer-move-tap.active{background:#4a90d9;border-color:#4a90d9;color:#fff}.post-composer-insert-slot{display:flex;width:28px;min-height:100px;flex-shrink:0;background:#4a90d926;border:2px dashed #4a90d9;border-radius:6px;cursor:pointer;margin:0 -2px;padding:0;animation:slot-pulse 1s ease-in-out infinite alternate}.post-composer-insert-slot:active{background:#4a90d94d}@keyframes slot-pulse{0%{border-color:#93c5fd}to{border-color:#2563eb}}.post-composer-move-hint{display:block;font-size:.8rem;color:#4a90d9;text-align:center;margin:.25rem 0 0;font-style:italic}}.landing{min-height:100vh;background:#fafafa;color:#0a0a0a;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.landing__nav{max-width:1200px;margin:0 auto;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.landing__brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.05rem;letter-spacing:-.02em;color:#0a0a0a}.landing__brand img{width:32px;height:32px}.landing__nav-meta{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.72rem;color:#9a9a9a;letter-spacing:.02em}.landing__hero{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 5rem;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:4rem;align-items:center}.landing__pitch{max-width:620px}.landing__eyebrow{display:inline-block;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:#4a90d9;margin-bottom:1.25rem}.landing__h1{font-size:clamp(2.75rem,6vw,4.75rem);line-height:1.02;letter-spacing:-.035em;font-weight:800;margin:0 0 1.25rem;color:#0a0a0a}.landing__h1-accent{color:#4a90d9}.landing__sub{font-size:1.15rem;line-height:1.55;color:#4a4a4a;margin:0 0 1.75rem;max-width:36rem}.landing__proof-strip{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.78rem;color:#6a6a6a;letter-spacing:.02em;display:flex;flex-wrap:wrap;gap:1.25rem 1.75rem}.landing__proof-strip span:before{content:"→ ";color:#4a90d9}.landing__auth-card{background:#fff;border:1px solid #ececec;border-radius:12px;padding:1.75rem;box-shadow:0 1px 2px #0000000a,0 8px 24px #0000000f;display:flex;flex-direction:column;gap:.85rem;max-width:420px;width:100%;justify-self:end}.landing__auth-card h2{font-size:1.15rem;font-weight:700;margin:0 0 .25rem;letter-spacing:-.01em}.landing__auth-card .landing__auth-hint{font-size:.85rem;color:#6a6a6a;margin:0 0 .5rem}.landing__auth-card input{padding:.7rem .85rem;border:1px solid #dcdcdc;border-radius:6px;font-size:.95rem;font-family:inherit;transition:border-color .15s}.landing__auth-card input:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d91f}.landing__auth-card button[type=submit]{padding:.75rem;background:#7ba87b;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.landing__auth-card button[type=submit]:hover:not(:disabled){background:#6b9c6b}.landing__auth-card button[type=submit]:disabled{background:#bdbdbd;cursor:not-allowed}.landing__auth-card .error{color:#d32f2f;font-size:.85rem;margin:0}.landing__auth-card .message{color:#2e7d32;font-size:.85rem;margin:0}.landing__auth-toggle{font-size:.82rem;color:#6a6a6a;text-align:center;margin:.25rem 0 0}.landing__auth-toggle button{background:none;border:none;color:#4a90d9;cursor:pointer;font-size:.82rem;font-family:inherit;padding:0;text-decoration:underline}.landing__auth-toggle--split{display:flex;justify-content:space-between;gap:1rem}.landing__section{border-top:1px solid #ececec;padding:5rem 1.5rem}.landing__section--dark{background:#0a0a0a;color:#fafafa;border-top:none}.landing__section-inner{max-width:1100px;margin:0 auto}.landing__section-eyebrow{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#4a90d9;margin:0 0 .75rem}.landing__section--dark .landing__section-eyebrow{color:#7cb5ea}.landing__section-title{font-size:clamp(1.75rem,3.4vw,2.75rem);line-height:1.1;letter-spacing:-.025em;font-weight:700;margin:0 0 1rem;max-width:30rem}.landing__section-lead{font-size:1.05rem;line-height:1.55;color:#4a4a4a;max-width:40rem;margin:0 0 2.5rem}.landing__section--dark .landing__section-lead{color:#b5b5b5}.landing__manifesto{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1px;background:#232323;border:1px solid #232323;border-radius:10px;overflow:hidden}.landing__manifesto-item{background:#0a0a0a;padding:1.5rem 1.6rem;display:flex;flex-direction:column;gap:.4rem}.landing__manifesto-no{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#6a6a6a}.landing__manifesto-title{font-size:1.05rem;font-weight:600;letter-spacing:-.01em;color:#fafafa}.landing__manifesto-body{font-size:.88rem;line-height:1.5;color:#9a9a9a}.landing__manifesto-body p{margin:0 0 .5rem}.landing__manifesto-body p:last-child{margin-bottom:0}.landing__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.landing__card{background:#fff;border:1px solid #ececec;border-radius:12px;padding:1.75rem;display:flex;flex-direction:column;gap:.6rem}.landing__card-eyebrow{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#4a90d9}.landing__card-title{font-size:1.2rem;font-weight:700;letter-spacing:-.015em;color:#0a0a0a;margin:0}.landing__card-body{font-size:.95rem;line-height:1.55;color:#4a4a4a;margin:0}.landing__outbound{background:#0a0a0a;color:#fafafa;border-radius:10px;padding:1.75rem 2rem;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.9rem;line-height:1.75;max-width:720px}.landing__outbound-line{display:flex;gap:1rem;align-items:baseline}.landing__outbound-key{color:#7cb5ea;flex-shrink:0;width:6.5rem}.landing__outbound-val{color:#fafafa}.landing__outbound-comment{color:#6a6a6a}.landing__final-cta{text-align:center;padding:6rem 1.5rem;border-top:1px solid #ececec}.landing__final-cta h2{font-size:clamp(2rem,4.5vw,3.5rem);line-height:1.05;letter-spacing:-.03em;font-weight:800;margin:0 0 1rem}.landing__final-cta p{font-size:1.05rem;color:#6a6a6a;margin:0 0 2rem}.landing__final-cta-button{display:inline-block;padding:.9rem 1.75rem;background:#7ba87b;color:#fff;text-decoration:none;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.landing__final-cta-button:hover{background:#6b9c6b}.landing__footer{max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem 3.5rem;color:#6a6a6a;font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-top:1px solid #ececec}.landing__footer a{color:#6a6a6a;text-decoration:none;margin-left:1.25rem}.landing__footer a:hover{text-decoration:underline}.landing__footer-trackers{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:.72rem;color:#7ba87b;letter-spacing:.02em}@media(max-width:880px){.landing__hero{grid-template-columns:1fr;gap:2.5rem;padding:2rem 1.25rem 3.5rem}.landing__auth-card{justify-self:stretch;max-width:none}.landing__section{padding:3.5rem 1.25rem}.landing__final-cta{padding:4rem 1.25rem}.landing__nav-meta{display:none}}.landing__section--cream{background:#faf6ee;border-top-color:#efe6d4}.landing__founder{display:grid;grid-template-columns:auto 1fr;gap:2.5rem;align-items:start}.landing__founder-avatar{width:144px;height:144px;border-radius:50%;object-fit:cover;background:#e8f0fa;border:1px solid #cfdceb;flex-shrink:0;display:block}.landing__founder-body{max-width:620px}.landing__founder-prose p{font-size:1.05rem;line-height:1.65;color:#3a3a3a;margin:0 0 1rem}.landing__founder-prose p:last-child:has(em:only-child){font-size:.95rem;color:#6a6a6a;margin:1.25rem 0 0;font-style:italic}.landing__founder-prose p:last-child:has(em:only-child) em{font-style:inherit}.landing__faq{display:flex;flex-direction:column;gap:.5rem;max-width:760px}.landing__faq-item{border:1px solid #ececec;border-radius:8px;background:#fff;overflow:hidden}.landing__faq-item[open]{border-color:#cfdceb;box-shadow:0 2px 8px #4a90d90f}.landing__faq-item>summary{padding:1rem 1.25rem;cursor:pointer;font-weight:600;font-size:1rem;color:#0a0a0a;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}.landing__faq-item>summary::-webkit-details-marker{display:none}.landing__faq-item>summary:after{content:"+";font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:1.2rem;color:#4a90d9;font-weight:400;line-height:1;flex-shrink:0}.landing__faq-item[open]>summary:after{content:"−"}.landing__faq-answer{padding:0 1.25rem 1rem;font-size:.95rem;line-height:1.6;color:#4a4a4a}.landing__faq-answer p{margin:0 0 .75rem}.landing__faq-answer p:last-child{margin-bottom:0}@media(max-width:880px){.landing__founder{grid-template-columns:1fr;gap:1.5rem}.landing__founder-avatar{width:96px;height:96px}}.reaction-pill-wrap{position:relative;display:inline-block}.reaction-popup{position:absolute;bottom:calc(100% + .3rem);left:0;z-index:30;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000014;padding:.4rem .5rem;min-width:160px;max-width:280px;font-size:.82rem;color:#333;pointer-events:auto}.reaction-popup-loading,.reaction-popup-error{display:block;padding:.2rem .25rem;color:#6a6a6a}.reaction-popup-error{color:#d32f2f}.reaction-popup-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.reaction-popup-known{display:flex;align-items:center;gap:.4rem;color:#333;text-decoration:none;padding:.1rem .25rem;border-radius:4px}.reaction-popup-known:hover{background:#eaf2fb}.reaction-popup-unknown{color:#6a6a6a;font-style:italic;padding:.15rem .25rem}.messages-page{display:grid;grid-template-columns:320px 1fr;height:100%;max-width:1200px;margin:0 auto;background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}body.messages-active{height:var(--app-vh, 100dvh);min-height:0;overflow:hidden}html:has(body.messages-active){height:var(--app-vh, 100dvh);overflow:hidden}body.messages-active .app-layout{height:var(--app-vh, 100dvh);min-height:0;overflow:hidden;display:flex;flex-direction:column}body.messages-active .app-main{flex:1;min-height:0;margin:0;padding:0;max-width:none;overflow:hidden}.conversation-list{border-right:1px solid #e0e0e0;display:flex;flex-direction:column;min-height:0}.conversation-list-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #e0e0e0}.conversation-list-header h2{margin:0;font-size:1.1rem}.conversation-new-btn{background:#4a90d9;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.9rem}.conversation-new-btn:hover{background:#3a7bc4}.conversation-items{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.conversation-item{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;width:100%;padding:.75rem 1rem;background:none;border:none;border-bottom:1px solid #f0f0f0;cursor:pointer;text-align:left}.conversation-item:hover{background:#f7f9fc}.conversation-item.selected{background:#eaf2fb}.conversation-meta{min-width:0;display:flex;flex-direction:column;gap:.15rem}.conversation-title{font-weight:500;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-preview{font-size:.85rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-unread{background:#4a90d9;color:#fff;font-size:.75rem;font-weight:600;padding:.15rem .45rem;border-radius:999px;min-width:1.5rem;text-align:center}.conversation-view{display:flex;flex-direction:column;min-height:0;min-width:0}.conversation-view-empty{display:flex;align-items:center;justify-content:center;flex:1;color:#888}.conversation-pane{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0}.conversation-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #e0e0e0;background:#fafafa;min-width:0}.conversation-header-info{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.conversation-header-info h3{margin:0;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.conversation-header-actions{flex-shrink:0}.conversation-members-btn{background:none;border:none;color:#4a90d9;cursor:pointer;font-size:.9rem;padding:0;white-space:nowrap;flex-shrink:0}.conversation-leave-btn{background:none;border:1px solid #d0d0d0;color:#666;padding:.3rem .7rem;border-radius:4px;cursor:pointer;font-size:.85rem}.conversation-leave-btn:hover{background:#f0f0f0}.conversation-members-panel{border-bottom:1px solid #e0e0e0;padding:.75rem 1rem;background:#f8fafc;max-height:300px;overflow-y:auto}.conversation-members-panel h4{margin:0 0 .5rem;font-size:.9rem;color:#444}.conversation-members-panel ul{list-style:none;margin:0 0 .75rem;padding:0}.conversation-members-panel li{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.9rem}.conversation-members-panel button{margin-left:auto;background:none;border:1px solid #d0d0d0;border-radius:4px;padding:.2rem .6rem;cursor:pointer;font-size:.8rem}.conversation-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.message-row{display:flex;gap:.5rem;align-items:flex-end;max-width:75%}.message-row.mine{align-self:flex-end;flex-direction:row-reverse}.message-bubble{display:flex;flex-direction:column;gap:.15rem;background:#f0f0f0;padding:.5rem .75rem;border-radius:12px;word-wrap:break-word}.message-row.mine .message-bubble{background:#d4e9fa}.message-author{font-size:.75rem;font-weight:600;color:#555}.message-body{white-space:pre-wrap;color:#1a1a1a}.message-deleted{color:#999}.message-composer{display:grid;grid-template-columns:1fr auto auto;grid-template-areas:"input file send";gap:.5rem;align-items:end;padding:.75rem;border-top:1px solid #e0e0e0;background:#fafafa;flex-shrink:0}.message-composer textarea{grid-area:input}.message-composer-file-btn{grid-area:file}.message-composer button[type=submit]{grid-area:send}.message-composer-previews{grid-column:1 / -1}.message-composer textarea{min-width:0;resize:none;border:1px solid #d0d0d0;border-radius:4px;padding:.5rem;font-family:inherit;font-size:.95rem}.message-composer-file{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.message-composer-file-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #d0d0d0;border-radius:4px;background:#fff;color:#555;cursor:pointer;flex-shrink:0}.message-composer-file-btn:hover{background:#f0f0f0;color:#333}.message-composer button[type=submit]{background:#4a90d9;color:#fff;border:none;padding:.4rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;height:36px;flex-shrink:0}.message-composer button[type=submit]:disabled{background:#b0c4de;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:8px;padding:1.5rem;width:90%;max-width:480px;max-height:80vh;overflow-y:auto}.modal h3{margin:0 0 1rem}.modal h4{margin:.75rem 0 .5rem;font-size:.9rem;color:#444}.modal .form-group{margin-bottom:.75rem}.modal .form-group label{display:flex;align-items:center;gap:.4rem;font-size:.95rem}.modal input[type=text]{width:100%;border:1px solid #d0d0d0;border-radius:4px;padding:.4rem .6rem;margin-top:.3rem}.friend-picker{list-style:none;margin:0;padding:0;max-height:220px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:4px}.friend-picker li{border-bottom:1px solid #f0f0f0}.friend-picker li:last-child{border-bottom:none}.friend-picker label{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer}.friend-picker label:hover{background:#f7f9fc}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.modal-actions button{padding:.5rem 1rem;border:1px solid #d0d0d0;border-radius:4px;background:#fff;cursor:pointer}.modal-actions button:last-child{background:#4a90d9;color:#fff;border-color:#4a90d9}.modal-actions button:disabled{opacity:.5;cursor:not-allowed}.conversation-back-btn{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;padding:0 .5rem;margin-right:.25rem;color:#555}@media(max-width:768px){.messages-page{grid-template-columns:1fr;border:none;border-radius:0}.messages-page:not(.has-selected) .conversation-view{display:none}.messages-page.has-selected .conversation-list{display:none}.conversation-back-btn{display:inline-block}.conversation-list,.conversation-view{width:100%}.message-row{max-width:92%}.message-attachment-image{max-width:100%}.message-composer{padding:.5rem}.message-composer textarea{font-size:16px}}.message-avatar-wrap{position:relative}.presence-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;background:#4caf50;border:2px solid #fff}.conversation-online-count{font-weight:400;color:#4caf50}.conversation-typing{padding:.4rem 1rem;font-size:.85rem;color:#888;font-style:italic;background:#fafafa;border-top:1px solid #f0f0f0}.message-attachments{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.4rem}.message-attachment-image{max-width:240px;max-height:240px;border-radius:6px;display:block}.message-composer-previews{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.8rem;color:#555}.message-composer-preview{background:#eef4fa;padding:.2rem .5rem;border-radius:4px}.message-composer-clear{background:none;border:1px solid #d0d0d0;border-radius:4px;padding:.1rem .4rem;font-size:.75rem;cursor:pointer}.message-actions{display:none;gap:.25rem;margin-top:.3rem}.message-row.mine .message-bubble:hover .message-actions,.message-actions:focus-within{display:flex}.message-actions button{background:none;border:1px solid #d0d0d0;border-radius:4px;padding:.1rem .4rem;font-size:.75rem;cursor:pointer;color:#555}.message-edit-form{display:flex;gap:.4rem;align-items:center}.message-edit-form input{flex:1;padding:.3rem .5rem;border:1px solid #d0d0d0;border-radius:4px}.message-edit-form button{background:#4a90d9;color:#fff;border:none;padding:.3rem .6rem;border-radius:4px;font-size:.8rem;cursor:pointer}.message-edit-form button:last-child{background:#fff;color:#555;border:1px solid #d0d0d0}.message-edited-flag{color:#999;font-size:.75rem;font-style:italic}.message-seen-by{display:block;margin-top:.3rem;color:#888;font-size:.75rem}
