.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--gradient-primary)}.auth-card{background:var(--bg-card);border-radius:1rem;padding:2rem;width:100%;max-width:400px;box-shadow:var(--shadow-xl)}.auth-title{font-size:1.75rem;font-weight:700;color:var(--text-heading);margin:0 0 .5rem;text-align:center}.auth-subtitle{color:var(--text-secondary);text-align:center;margin:0 0 1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-error{background:var(--bg-error);color:var(--color-error);padding:.75rem;border-radius:.5rem;font-size:.875rem}.form-group input{padding:.75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.btn{padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s;border:none}.auth-links{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem;text-align:center}.link-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.875rem;padding:.25rem}.link-btn:hover{text-decoration:underline}.layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-body)}.header{background:var(--bg-card);border-bottom:1px solid var(--border-default);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-logo{font-size:1.25rem;font-weight:700;color:var(--text-heading);text-decoration:none;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;gap:.5rem}.nav-link{padding:.5rem 1rem;border-radius:.5rem;text-decoration:none;color:var(--text-secondary);font-weight:500;transition:all .15s}.nav-link:hover{background:var(--bg-subtle);color:var(--text-primary)}.nav-link.active{background:var(--bg-primary-light);color:var(--color-primary)}.header-actions{display:flex;align-items:center;gap:.75rem}.upload-btn{background:var(--gradient-primary);color:var(--text-on-primary);border:none;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:transform .15s,box-shadow .15s}.upload-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.user-menu{position:relative}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{color:var(--text-on-primary);font-size:.75rem;font-weight:600}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-card);border-radius:.75rem;box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;animation:fadeIn .15s ease-out}.menu-user{padding:1rem;display:flex;flex-direction:column;gap:.25rem}.menu-user strong{color:var(--text-heading)}.menu-user span{font-size:.75rem;color:var(--text-secondary)}.menu-user-link{text-decoration:none;border-radius:.5rem;transition:background .15s;cursor:pointer}.menu-user-link:hover{background:var(--bg-subtle)}.menu-user-view{font-size:.7rem;color:var(--color-primary);margin-top:.15rem}.menu-divider{height:1px;background:var(--border-default)}.menu-item{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:var(--text-primary);font-size:.875rem;transition:background .15s}.menu-item:hover{background:var(--bg-subtle)}.menu-install{color:var(--color-primary)}.menu-install:hover{background:var(--bg-primary-light)}.menu-logout{color:var(--color-error)}.menu-logout:hover{background:var(--bg-error)}.main-content{flex:1;padding:1rem 0}.invite-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.invite-content{background:var(--bg-card);border-radius:1rem;padding:2rem;text-align:center;max-width:320px}.invite-content h3{margin:0 0 .5rem;color:var(--text-heading)}.invite-content p{margin:0;color:var(--text-secondary);font-size:.875rem}.invite-code{font-size:2rem;font-weight:700;letter-spacing:.1em;color:var(--color-primary);background:var(--bg-primary-lighter);padding:1rem;border-radius:.5rem;margin:1rem 0}.invite-note{font-size:.75rem;color:var(--text-muted);margin-bottom:1rem!important}.ios-install-content{text-align:left}.ios-install-content h3{text-align:center;margin-bottom:1rem}.ios-install-content>p{margin-bottom:1rem}.ios-install-steps{margin:0 0 1.5rem;padding-left:1.25rem}.ios-install-steps li{margin-bottom:.75rem;color:var(--text-primary);line-height:1.5}.ios-install-steps li:last-child{margin-bottom:0}.ios-install-content .btn{width:100%}@media (max-width: 600px){.header-content{flex-wrap:wrap}.header-logo{font-size:1rem}.header-nav{order:3;width:100%;justify-content:center;padding-top:.5rem;border-top:1px solid var(--border-default);margin-top:.5rem}.nav-link{padding:.4rem 1rem;font-size:.875rem}.upload-btn{padding:.5rem;font-size:.875rem}}.reactions{position:relative}.reactions-list{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.reaction-wrapper{position:relative}.reaction-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--bg-subtle);border:1px solid var(--border-default);border-radius:1rem;cursor:pointer;transition:all .15s}.reaction-badge:hover{background:var(--bg-subtle-hover)}.reaction-badge.reacted{background:var(--bg-primary-light);border-color:var(--color-primary)}.reaction-emoji{font-size:1rem}.reaction-count{font-size:.75rem;color:var(--text-secondary)}.reaction-add{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-subtle);border:1px dashed var(--border-strong);border-radius:50%;cursor:pointer;font-size:1rem;color:var(--text-secondary);transition:all .15s}.reaction-add:hover{background:var(--bg-subtle-hover);border-color:var(--text-muted)}.emoji-picker-container{position:absolute;top:100%;left:0;z-index:1000;margin-top:.5rem;box-shadow:var(--shadow-lg);border-radius:.75rem;background:var(--bg-card)}@media (max-width: 480px){.emoji-picker-container{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);margin-top:0}}.reaction-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:.5rem;background:var(--bg-card);border-radius:.75rem;box-shadow:var(--shadow-menu);padding:.75rem;min-width:140px;z-index:100;animation:tooltipFadeIn .15s ease-out}.reaction-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--bg-card)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.reaction-tooltip-header{display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-default);margin-bottom:.5rem}.reaction-tooltip-emoji{font-size:1.25rem}.reaction-tooltip-count{font-size:.875rem;font-weight:600;color:var(--text-primary)}.reaction-tooltip-users{list-style:none;margin:0;padding:0;max-height:150px;overflow-y:auto}.reaction-tooltip-users li{padding:.25rem 0;font-size:.8125rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reaction-bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);z-index:1000;display:flex;align-items:flex-end;animation:fadeIn .2s ease-out}.reaction-bottom-sheet{width:100%;background:var(--bg-card);border-radius:1.5rem 1.5rem 0 0;padding:.75rem 1.5rem 1.5rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom));animation:slideUp .3s ease-out}.reaction-bottom-sheet-handle{width:36px;height:4px;background:var(--border-strong);border-radius:2px;margin:0 auto 1rem}.reaction-bottom-sheet-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.reaction-bottom-sheet-emoji{font-size:2rem}.reaction-bottom-sheet-title{font-size:1.125rem;font-weight:600;color:var(--text-heading)}.reaction-bottom-sheet-users{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;margin-bottom:1rem}.reaction-bottom-sheet-users li{padding:.75rem 0;font-size:1rem;color:var(--text-primary);border-bottom:1px solid var(--bg-subtle)}.reaction-bottom-sheet-users li:last-child{border-bottom:none}.reaction-bottom-sheet-btn{width:100%;padding:1rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:500;cursor:pointer;background:var(--gradient-primary);color:var(--text-on-primary);transition:transform .15s,box-shadow .15s}.reaction-bottom-sheet-btn:active{transform:scale(.98)}.reaction-bottom-sheet-btn.reacted{background:var(--bg-subtle);color:var(--text-secondary)}.gif-picker{position:absolute;bottom:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:.75rem;box-shadow:var(--shadow-dropdown);z-index:100;margin-bottom:.5rem;display:flex;flex-direction:column;max-height:350px}.gif-picker-header{display:flex;gap:.5rem;padding:.5rem;border-bottom:1px solid var(--border-default)}.gif-picker-search{flex:1;padding:.5rem .75rem;border:1px solid var(--border-strong);border-radius:1rem;font-size:.875rem;outline:none}.gif-picker-search:focus{border-color:var(--color-primary)}.gif-picker-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--text-secondary);padding:0 .5rem;line-height:1}.gif-picker-close:hover{color:var(--text-primary)}.gif-picker-grid{column-count:2;column-gap:4px;padding:4px;overflow-y:auto;flex:1;min-height:0}.gif-picker-grid .gif-picker-item{margin-bottom:4px;break-inside:avoid}.gif-picker-item{background:var(--bg-subtle);border:none;padding:0;cursor:pointer;border-radius:.375rem;overflow:hidden}.gif-picker-item:hover{opacity:.85}.gif-picker-item img{width:100%;display:block}.gif-picker-loading,.gif-picker-empty{grid-column:1 / -1;text-align:center;padding:2rem;color:var(--text-secondary);font-size:.875rem}.gif-picker-attribution{text-align:center;padding:.25rem;font-size:.625rem;color:var(--text-muted);border-top:1px solid var(--border-default)}.emoji-suggestions{position:absolute;bottom:100%;left:0;right:0;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-default);border-radius:.5rem;z-index:100;margin-bottom:.25rem;max-height:200px;overflow-y:auto}.emoji-suggestion{display:flex;align-items:center;gap:.625rem;width:100%;padding:.5rem .75rem;border:none;background:none;cursor:pointer;text-align:left;font-size:.875rem;color:var(--text-primary)}.emoji-suggestion:hover,.emoji-suggestion.selected{background:var(--bg-subtle)}.emoji-suggestion-native{font-size:1.25rem;width:1.75rem;text-align:center;flex-shrink:0}.emoji-suggestion-name{color:var(--text-secondary);font-size:.8rem}.mention-input-wrapper{position:relative;flex:1}.mention-input-wrapper input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-strong);border-radius:1rem;font-size:.875rem;box-sizing:border-box}.mention-input-wrapper input:focus{outline:none;border-color:var(--color-primary)}.mention-suggestions{position:absolute;bottom:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border-default);border-radius:.75rem;box-shadow:var(--shadow-dropdown);z-index:101;margin-bottom:.25rem;max-height:260px;overflow-y:auto;padding:.375rem 0}.mention-suggestion{display:flex;align-items:center;gap:.75rem;width:90%;padding:.75rem 1rem;border:none;background:none;cursor:pointer;text-align:left;font-size:.9375rem;border-radius:0;margin:0 auto;margin-top:.5rem}.mention-suggestion:hover{background:var(--bg-subtle)}.mention-suggestion-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-avatar-placeholder);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.mention-suggestion-avatar img{width:100%;height:100%;object-fit:cover}.mention-suggestion-avatar span{color:var(--text-on-primary);font-size:.55rem;font-weight:600}.mention-suggestion-name{color:var(--text-primary);font-weight:400}.mention-link{color:var(--color-mention-link);font-weight:600;text-decoration:none}.mention-link:hover{text-decoration:underline}.admin-panel{max-width:900px;margin:0 auto;padding:0 1rem}.admin-header{margin-bottom:1.5rem}.admin-header h1{font-size:1.5rem;color:var(--text-heading);margin:0 0 1rem}.admin-tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--border-default);padding-bottom:0}.admin-tab{padding:.5rem 1rem;border:none;background:none;color:var(--text-secondary);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-loading{text-align:center;padding:2rem;color:var(--text-secondary)}.admin-user-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.admin-user-card{background:var(--bg-card);border-radius:.75rem;padding:1rem;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.admin-user-info{display:flex;gap:.75rem;align-items:flex-start;min-width:0;flex:1}.admin-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.admin-user-avatar img{width:100%;height:100%;object-fit:cover}.admin-user-avatar span{color:var(--text-on-primary);font-size:.875rem;font-weight:600}.admin-user-details{min-width:0}.admin-user-name{font-weight:600;color:var(--text-heading);display:flex;align-items:center;gap:.5rem}.admin-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--gradient-primary);color:var(--text-on-primary);padding:.125rem .5rem;border-radius:1rem}.admin-user-email{font-size:.8125rem;color:var(--text-secondary)}.admin-user-meta{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.admin-user-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.btn-admin{padding:.375rem .75rem;border:1px solid var(--border-default);border-radius:.5rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--bg-card);color:var(--text-primary)}.btn-admin:hover{background:var(--bg-subtle)}.btn-admin:disabled{opacity:.5;cursor:not-allowed}.btn-promote{color:var(--color-primary);border-color:var(--color-primary)}.btn-promote:hover{background:var(--bg-primary-light)}.btn-demote{color:var(--color-warning);border-color:var(--color-warning)}.btn-demote:hover{background:var(--bg-warning)}.btn-danger{color:var(--color-error);border-color:var(--color-error)}.btn-cancel{color:var(--text-secondary)}.admin-confirm-delete{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--color-error)}.admin-stats{margin-top:1rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.admin-stat-card{background:var(--bg-card);border-radius:.75rem;padding:1.25rem;box-shadow:var(--shadow-sm);text-align:center}.admin-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-heading);margin-bottom:.25rem}.admin-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 600px){.admin-user-card{flex-direction:column}.admin-user-actions{width:100%;justify-content:flex-end}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-confirm-delete{flex-wrap:wrap}}.admin-delete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.admin-delete-modal{background:var(--bg-card);border-radius:.75rem;padding:1.5rem;max-width:420px;width:100%;box-shadow:var(--shadow-xl)}.admin-delete-modal h3{margin:0 0 .5rem;color:var(--color-error);font-size:1.125rem}.admin-delete-desc{color:var(--text-primary);font-size:.875rem;margin:0 0 1rem;line-height:1.4}.admin-delete-reason{width:100%;border:1px solid var(--border-strong);border-radius:.5rem;padding:.75rem;font-size:.875rem;resize:vertical;font-family:inherit;margin-bottom:1rem;box-sizing:border-box}.admin-delete-reason:focus{outline:none;border-color:var(--color-primary)}.admin-delete-actions{display:flex;gap:.5rem;justify-content:flex-end}.admin-delete-cancel-btn{background:var(--bg-subtle);border:none;color:var(--text-primary);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem}.admin-delete-cancel-btn:hover{background:var(--bg-subtle-hover)}.admin-delete-confirm-btn{background:var(--color-error);border:none;color:var(--text-on-primary);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem}.admin-delete-confirm-btn:hover{background:var(--color-error-hover)}.admin-delete-confirm-btn:disabled,.admin-delete-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.comments{margin-top:.75rem}.comments-loading{color:var(--text-secondary);font-size:.875rem;padding:.5rem 0}.comments-show-more{background:none;border:none;color:var(--color-primary);font-size:.875rem;cursor:pointer;padding:.25rem 0;margin-bottom:.5rem;display:block}.comments-show-more:hover{color:var(--color-primary-hover);text-decoration:underline}.comments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.75rem}.comment{display:flex;gap:.5rem}.comment-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.comment-avatar img{width:100%;height:100%;object-fit:cover}.comment-avatar span{color:var(--text-on-primary);font-size:.625rem;font-weight:600}.comment-body{flex:1;min-width:0;background:var(--bg-subtle);border-radius:.75rem;padding:.5rem .75rem;overflow-wrap:break-word;word-break:break-word}.comment-header{display:flex;align-items:baseline;gap:.5rem}.comment-name{font-size:.875rem;font-weight:600;color:var(--text-heading)}.comment-name-link{text-decoration:none;color:var(--text-heading);transition:color .15s}.comment-name-link:hover{color:var(--color-primary)}.comment-avatar-link{text-decoration:none;transition:transform .15s}.comment-avatar-link:hover{transform:scale(1.1)}.comment-time{font-size:.625rem;color:var(--text-muted)}.comment-content{margin:.25rem 0 0;font-size:.875rem;color:var(--text-primary);line-height:1.4}.comment-actions{display:flex;gap:.5rem;margin-top:.25rem}.comment-actions>button,.comment-edit-btns button{background:none;border:none;color:var(--text-secondary);font-size:.75rem;cursor:pointer;padding:0}.comment-actions>button:hover,.comment-edit-btns button:hover{color:var(--text-primary)}.comment-reactions{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.comment-reaction-badge{display:flex;align-items:center;gap:.2rem;padding:.2rem .4rem;border-radius:1rem;background:var(--bg-subtle);border:1px solid var(--border-default);font-size:.8rem;cursor:pointer;transition:all .15s}.comment-reaction-badge:hover{background:var(--bg-subtle-hover)}.comment-reaction-badge.reacted{background:var(--bg-primary-light);border-color:var(--color-primary);color:var(--text-primary)}.comment-reaction-count{font-size:.7rem;color:var(--text-secondary)}.comment-reaction-add{width:24px;height:24px;border-radius:50%;background:var(--bg-subtle);border:1px dashed var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .15s}.comment-reaction-add:hover{background:var(--bg-subtle-hover);border-color:var(--text-muted)}.comment-edit-btns{display:flex;gap:.5rem;margin-left:auto}.comment-emoji-picker{position:absolute;z-index:1000;margin-top:.25rem}.comment-edit{margin-top:.25rem}.comment-edit input{width:100%;padding:.375rem .5rem;border:1px solid var(--border-strong);border-radius:.375rem;font-size:.875rem}.comment-edit-actions{display:flex;gap:.5rem;margin-top:.375rem}.comment-edit-actions button{background:none;border:none;font-size:.75rem;cursor:pointer;color:var(--color-primary)}.comment-gif{margin:.25rem 0;max-width:200px}.comment-gif img{width:100%;border-radius:.5rem;display:block}.comment-form-wrapper{position:relative}.comment-form{display:flex;gap:.5rem}.comment-extras{display:flex;gap:.5rem;margin-top:.375rem}.comment-gif-btn{background:var(--bg-subtle-hover);color:var(--text-primary);border:none;padding:.25rem .625rem;border-radius:1rem;font-size:.75rem;font-weight:700;cursor:pointer;transition:background .15s}.comment-gif-btn:hover{background:var(--border-strong)}.comment-form .mention-input-wrapper{flex:1}.comment-form>button{background:var(--color-primary);color:var(--text-on-primary);border:none;padding:.5rem 1rem;border-radius:1rem;font-size:.875rem;cursor:pointer;transition:background .15s}.comment-form>button:hover:not(:disabled){background:var(--color-primary-hover)}.comment-form>button:disabled{opacity:.5;cursor:not-allowed}.social-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);z-index:1100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .15s ease-out}.social-sheet{background:var(--bg-card);border-radius:1rem 1rem 0 0;width:100%;max-width:600px;max-height:75vh;display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.social-sheet-handle-area{padding:.75rem 0 .5rem;cursor:grab;touch-action:none;flex-shrink:0;user-select:none;-webkit-user-select:none}.social-sheet-handle-area:active{cursor:grabbing}.social-sheet-handle{width:36px;height:4px;background:var(--border-strong);border-radius:2px;margin:0 auto}.social-sheet-section{padding:.75rem 1rem;border-bottom:1px solid var(--border-default);flex-shrink:0}.social-sheet-section h3{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:var(--text-heading)}.social-sheet-count{font-weight:400;color:var(--text-secondary)}.social-sheet-reactions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.social-sheet-reaction{display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;border-radius:2rem;background:var(--bg-subtle);border:1.5px solid transparent;font-size:.9rem;cursor:pointer;transition:all .15s}.social-sheet-reaction:hover{background:var(--bg-subtle-hover)}.social-sheet-reaction.reacted{background:var(--bg-primary-light);border-color:var(--color-primary)}.social-sheet-reaction-count{font-size:.8rem;color:var(--text-secondary)}.social-sheet-reaction-add{width:32px;height:32px;border-radius:50%;background:var(--bg-subtle);border:none;font-size:1.125rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.social-sheet-reaction-add:hover{background:var(--bg-subtle-hover)}.social-sheet-emoji-picker{margin-top:.5rem}.social-sheet-comments-section{flex:1;min-height:0;overflow-y:auto;border-bottom:none}.social-sheet-comments-list{display:flex;flex-direction:column;gap:.75rem}.social-sheet-empty{color:var(--text-muted);font-size:.875rem;margin:0;padding:1rem 0;text-align:center}.social-sheet-comment{display:flex;gap:.5rem}.social-sheet-comment-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;text-decoration:none}.social-sheet-comment-avatar img{width:100%;height:100%;object-fit:cover}.social-sheet-comment-avatar span{color:var(--text-on-primary);font-size:.625rem;font-weight:600}.social-sheet-comment-body{flex:1;min-width:0;background:var(--bg-subtle);border-radius:.75rem;padding:.5rem .75rem;overflow-wrap:break-word;word-break:break-word}.social-sheet-comment-header{display:flex;align-items:baseline;gap:.5rem}.social-sheet-comment-name{font-size:.875rem;font-weight:600;color:var(--text-heading)}.social-sheet-comment-time{font-size:.625rem;color:var(--text-muted)}.social-sheet-comment-text{margin:.25rem 0 0;font-size:.875rem;color:var(--text-primary);line-height:1.4}.social-sheet-comment-gif{margin:.25rem 0;max-width:200px}.social-sheet-comment-gif img{width:100%;border-radius:.5rem;display:block}.social-sheet-comment-reactions{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;margin-top:.25rem}.social-sheet-comment-reaction{display:inline-flex;align-items:center;gap:.125rem;padding:.125rem .375rem;border-radius:1rem;background:var(--bg-subtle-hover);border:1px solid transparent;font-size:.75rem;cursor:pointer;transition:all .15s}.social-sheet-comment-reaction:hover{background:var(--border-strong)}.social-sheet-comment-reaction.reacted{background:var(--bg-primary-light);border-color:var(--color-primary)}.social-sheet-comment-reaction-add{width:22px;height:22px;border-radius:50%;background:var(--bg-subtle-hover);border:none;font-size:.75rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.social-sheet-comment-reaction-add:hover{background:var(--border-strong)}.social-sheet-comment-emoji-picker{margin-top:.25rem}.social-sheet-input{padding:.75rem 1rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom));border-top:1px solid var(--border-default);flex-shrink:0;position:relative}.social-sheet-form{display:flex;gap:.5rem}.social-sheet-form .mention-input-wrapper{flex:1}.social-sheet-form button{background:var(--color-primary);color:var(--text-on-primary);border:none;padding:.5rem 1rem;border-radius:1rem;font-size:.875rem;cursor:pointer;transition:background .15s;flex-shrink:0}.social-sheet-form button:hover:not(:disabled){background:var(--color-primary-hover)}.social-sheet-form button:disabled{opacity:.5;cursor:not-allowed}.social-sheet-gif-btn{background:var(--bg-subtle-hover);color:var(--text-primary);border:none;padding:.25rem .625rem;border-radius:1rem;font-size:.75rem;font-weight:700;cursor:pointer;margin-top:.375rem;transition:background .15s}.social-sheet-gif-btn:hover{background:var(--border-strong)}.photo-viewer-social-bar{display:flex;gap:.75rem;align-items:center}.photo-viewer-social-btn{display:flex;align-items:center;gap:.375rem;background:#ffffff1a;border:none;color:var(--text-on-primary);padding:.5rem .75rem;border-radius:2rem;font-size:.8rem;cursor:pointer;transition:background .15s}.photo-viewer-social-btn:hover{background:#fff3}.photo-viewer-social-btn .social-icon{font-size:1rem}.photo-viewer-social-btn .social-count{font-weight:500}.photo-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.photo-viewer-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.photo-viewer-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;z-index:10;transition:background .2s}.photo-viewer-close:hover{background:#fff3}.photo-viewer-image{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:3.5rem 1rem 1rem;overflow:hidden;touch-action:none;user-select:none;-webkit-user-select:none}.photo-viewer-image img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none;will-change:transform;transform-origin:center center}.photo-viewer-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;width:50px;height:50px;border-radius:50%;font-size:2rem;cursor:pointer;transition:background .2s}.photo-viewer-nav:hover{background:#fff3}.photo-viewer-prev{left:1rem}.photo-viewer-next{right:1rem}.photo-viewer-footer{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:1rem;padding-bottom:max(1rem,env(safe-area-inset-bottom));background:#00000080}.photo-viewer-info{display:flex;flex-direction:column;gap:.25rem}.photo-viewer-name{color:#fff;font-size:.875rem}.photo-viewer-count{color:#ffffffb3;font-size:.75rem}.photo-viewer-actions{display:flex;gap:.5rem;align-items:center}.photo-viewer-download{background:var(--color-primary);border:none;color:#fff;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:background .2s}.photo-viewer-download:hover{background:var(--color-primary-hover)}.photo-viewer-delete{background:transparent;border:1px solid var(--color-error);color:var(--color-error);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s}.photo-viewer-delete:hover{background:var(--color-error);color:#fff}.photo-viewer-confirm-delete{display:flex;gap:.5rem}.photo-viewer-delete-confirm{background:var(--color-error);border:none;color:#fff;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem}.photo-viewer-delete-confirm:disabled{opacity:.5;cursor:not-allowed}.photo-viewer-delete-cancel{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem}@media (max-width: 600px){.photo-viewer-image{padding:3rem .5rem .5rem}.photo-viewer-nav{width:40px;height:40px;font-size:1.5rem}.photo-viewer-prev{left:.5rem}.photo-viewer-next{right:.5rem}}.emoji-textarea-wrapper{position:relative;width:100%}.emoji-textarea-wrapper textarea{width:100%;border:1px solid var(--border-strong);border-radius:.5rem;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;resize:vertical;line-height:1.5;box-sizing:border-box}.emoji-textarea-wrapper textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--focus-ring-strong)}.emoji-textarea-wrapper .emoji-suggestions{bottom:auto;top:100%;margin-bottom:0;margin-top:.25rem}.photo-card{background:var(--bg-card);border-radius:1rem;box-shadow:var(--shadow-md)}.photo-card-header{display:flex;align-items:center;gap:.75rem;padding:1rem;position:relative}.photo-card-admin-delete{margin-left:auto;background:none;border:none;color:var(--color-error);font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;opacity:.5;transition:opacity .2s}.photo-card-admin-delete:hover{opacity:1;background:var(--bg-error)}.photo-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;overflow:hidden}.photo-card-avatar img{width:100%;height:100%;object-fit:cover}.photo-card-avatar span{color:var(--text-on-primary);font-size:.875rem;font-weight:600}.photo-card-info{display:flex;flex-direction:column}.photo-card-name{font-weight:600;color:var(--text-heading)}.photo-card-name-link{text-decoration:none;color:var(--text-heading);transition:color .15s}.photo-card-name-link:hover{color:var(--color-primary)}.photo-card-avatar-link{text-decoration:none;transition:transform .15s,box-shadow .15s}.photo-card-avatar-link:hover{transform:scale(1.05);box-shadow:0 2px 8px #667eea4d}.photo-card-time{font-size:.75rem;color:var(--text-secondary)}.photo-card-grid{display:grid;gap:2px;overflow:hidden;position:relative}.photo-count-1{grid-template-columns:1fr}.photo-count-2{grid-template-columns:1fr 1fr}.photo-count-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr}.photo-count-3 .photo-card-image:first-child{grid-row:span 2}.photo-count-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.photo-card-image{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer}.photo-count-1 .photo-card-image{aspect-ratio:4/3}.photo-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.photo-card-image:hover img{transform:scale(1.05)}.photo-card-more{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;color:var(--text-on-primary);font-size:1.5rem;font-weight:600}.photo-card-album-context{font-size:.8rem;color:var(--text-secondary)}.photo-card-album-link{color:var(--color-primary);text-decoration:none;font-weight:500}.photo-card-album-link:hover{text-decoration:underline}.photo-card-caption{padding:.75rem 1rem;margin:0;color:var(--text-primary);line-height:1.5;overflow-wrap:break-word;word-break:break-word}.photo-card-actions{padding:0 1rem 1rem}.photo-interactions{border-top:1px solid var(--border-default);padding-top:.75rem;margin-top:.75rem}.photo-interactions:first-child{border-top:none;margin-top:0}.photo-card-heart-animation{position:absolute;transform:translate(-50%,-50%);font-size:4rem;pointer-events:none;z-index:5;animation:heart-pop .8s ease-out forwards}@keyframes heart-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.3)}30%{transform:translate(-50%,-50%) scale(1)}70%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.4)}}.photo-card-menu-wrapper{margin-left:auto;position:relative}.photo-card-menu-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;color:var(--text-secondary);transition:background .2s,color .2s;line-height:1}.photo-card-menu-btn:hover{background:var(--bg-subtle);color:var(--text-primary)}.photo-card-menu{position:absolute;top:100%;right:0;background:var(--bg-card);border-radius:.5rem;box-shadow:var(--shadow-menu);z-index:10;min-width:150px;overflow:hidden}.photo-card-menu button{display:block;width:100%;padding:.625rem 1rem;border:none;background:none;text-align:left;cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background .15s}.photo-card-menu button:hover{background:var(--bg-subtle)}.photo-card-menu-delete{color:var(--color-error)!important}.photo-card-menu-delete:hover{background:var(--bg-error)!important}.photo-card-caption-edit{padding:.75rem 1rem}.photo-card-caption-edit-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.photo-card-caption-cancel{padding:.375rem .75rem;border:1px solid var(--border-strong);border-radius:.375rem;background:var(--bg-card);color:var(--text-secondary);font-size:.8rem;cursor:pointer}.photo-card-caption-cancel:hover{background:var(--bg-subtle)}.photo-card-caption-save{padding:.375rem .75rem;border:none;border-radius:.375rem;background:var(--color-primary);color:var(--text-on-primary);font-size:.8rem;cursor:pointer}.photo-card-caption-save:hover{background:var(--color-primary-hover)}.photo-card-caption-save:disabled{opacity:.6;cursor:not-allowed}.photo-card-delete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.photo-card-delete-confirm{background:var(--bg-card);border-radius:.75rem;padding:1.5rem;max-width:400px;width:100%;box-shadow:var(--shadow-xl)}.photo-card-delete-confirm h3{margin:0 0 .5rem;color:var(--text-heading)}.photo-card-delete-confirm p{margin:0 0 1.25rem;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.photo-card-delete-confirm-actions{display:flex;justify-content:flex-end;gap:.5rem}.photo-card-delete-confirm-cancel{padding:.5rem 1rem;border:1px solid var(--border-strong);border-radius:.375rem;background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:.875rem}.photo-card-delete-confirm-cancel:hover{background:var(--bg-subtle)}.photo-card-delete-confirm-delete{padding:.5rem 1rem;border:none;border-radius:.375rem;background:var(--color-error);color:var(--text-on-primary);cursor:pointer;font-size:.875rem}.photo-card-delete-confirm-delete:hover{background:var(--color-error-hover)}.photo-card-delete-confirm-delete:disabled{opacity:.6;cursor:not-allowed}.albums-page{padding:1rem;max-width:1200px;margin:0 auto}.albums-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.albums-header h1{margin:0;font-size:1.5rem;color:var(--text-heading)}.albums-loading,.albums-error,.albums-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-secondary)}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.album-card{background:var(--bg-card);border-radius:1rem;box-shadow:var(--shadow-md);overflow:hidden;transition:transform .2s,box-shadow .2s}.album-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-menu)}.album-card.in-feed{max-width:100%;overflow:visible;transform:none!important}.album-card-header{display:flex;align-items:center;gap:.75rem;padding:1rem}.album-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;overflow:hidden}.album-card-avatar img{width:100%;height:100%;object-fit:cover}.album-card-avatar span{color:var(--text-on-primary);font-size:.875rem;font-weight:600}.album-card-info{display:flex;flex-wrap:wrap;gap:.25rem;align-items:baseline}.album-card-name{font-weight:600;color:var(--text-heading)}.album-card-name-link{text-decoration:none;color:var(--text-heading);transition:color .15s}.album-card-name-link:hover{color:var(--color-primary)}.album-card-avatar-link{text-decoration:none;transition:transform .15s,box-shadow .15s}.album-card-avatar-link:hover{transform:scale(1.05);box-shadow:0 2px 8px var(--focus-ring-strong)}.album-card-action{color:var(--text-secondary);font-size:.875rem}.album-card-time{font-size:.75rem;color:var(--text-muted)}.album-card-link{text-decoration:none;color:inherit;display:block}.album-card-cover{aspect-ratio:16/9;background:var(--bg-subtle);overflow:hidden}.album-card-cover img{width:100%;height:100%;object-fit:cover}.album-card-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;height:100%}.album-card-preview-grid img{width:100%;height:100%;object-fit:cover}.album-card-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.album-card-details{padding:1rem}.album-card-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-heading)}.album-card-description{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.album-card-count{font-size:.75rem;color:var(--text-muted);margin-top:.5rem;display:block}.album-card-social{padding:.5rem 1rem 1rem;border-top:1px solid var(--border-default)}.create-album-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.create-album-content{background:var(--bg-card);border-radius:1rem;width:100%;max-width:400px}.create-album-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-default)}.create-album-header h2{margin:0;font-size:1.25rem}.create-album-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer}.create-album-content form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.create-album-content textarea{width:100%;padding:.75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-family:inherit;font-size:.875rem;resize:none}.create-album-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.create-album-error{margin-top:1rem;padding:.75rem;background:var(--bg-error);color:var(--color-error);border-radius:.5rem;font-size:.875rem}.album-detail{padding:1rem;max-width:1200px;margin:0 auto}.album-detail-loading,.album-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;gap:1rem}.album-detail-header{margin-bottom:1.5rem}.back-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:1rem;padding:0;margin-bottom:1rem}.album-detail-info h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--text-heading)}.album-detail-info p{margin:0 0 .5rem;color:var(--text-secondary)}.album-detail-meta{font-size:.875rem;color:var(--text-muted)}.album-detail-actions{display:flex;gap:.75rem;margin-top:1rem}.btn-danger{background:var(--bg-error);color:var(--color-error)}.btn-danger:hover{background:var(--bg-error)}.album-edit-form{display:flex;flex-direction:column;gap:1rem}.album-edit-form input,.album-edit-form textarea{padding:.75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-family:inherit;font-size:1rem}.album-edit-actions{display:flex;gap:.75rem}.album-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.album-photo{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;cursor:pointer}.album-photo img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.album-photo:hover img{transform:scale(1.05)}.album-photo-remove{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;background:var(--overlay-backdrop);border:none;color:#fff;cursor:pointer;font-size:1rem;opacity:0;transition:opacity .2s}.album-photo:hover .album-photo-remove{opacity:1}.album-empty{text-align:center;padding:3rem;color:var(--text-secondary)}.add-photos-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-photos-content{background:var(--bg-card);border-radius:1rem;width:100%;max-width:700px;max-height:80vh;display:flex;flex-direction:column}.add-photos-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-default)}.add-photos-header h2{margin:0;font-size:1.25rem}.add-photos-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer}.add-photos-loading,.add-photos-empty{padding:3rem;text-align:center;color:var(--text-secondary)}.add-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));grid-auto-rows:min-content;gap:.5rem;padding:1rem;overflow-y:auto;flex:1;min-height:0}.add-photos-item{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;cursor:pointer;border:2px solid transparent}.add-photos-img-wrapper{width:100%;height:100%}.add-photos-img-wrapper img{width:100%;height:100%;object-fit:cover}.add-photos-img-placeholder{width:100%;height:100%;background:var(--bg-subtle)}.add-photos-item img{width:100%;height:100%;object-fit:cover}.add-photos-loading-more{grid-column:1 / -1;text-align:center;padding:1rem}.add-photos-loading-more .spinner{width:24px;height:24px;border:2px solid var(--border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.add-photos-item.selected{border-color:var(--color-primary)}.add-photos-checkbox{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border-radius:50%;background:var(--bg-card);border:2px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:.875rem;color:var(--color-primary)}.add-photos-item.selected .add-photos-checkbox{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-on-primary)}.add-photos-actions{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid var(--border-default)}.add-photos-count{font-size:.875rem;color:var(--text-secondary)}.add-photos-buttons{display:flex;gap:.75rem}.add-photos-tabs{display:flex;border-bottom:1px solid var(--border-default)}.add-photos-tab{flex:1;padding:.75rem 1rem;background:none;border:none;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s;border-bottom:2px solid transparent;margin-bottom:-1px}.add-photos-tab:hover{color:var(--text-primary);background:var(--bg-card)}.add-photos-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.add-photos-dropzone{margin:1rem;border:2px dashed var(--border-strong);border-radius:.75rem;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.add-photos-dropzone:hover,.add-photos-dropzone.active{border-color:var(--color-primary);background:var(--bg-primary-lighter)}.add-photos-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.add-photos-dropzone-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-primary-light);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-primary)}.add-photos-dropzone p{margin:0;color:var(--text-primary);font-weight:500}.add-photos-dropzone span{font-size:.75rem;color:var(--text-muted)}.album-private-badge{display:inline-flex;align-items:center;gap:.25rem;background:var(--bg-subtle);color:var(--text-secondary);font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:1rem;white-space:nowrap}.album-detail-title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.album-detail-title-row h1{margin:0}.album-members-row{display:flex;align-items:center;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.album-members-label{font-size:.875rem;color:var(--text-secondary)}.album-members-avatars{display:flex;gap:.25rem;flex-wrap:wrap}.album-member-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:.75rem;color:var(--text-on-primary);font-weight:600}.album-member-avatar img{width:100%;height:100%;object-fit:cover}.album-privacy-controls{display:flex;align-items:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.album-switch-label{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:var(--text-primary);cursor:pointer}.album-switch-label input[type=checkbox]{display:none}.album-switch-track{position:relative;width:44px;height:24px;background:var(--border-strong);border-radius:12px;transition:background .2s;flex-shrink:0}.album-switch-label input:checked+.album-switch-track{background:var(--color-primary)}.album-switch-track:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--bg-card);border-radius:50%;transition:transform .2s;box-shadow:var(--shadow-sm)}.album-switch-label input:checked+.album-switch-track:after{transform:translate(20px)}.album-switch-tooltip{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--bg-subtle-hover);color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:help;position:relative;flex-shrink:0;margin-left:.25rem}.album-switch-tooltip-text{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-tooltip);color:var(--text-on-primary);font-size:.8rem;font-weight:400;padding:.5rem .75rem;border-radius:.5rem;width:220px;line-height:1.4;text-align:center;z-index:10;box-shadow:var(--shadow-dropdown)}.album-switch-tooltip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border-tooltip)}.album-switch-tooltip:hover .album-switch-tooltip-text,.album-switch-tooltip:focus .album-switch-tooltip-text{display:block}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.album-user-results{display:flex;flex-direction:column;border:1px solid var(--border-default);border-radius:.5rem;margin-top:.25rem;max-height:150px;overflow-y:auto}.album-user-result{background:none;border:none;padding:.5rem .75rem;text-align:left;cursor:pointer;font-size:.875rem;color:var(--text-primary)}.album-user-result:hover{background:var(--bg-subtle)}.album-member-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.album-member-chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--bg-primary-light);color:var(--color-member-chip);padding:.25rem .5rem;border-radius:1rem;font-size:.8rem;font-weight:500}.album-member-chip button{background:none;border:none;color:var(--color-member-chip);cursor:pointer;font-size:1rem;padding:0;line-height:1}.album-card-lock{font-size:.875rem}.add-photos-remove{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border-radius:50%;background:var(--overlay-backdrop);border:none;color:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}.events-page{max-width:700px;margin:0 auto;padding:0 1rem}.events-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.events-tabs{display:flex;gap:.25rem;background:var(--bg-subtle);border-radius:.5rem;padding:.25rem}.events-tab{padding:.5rem 1.25rem;border:none;background:none;border-radius:.375rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.events-tab.active{background:var(--bg-card);color:var(--text-heading);box-shadow:var(--shadow-sm)}.events-create-btn{background:var(--gradient-primary);color:var(--text-on-primary);border:none;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;font-size:.875rem;transition:transform .15s,box-shadow .15s}.events-create-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--focus-ring-strong)}.events-loading{display:flex;justify-content:center;padding:3rem}.events-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.events-empty .events-create-btn{margin-top:1rem}.events-list{display:flex;flex-direction:column;gap:1rem}.event-card{background:var(--bg-card);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .15s,transform .15s}.event-card:hover{box-shadow:var(--shadow-dropdown);transform:translateY(-1px)}.event-card-image{height:160px;overflow:hidden}.event-card-image img{width:100%;height:100%;object-fit:cover}.event-card-body{padding:1rem 1.25rem}.event-card-date{font-size:.8125rem;font-weight:600;color:var(--color-primary);margin-bottom:.25rem}.event-card-title{margin:0 0 .25rem;font-size:1.125rem;color:var(--text-heading)}.event-card-time{font-size:.8125rem;color:var(--text-secondary);margin-bottom:.5rem}.event-card-location{font-size:.8125rem;color:var(--color-primary);margin-bottom:.5rem}.event-location-link{color:var(--color-primary);text-decoration:none}.event-location-link:hover{text-decoration:underline}.event-card-desc{margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--bg-subtle)}.event-card-responses{display:flex;gap:.75rem;font-size:.8125rem}.event-count-attending{color:var(--color-success-hover)}.event-count-declined{color:var(--text-muted)}.event-status-badge{font-size:.75rem;font-weight:500;padding:.25rem .625rem;border-radius:1rem}.event-status-attending{background:var(--bg-success);color:var(--text-success-badge)}.event-status-declined{background:var(--bg-error);color:var(--text-error-badge)}.event-status-pending{background:var(--bg-warning);color:var(--text-warning-badge)}.event-status-cancelled{background:var(--bg-subtle);color:var(--text-secondary)}.event-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.event-modal{background:var(--bg-card);border-radius:1rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.event-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-default)}.event-modal-header h2{margin:0;font-size:1.125rem;color:var(--text-heading)}.event-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.event-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.event-form-field label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-primary);margin-bottom:.375rem}.event-form-field input[type=text],.event-form-field input[type=url],.event-form-field input[type=date],.event-form-field input[type=time],.event-form-field textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-size:.875rem;box-sizing:border-box}.event-form-field textarea{resize:vertical}.event-form-field input:focus,.event-form-field textarea:focus{outline:none;border-color:var(--color-primary)}.event-form-row{display:flex;gap:1rem}.event-form-row .event-form-field{flex:1}.event-checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer}.event-checkbox-label input[type=checkbox]{width:1rem;height:1rem}.event-image-upload-btn{background:var(--bg-subtle);border:1px dashed var(--border-strong);border-radius:.5rem;padding:1rem;width:100%;cursor:pointer;color:var(--text-secondary);font-size:.875rem}.event-image-preview{position:relative;border-radius:.5rem;overflow:hidden;cursor:pointer}.event-image-preview img{width:100%;max-height:200px;object-fit:cover;display:block}.event-image-remove{position:absolute;top:.5rem;right:.5rem;background:var(--overlay-backdrop);color:#fff;border:none;border-radius:50%;width:28px;height:28px;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.event-user-results{margin-top:.5rem;border:1px solid var(--border-default);border-radius:.5rem;overflow:hidden}.event-user-result{display:block;width:100%;padding:.625rem .75rem;border:none;background:none;text-align:left;cursor:pointer;font-size:.875rem;color:var(--text-primary)}.event-user-result:hover{background:var(--bg-subtle)}.event-invitee-chips{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.event-invitee-chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--bg-primary-light);color:var(--color-member-chip);padding:.25rem .5rem;border-radius:1rem;font-size:.8125rem}.event-invitee-chip button{background:none;border:none;color:var(--color-member-chip);cursor:pointer;font-size:.875rem;padding:0;line-height:1}.event-form-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.event-btn-cancel{padding:.625rem 1.25rem;border:1px solid var(--border-strong);background:var(--bg-card);border-radius:.5rem;color:var(--text-primary);cursor:pointer;font-size:.875rem}.event-btn-submit{padding:.625rem 1.25rem;border:none;background:var(--gradient-primary);color:var(--text-on-primary);border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500}.event-btn-submit:disabled{opacity:.5;cursor:not-allowed}.event-detail-page{max-width:700px;margin:0 auto;padding:0 1rem}.event-back-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.875rem;padding:.5rem 0;margin-bottom:.5rem}.event-detail-card{background:var(--bg-card);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm)}.event-detail-image{max-height:300px;overflow:hidden}.event-detail-image img{width:100%;height:100%;object-fit:cover}.event-detail-body{padding:1.5rem}.event-detail-title{margin:0 0 1rem;font-size:1.5rem;color:var(--text-heading)}.event-detail-meta{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;background:var(--bg-card);border-radius:.5rem}.event-detail-meta-row{display:flex;gap:.75rem;font-size:.875rem}.event-meta-label{font-weight:600;color:var(--text-primary);min-width:80px}.event-detail-desc{margin:0 0 1.5rem;font-size:.9375rem;color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.event-detail-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.event-calendar-btn{background:var(--bg-subtle);border:1px solid var(--border-strong);border-radius:.5rem;padding:.625rem 1rem;cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background .15s}.event-calendar-btn:hover{background:var(--bg-subtle-hover)}.event-rsvp{margin-bottom:1.5rem}.event-rsvp h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-heading)}.event-rsvp-buttons{display:flex;gap:.75rem}.event-rsvp-btn{flex:1;padding:.75rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.event-rsvp-attend{background:var(--bg-card);border:2px solid var(--color-success-hover);color:var(--color-success-hover)}.event-rsvp-attend:hover,.event-rsvp-attend.active{background:var(--color-success-hover);color:var(--text-on-primary)}.event-rsvp-decline{background:var(--bg-card);border:2px solid var(--color-error);color:var(--color-error)}.event-rsvp-decline:hover,.event-rsvp-decline.active{background:var(--color-error);color:var(--text-on-primary)}.event-respond-form{margin-bottom:1.5rem;padding:1rem;background:var(--bg-card);border-radius:.5rem}.event-respond-form h3{margin:0 0 .75rem;font-size:.9375rem}.event-respond-form textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-size:.875rem;resize:vertical;box-sizing:border-box;margin-bottom:.75rem}.event-respond-form textarea:focus{outline:none;border-color:var(--color-primary)}.event-respond-actions{display:flex;gap:.75rem;justify-content:flex-end}.event-responses-summary{display:flex;gap:1.5rem;margin-bottom:1.5rem}.event-response-group{position:relative;display:flex;align-items:center;gap:.375rem;cursor:pointer;padding:.5rem 0}.event-response-count{font-size:1.25rem;font-weight:700}.event-response-attending-group .event-response-count{color:var(--color-success-hover)}.event-response-declined-group .event-response-count{color:var(--color-error)}.event-response-label{font-size:.8125rem;color:var(--text-secondary)}.event-response-tooltip{display:none;position:absolute;bottom:100%;left:0;background:var(--bg-tooltip);color:var(--text-on-primary);padding:.5rem .75rem;border-radius:.5rem;font-size:.8125rem;white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis;z-index:10;margin-bottom:.25rem}@media (hover: hover){.event-response-group:hover .event-response-tooltip{display:block}}.event-responses-detail{display:flex;flex-direction:column;gap:1rem}.event-response-section h4{margin:0 0 .5rem;font-size:.875rem;color:var(--text-primary)}.event-response-section.attending h4{color:var(--color-success-hover)}.event-response-section.declined h4{color:var(--color-error)}.event-response-list{display:flex;flex-direction:column;gap:.5rem}.event-response-user{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:.5rem}.event-response-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-avatar-placeholder);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.event-response-avatar img{width:100%;height:100%;object-fit:cover}.event-response-avatar span{color:#fff;font-size:.625rem;font-weight:600}.event-response-info{display:flex;flex-direction:column}.event-response-name{font-size:.875rem;font-weight:500;color:var(--text-heading)}.event-response-comment{font-size:.8125rem;color:var(--text-secondary);font-style:italic}.event-bottom-sheet-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);z-index:1000;align-items:flex-end}.event-bottom-sheet{background:var(--bg-card);border-radius:1rem 1rem 0 0;padding:1rem 1.5rem 2rem;max-height:60vh;overflow-y:auto;width:100%}.event-bottom-sheet-handle{width:40px;height:4px;background:var(--border-strong);border-radius:2px;margin:0 auto 1rem}.event-cancelled-banner{background:var(--bg-error-light);border:1px solid var(--bg-error);color:var(--text-error-badge);padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem;font-weight:500;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.event-reactivate-btn{background:var(--color-success-hover);color:var(--text-on-primary);border:none;border-radius:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.event-reactivate-btn:hover{background:var(--color-success-hover)}.event-cancel-btn{background:var(--bg-card);border:1px solid var(--color-error);border-radius:.5rem;padding:.625rem 1rem;cursor:pointer;font-size:.875rem;color:var(--color-error);transition:all .15s}.event-cancel-btn:hover{background:var(--color-error);color:var(--text-on-primary)}.event-image-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-photo-viewer);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.event-image-fullscreen img{max-width:100%;max-height:100%;object-fit:contain;padding:1rem}.event-image-fullscreen-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;z-index:10;transition:background .2s}.event-image-fullscreen-close:hover{background:#fff3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.event-feed-card{background:var(--bg-card);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .15s}.event-feed-card:hover{box-shadow:var(--shadow-dropdown)}.event-feed-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem}.event-feed-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.event-feed-avatar img{width:100%;height:100%;object-fit:cover}.event-feed-avatar span{color:var(--text-on-primary);font-size:.625rem;font-weight:600}.event-feed-header-text{font-size:.875rem;color:var(--text-primary)}.event-feed-header-text strong{color:var(--text-heading)}.event-feed-time{color:var(--text-muted);font-size:.75rem;margin-left:.5rem}.event-feed-image{max-height:200px;overflow:hidden}.event-feed-image img{width:100%;height:100%;object-fit:cover}.event-feed-body{padding:1rem 1.25rem}.event-feed-footer{display:flex;gap:.75rem;font-size:.8125rem;padding-top:.75rem;border-top:1px solid var(--bg-subtle)}.event-edit-btn{background:var(--bg-subtle);border:1px solid var(--border-strong);border-radius:.5rem;padding:.625rem 1rem;cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background .15s}.event-edit-btn:hover{background:var(--bg-subtle-hover)}@media (max-width: 768px){.events-tab{padding:.5rem .75rem;font-size:.8125rem}.events-create-btn{white-space:nowrap}.event-responses-detail{display:none}.event-bottom-sheet-overlay{display:flex}}@media (min-width: 769px){.event-response-group{cursor:default}.event-bottom-sheet-overlay{display:none!important}}.feed{display:flex;flex-direction:column;gap:1.5rem;padding:1rem;max-width:600px;margin:0 auto}.feed-item{animation:fadeIn .3s ease-out}.feed-loading,.feed-error,.feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-secondary)}.feed-item-removing{overflow:hidden;opacity:0;max-height:0!important;margin:0;padding:0;transition:max-height .35s ease-in-out,opacity .25s ease-out}.feed-loading-more{display:flex;justify-content:center;padding:1rem}.spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.upload-progress{padding:1.5rem}.upload-progress-header h3{margin:0 0 1rem;font-size:1rem;color:var(--text-heading)}.upload-progress-section{margin-bottom:1rem}.upload-progress-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary);margin-bottom:.35rem}.upload-progress-bar{height:8px;background:var(--bg-subtle-hover);border-radius:4px;overflow:hidden}.upload-progress-bar.batch{height:6px}.upload-progress-fill{height:100%;background:var(--gradient-primary);border-radius:4px;transition:width .3s ease}.upload-progress-fill.complete{background:var(--color-success)}.upload-progress-fill.error{background:var(--color-warning)}.upload-progress-finalizing{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;color:var(--text-secondary);font-size:.85rem}.upload-progress-finalizing .spinner{width:20px;height:20px;border:2px solid var(--border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.upload-progress-error{background:var(--bg-error-light);border:1px solid var(--bg-error);border-radius:.5rem;padding:.75rem 1rem;margin-bottom:1rem}.upload-progress-error p{margin:0 0 .75rem;color:var(--color-error);font-size:.85rem}.upload-progress-error-actions{display:flex;gap:.5rem}.upload-progress-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:4px;margin-top:1rem;max-height:200px;overflow-y:auto}.upload-progress-thumb{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden;background:var(--bg-subtle)}.upload-progress-thumb img{width:100%;height:100%;object-fit:cover}.upload-progress-thumb.pending img{opacity:.4}.upload-progress-thumb.uploading img{opacity:.6}.upload-progress-thumb.failed img{opacity:.5}.upload-progress-thumb.complete img{opacity:1}.upload-progress-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.upload-progress-thumb-overlay .spinner.small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.status-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff}.status-icon.complete{background:var(--color-success)}.status-icon.failed{background:var(--color-error-bright)}.upload-progress-actions{display:flex;justify-content:flex-end;margin-top:1rem}.upload-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.upload-content{background:var(--bg-card);border-radius:1rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.upload-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-default)}.upload-header h2{margin:0;font-size:1.25rem;color:var(--text-heading)}.upload-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.upload-close:hover{color:var(--text-primary)}.upload-content form{padding:1.5rem}.upload-dropzone{border:2px dashed var(--border-strong);border-radius:.75rem;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.upload-dropzone:hover,.upload-dropzone.active{border-color:var(--color-primary);background:var(--bg-primary-lighter)}.upload-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-primary-light);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-primary)}.upload-dropzone p{margin:0;color:var(--text-primary);font-weight:500}.upload-dropzone span{font-size:.75rem;color:var(--text-muted)}.upload-previews{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:1rem}.upload-preview{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;transition:transform .15s ease;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.upload-preview img{width:100%;height:100%;object-fit:cover;pointer-events:none}.upload-preview-remove{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;font-size:1rem;line-height:1}.upload-caption{margin-top:1rem}.upload-caption textarea{width:100%;padding:.75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-family:inherit;font-size:.875rem;resize:none}.upload-caption textarea:focus{outline:none;border-color:var(--color-primary)}.upload-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.btn-secondary:hover{background:var(--bg-subtle-hover)}.upload-error{margin-top:1rem;padding:.75rem;background:var(--bg-error);color:var(--color-error);border-radius:.5rem;font-size:.875rem}.upload-preview-order{position:absolute;bottom:.25rem;left:.25rem;width:20px;height:20px;border-radius:50%;background:#667eead9;color:#fff;font-size:.65rem;display:flex;align-items:center;justify-content:center;font-weight:600;pointer-events:none}.upload-preview-arrows{position:absolute;bottom:.25rem;right:.25rem;display:flex;gap:2px}.upload-preview-arrow{width:22px;height:22px;border-radius:50%;background:#667eead9;border:none;color:#fff;cursor:pointer;font-size:.9rem;line-height:1;display:flex;align-items:center;justify-content:center;padding:0}.upload-preview-arrow:active{background:#667eea;transform:scale(.9)}.upload-previews.reordering{user-select:none;-webkit-user-select:none}.upload-preview.dragging{opacity:.4;transform:scale(.95)}.upload-preview.drop-target{box-shadow:0 0 0 2px var(--color-primary)}.user-profile{max-width:800px;margin:0 auto;padding:1rem}.user-profile-loading,.user-profile-error{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.user-profile-loading .spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.user-profile-header{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:var(--bg-card);border-radius:1rem;box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.user-profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.user-profile-avatar img{width:100%;height:100%;object-fit:cover}.user-profile-avatar span{color:var(--text-on-primary);font-size:1.5rem;font-weight:600}.user-profile-info{flex:1}.user-profile-name{margin:0 0 .75rem;font-size:1.5rem;font-weight:700;color:var(--text-heading)}.user-profile-stats{display:flex;gap:1.5rem}.user-profile-stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.25rem;font-weight:700;color:var(--text-heading)}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.user-profile-tabs{display:flex;background:var(--bg-card);border-radius:.75rem;padding:.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.user-profile-tab{flex:1;padding:.625rem 1rem;border:none;background:transparent;border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.user-profile-tab:hover{color:var(--text-primary);background:var(--bg-subtle)}.user-profile-tab.active{background:var(--gradient-primary);color:var(--text-on-primary)}.user-profile-empty{text-align:center;padding:3rem 1rem;background:var(--bg-card);border-radius:1rem;color:var(--text-secondary)}.user-profile-feed{display:flex;flex-direction:column;gap:1rem}.user-profile-loading-more{text-align:center;padding:1.5rem}.user-profile-loading-more .spinner{width:24px;height:24px;border:2px solid var(--border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.user-profile-settings{display:flex;flex-direction:column;gap:1rem}.settings-section{background:var(--bg-card);border-radius:1rem;box-shadow:var(--shadow-sm);overflow:hidden}.settings-section-title{margin:0;padding:1rem 1.25rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--bg-subtle)}.settings-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem}.settings-item-info{flex:1}.settings-item-info strong{display:block;font-size:.95rem;color:var(--text-heading);margin-bottom:.25rem}.settings-item-info p{margin:0;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.settings-btn{flex-shrink:0;padding:.5rem 1.25rem;font-size:.85rem}.theme-picker{display:flex;border-radius:.5rem;overflow:hidden;border:1px solid var(--border-default);flex-shrink:0}.theme-picker-option{padding:.5rem 1rem;border:none;background:var(--bg-subtle);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .15s;font-family:inherit}.theme-picker-option:not(:last-child){border-right:1px solid var(--border-default)}.theme-picker-option.active{background:var(--gradient-primary);color:var(--text-on-primary);font-weight:500}@media (max-width: 600px){.user-profile{padding:.5rem}.user-profile-header{padding:1rem;gap:1rem}.user-profile-avatar{width:60px;height:60px}.user-profile-avatar span,.user-profile-name{font-size:1.25rem}.user-profile-stats{gap:1rem}.stat-value{font-size:1rem}.stat-label{font-size:.625rem}}.moderation-loading{display:flex;justify-content:center;padding:3rem}.moderation-not-found{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.moderation-not-found button{margin-top:1rem;background:var(--color-primary);color:var(--text-on-primary);border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer}.moderation-detail-page{max-width:600px;margin:0 auto;padding:1rem}.moderation-back-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.875rem;padding:.5rem 0;margin-bottom:1rem}.moderation-detail-card{background:var(--bg-card);border-radius:.75rem;box-shadow:var(--shadow-sm);overflow:hidden}.moderation-detail-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-default);display:flex;align-items:center;justify-content:space-between}.moderation-detail-header h2{margin:0;font-size:1.125rem;color:var(--color-error)}.moderation-detail-type{background:var(--bg-error);color:var(--color-error);font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:1rem}.moderation-detail-meta{padding:1rem 1.5rem;border-bottom:1px solid var(--border-default)}.moderation-detail-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.875rem}.moderation-meta-label{color:var(--text-muted)}.moderation-reason{padding:1rem 1.5rem;border-bottom:1px solid var(--border-default);background:var(--bg-warning)}.moderation-reason h4{margin:0 0 .5rem;font-size:.875rem;color:var(--text-warning-badge)}.moderation-reason p{margin:0;font-size:.875rem;color:var(--text-warning-badge);line-height:1.5}.moderation-snapshot{padding:1rem 1.5rem}.moderation-snapshot h4{margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary)}.moderation-snapshot-content{font-size:.875rem;color:var(--text-primary)}.moderation-snapshot-content p{margin:.25rem 0}.moderation-snapshot-content blockquote{margin:0;padding:.75rem 1rem;border-left:3px solid var(--border-strong);background:var(--bg-card);border-radius:0 .25rem .25rem 0;color:var(--text-primary);font-style:italic}.moderation-photo-list{margin:.5rem 0 0;padding-left:1.25rem;color:var(--text-secondary)}.moderation-photo-list li{padding:.125rem 0}.install-prompt{background:var(--gradient-primary);padding:.75rem 1rem;padding-top:max(.75rem,env(safe-area-inset-top));animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.install-prompt-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.install-prompt-icon{width:36px;height:36px;background:#fff3;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.install-prompt-icon svg{width:20px;height:20px;color:#fff}.install-prompt-text{flex:1;min-width:150px}.install-prompt-text strong{display:block;color:#fff;font-size:.9375rem}.install-prompt-text p{margin:0;color:#ffffffd9;font-size:.8125rem}.install-prompt-actions{display:flex;gap:.5rem}.install-prompt-btn{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.install-prompt-btn:active{opacity:.8}.install-prompt-btn.install{background:var(--bg-card);color:var(--color-primary)}.install-prompt-btn.dismiss{background:#fff3;color:#fff}.install-prompt.ios-instructions .install-prompt-content{flex-direction:column;align-items:flex-start}.ios-steps{margin:.5rem 0 0;padding-left:1.25rem;color:#ffffffe6;font-size:.875rem}.ios-steps li{margin-bottom:.5rem}.ios-steps li:last-child{margin-bottom:0}.ios-icon{font-family:system-ui,-apple-system,sans-serif}.update-prompt{position:fixed;bottom:1rem;left:1rem;right:1rem;z-index:1000;background:var(--bg-card);border-radius:1rem;padding:1rem;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;max-width:400px;margin:0 auto}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.update-prompt-content{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.update-prompt-icon{width:40px;height:40px;background:var(--gradient-primary);border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.update-prompt-icon svg{width:22px;height:22px;color:#fff}.update-prompt-text{flex:1;min-width:120px}.update-prompt-text strong{display:block;color:var(--text-heading);font-size:.9375rem}.update-prompt-text p{margin:0;color:var(--text-secondary);font-size:.8125rem}.update-prompt-actions{display:flex;gap:.5rem}.update-prompt-btn{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.update-prompt-btn:active{opacity:.8}.update-prompt-btn.update{background:var(--gradient-primary);color:#fff}.update-prompt-btn.dismiss{background:var(--bg-subtle);color:var(--text-secondary)}.offline-indicator{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);z-index:999;background:var(--color-error-bright);color:#fff;padding:.5rem 1rem;border-radius:2rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;box-shadow:var(--shadow-md);animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.offline-indicator svg{width:18px;height:18px}@media (max-width: 600px){.install-prompt-content{flex-wrap:nowrap}.install-prompt-text p{display:none}.install-prompt-actions{flex-shrink:0}.update-prompt{left:.5rem;right:.5rem;bottom:.5rem;bottom:max(.5rem,env(safe-area-inset-bottom))}.offline-indicator{bottom:max(1rem,env(safe-area-inset-bottom))}}:root{--bg-body: #f8f9fa;--bg-card: #ffffff;--bg-subtle: #f3f4f6;--bg-subtle-hover: #e5e7eb;--bg-input: #ffffff;--text-heading: #1a1a2e;--text-primary: #374151;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-on-primary: #ffffff;--border-default: #e5e7eb;--border-strong: #d1d5db;--color-primary: #667eea;--color-primary-hover: #5a6fd6;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--bg-primary-light: #eef2ff;--bg-primary-lighter: #f5f7ff;--color-error: #dc2626;--color-error-hover: #b91c1c;--color-error-bright: #ef4444;--bg-error: #fee2e2;--bg-error-light: #fef2f2;--text-error-badge: #991b1b;--color-success: #10b981;--color-success-hover: #059669;--bg-success: #d1fae5;--text-success-badge: #065f46;--color-warning: #f59e0b;--bg-warning: #fef3c7;--text-warning-badge: #92400e;--text-warning-heading: #92400e;--bg-reacted: #eef2ff;--border-reacted: #667eea;--bg-comment-reacted: #dbeafe;--text-comment-reacted: #1d4ed8;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .15);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .2);--shadow-menu: 0 4px 16px rgba(0, 0, 0, .15);--shadow-dropdown: 0 4px 12px rgba(0, 0, 0, .1);--shadow-primary: 0 4px 12px rgba(102, 126, 234, .4);--overlay-backdrop: rgba(0, 0, 0, .5);--overlay-photo-viewer: rgba(0, 0, 0, .95);--focus-ring: rgba(102, 126, 234, .1);--focus-ring-strong: rgba(102, 126, 234, .2);--scrollbar-track: #f1f1f1;--scrollbar-thumb: #c1c1c1;--scrollbar-thumb-hover: #a1a1a1;--bg-tooltip: #1f2937;--border-tooltip: #1f2937;--bg-handle: #d1d5db;--bg-avatar-placeholder: #b0bec5;--color-mention-link: #4f6bc5;--color-member-chip: #4338ca}[data-theme=dark]{--bg-body: #111114;--bg-card: #1c1c21;--bg-subtle: #26262d;--bg-subtle-hover: #32323a;--bg-input: #1c1c21;--text-heading: #e5e7eb;--text-primary: #d1d5db;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-on-primary: #ffffff;--border-default: #32323a;--border-strong: #3f3f48;--bg-primary-light: rgba(102, 126, 234, .15);--bg-primary-lighter: rgba(102, 126, 234, .08);--color-error: #f87171;--color-error-hover: #ef4444;--color-error-bright: #f87171;--bg-error: rgba(239, 68, 68, .15);--bg-error-light: rgba(239, 68, 68, .08);--text-error-badge: #fca5a5;--color-success: #34d399;--color-success-hover: #10b981;--bg-success: rgba(16, 185, 129, .15);--text-success-badge: #6ee7b7;--color-warning: #fbbf24;--bg-warning: rgba(245, 158, 11, .15);--text-warning-badge: #fcd34d;--text-warning-heading: #fbbf24;--bg-reacted: rgba(102, 126, 234, .15);--bg-comment-reacted: rgba(102, 126, 234, .2);--text-comment-reacted: #93b4fd;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .5);--shadow-menu: 0 4px 16px rgba(0, 0, 0, .4);--shadow-dropdown: 0 4px 12px rgba(0, 0, 0, .3);--shadow-primary: 0 4px 12px rgba(102, 126, 234, .3);--overlay-backdrop: rgba(0, 0, 0, .7);--overlay-photo-viewer: rgba(0, 0, 0, .98);--focus-ring: rgba(102, 126, 234, .25);--focus-ring-strong: rgba(102, 126, 234, .35);--scrollbar-track: #1c1c21;--scrollbar-thumb: #3f3f48;--scrollbar-thumb-hover: #52525b;--bg-tooltip: #3f3f48;--border-tooltip: #3f3f48;--bg-handle: #4b5563;--bg-avatar-placeholder: #4b5563;--color-mention-link: #93b4fd;--color-member-chip: #a5b4fc}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{color-scheme:dark}*{box-sizing:border-box}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;background:var(--bg-body);color:var(--text-primary)}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.btn{padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s;border:none;font-family:inherit}.btn-primary{background:var(--gradient-primary);color:var(--text-on-primary)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-primary)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-subtle);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-subtle-hover)}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-group input{padding:.75rem;border:1px solid var(--border-strong);border-radius:.5rem;font-size:1rem;transition:border-color .15s,box-shadow .15s;font-family:inherit;background:var(--bg-input);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--focus-ring)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}
