*{box-sizing:border-box}:root{--bg-primary:#0d0d0f;--bg-secondary:#16161a;--bg-tertiary:#1e1e24;--bg-hover:#252530;--text-primary:#fffffe;--text-secondary:#94a1b2;--text-muted:#72757e;--accent:#7f5af0;--accent-hover:#6b46e5;--accent-glow:rgba(127,90,240,.3);--success:#2cb67d;--error:#ff6b6b;--border:#2e2e38;--shadow:rgba(0,0,0,.4)}body{background:var(--bg-primary);color:var(--text-primary);margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--border)}::selection{background:var(--accent);color:#fff}.app-layout{min-height:100vh;display:flex}main{flex:1;max-width:1200px;min-height:100vh;margin:0 auto;padding:32px 24px}.sidebar{background:var(--bg-secondary);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;align-self:flex-start;gap:24px;width:220px;height:100vh;padding:24px 16px;transition:width .2s,padding .2s;display:flex;position:sticky;top:0}.sidebar .logo{color:var(--text-primary);letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent)0%,#a78bfa 100%);-webkit-text-fill-color:transparent;text-align:center;border-bottom:1px solid var(--border);-webkit-background-clip:text;background-clip:text;padding-bottom:16px;font-size:24px;font-weight:700;text-decoration:none}.sidebar-links{flex-direction:column;flex:1;gap:8px;display:flex}.sidebar-user{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:12px;padding-bottom:16px;display:flex}.sidebar-username{color:var(--text-primary);text-align:center;word-break:break-word;font-size:14px;font-weight:500}.sidebar-nav{flex-direction:column;gap:4px;display:flex}.sidebar-item{color:var(--text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.sidebar-icon{flex-shrink:0;width:20px;height:20px}.sidebar-item:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-item[aria-current=page]{color:var(--accent);background:var(--accent-glow)}.sidebar-item.register-link{background:var(--accent);color:#fff;text-align:center}.sidebar-item.register-link:hover{background:var(--accent-hover)}.sidebar-item.sign-out:hover{color:var(--error);background:rgba(255,107,107,.1)}.menu-badge{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:12px;font-weight:600;display:inline-flex}.sidebar.collapsed .menu-badge{min-width:16px;height:16px;padding:0 4px;font-size:10px;position:absolute;top:4px;right:4px}.sidebar-divider{background:var(--border);height:1px;margin:8px 0}.sidebar-toggle{background:var(--bg-secondary);border:1px solid var(--border);width:24px;height:24px;color:var(--text-muted);cursor:pointer;z-index:10;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex;position:absolute;top:24px;left:-12px}.sidebar-toggle:hover{color:var(--text-primary);border-color:var(--accent);background:var(--bg-tertiary)}.sidebar-toggle-icon{width:14px;height:14px}.sidebar.collapsed{width:64px;padding:24px 8px}.sidebar.collapsed .logo{padding-bottom:12px;font-size:18px}.sidebar.collapsed .sidebar-user{padding-bottom:12px}.sidebar.collapsed .sidebar-user .avatar-lg{width:40px;height:40px}.sidebar.collapsed .sidebar-username,.sidebar.collapsed .sidebar-label{display:none}.sidebar.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-item.register-link{padding:10px}.avatar{object-fit:cover;border-radius:50%;flex-shrink:0}.avatar-xs{vertical-align:text-bottom;background:var(--bg-tertiary);width:18px;height:18px;margin-right:4px}.avatar-sm{width:28px;height:28px}.avatar-md{width:36px;height:36px}.avatar-lg{width:80px;height:80px}@media (width<=768px){.sidebar{z-index:1000;height:100vh;transition:right .3s;position:fixed;top:0;right:-220px}.sidebar.open{right:0}main{padding:16px}}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);font-size:14px;font-weight:500}.form-group input{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);border-radius:10px;padding:14px 16px;font-size:16px;transition:all .2s}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-group input::placeholder{color:var(--text-muted)}.form-error{color:var(--error);background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.3);border-radius:8px;margin:0;padding:12px;font-size:14px}.form-success{color:var(--success);background:rgba(44,182,125,.1);border:1px solid rgba(44,182,125,.3);border-radius:8px;margin:0;padding:12px;font-size:14px}.form-hint{color:var(--text-muted);margin-top:4px;font-size:12px;display:block}.auth-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;padding:14px 28px;font-size:16px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.auth-button:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-2px)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.download-btn{background:var(--accent);color:#fff;white-space:nowrap;border-radius:10px;align-items:center;padding:14px 28px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.download-btn:hover{background:var(--accent-hover);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-2px)}.delete-btn{color:var(--error);border:1px solid var(--error);cursor:pointer;background:0 0;border-radius:10px;align-items:center;padding:14px 28px;font-weight:600;transition:all .2s;display:inline-flex}.delete-btn:hover{background:var(--error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 20px rgba(255,107,107,.3)}.avatar-btn{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:10px;align-items:center;padding:14px 28px;font-weight:600;transition:all .2s;display:inline-flex}.avatar-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.avatar-btn:disabled{opacity:.7;cursor:default;color:var(--success);border-color:var(--success)}.cancel-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:12px 24px;font-weight:500;transition:all .2s}.cancel-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.approve-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 10px var(--accent-glow)}.clear-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;margin:32px auto 0;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s;display:block}.clear-btn:hover{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-primary)}.upload-link{background:var(--accent);color:#fff;border-radius:10px;padding:14px 28px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.upload-link:hover{background:var(--accent-hover);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-2px)}.user-link{color:var(--text-primary);text-decoration:none;transition:color .2s}.user-link:hover{color:var(--accent)}.success{color:var(--success);text-align:center;background:rgba(44,182,125,.1);border:1px solid rgba(44,182,125,.3);border-radius:8px;margin-top:16px;padding:16px}.error{color:var(--error);text-align:center;background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.3);border-radius:8px;margin-top:16px;padding:16px}.status-badge{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-active{color:var(--success);background:rgba(44,182,125,.2)}.status-pending{color:#ffc107;background:rgba(255,193,7,.2)}.role-badge{text-transform:uppercase;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.role-admin{color:var(--accent);background:rgba(127,90,240,.2)}.role-user{background:var(--bg-tertiary);color:var(--text-muted)}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;margin:0 auto 24px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-secondary);padding:60px 20px}.empty-state h2{color:var(--text-primary);margin-bottom:12px;font-size:28px;font-weight:600}.empty-state p{color:var(--text-secondary);margin-bottom:32px;font-size:16px}.empty-hint{color:var(--text-muted);margin-top:8px;font-size:14px}.getting-started-options{flex-wrap:wrap;justify-content:center;gap:16px;max-width:800px;margin:0 auto;display:flex}.getting-started-card{text-align:center;background:var(--bg-secondary);border:1px solid var(--border);color:inherit;border-radius:16px;flex-direction:column;flex:1;align-items:center;min-width:200px;max-width:240px;padding:24px 20px;text-decoration:none;transition:all .2s;display:flex}.getting-started-card:hover{border-color:var(--accent);box-shadow:0 12px 32px var(--shadow);transform:translateY(-4px)}.getting-started-icon{margin-bottom:12px;font-size:36px}.getting-started-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:600}.getting-started-desc{color:var(--text-secondary);font-size:13px;line-height:1.4}@media (width<=640px){.getting-started-options{flex-direction:column;align-items:center}.getting-started-card{width:100%;max-width:300px}}.loading-message{text-align:center;color:var(--text-secondary);padding:60px;font-size:16px}.profile-link{align-items:center;gap:6px;display:inline-flex}.profile-name{color:var(--text-secondary);text-decoration:none;transition:color .2s}.profile-name:hover{color:var(--accent);text-decoration:underline}.gallery{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}a.image-card{background:var(--bg-secondary);border:1px solid var(--border);color:inherit;border-radius:16px;text-decoration:none;transition:all .3s;display:block;overflow:hidden}a.image-card:hover{border-color:var(--accent);box-shadow:0 20px 40px var(--shadow),0 0 30px var(--accent-glow);transform:translateY(-6px)}.image-card img{object-fit:cover;width:100%;height:220px;transition:transform .3s;display:block}a.image-card:hover img{transform:scale(1.05)}.image-card p{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;border-top:1px solid var(--border);margin:0;padding:16px;font-size:14px;overflow:hidden}.scroll-sentinel{text-align:center;padding:32px}.loading-more{color:var(--accent);margin:0;font-weight:500}.end-of-gallery{color:var(--text-muted);margin:0;font-size:14px}.feed-view{flex-direction:column;gap:20px;max-width:700px;margin:0 auto;padding:16px;display:flex}.feed-card{background:var(--bg-secondary);border:1px solid var(--border);aspect-ratio:4/3;border-radius:12px;flex-direction:row;transition:all .2s;display:flex;overflow:hidden}.feed-card:hover{border-color:var(--accent);box-shadow:0 8px 24px var(--shadow)}a.feed-image{background:var(--bg-tertiary);flex:3;display:block;overflow:hidden}.feed-image img{object-fit:cover;opacity:0;width:100%;height:100%;transition:transform .3s,opacity .3s}.feed-image img.loaded{opacity:1}.feed-image:hover img{transform:scale(1.02)}.feed-details{border-left:1px solid var(--border);flex-direction:column;flex:1;justify-content:space-between;gap:8px;min-width:0;padding:16px;display:flex}a.feed-filename{color:var(--text-primary);word-break:break-word;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s;display:-webkit-box;overflow:hidden}a.feed-filename:hover{color:var(--accent)}.feed-footer{margin-top:auto}.feed-meta{color:var(--text-muted);font-size:12px}.feed-footer .profile-link{margin-top:6px}.feed-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.feed-description{color:var(--text-secondary);-webkit-line-clamp:4;-webkit-box-orient:vertical;flex:1;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.feed-description p{margin:0}.feed-description p+p{margin-top:4px}@media (width<=640px){.feed-view{gap:16px;padding:12px}.feed-card{aspect-ratio:auto;flex-direction:column}.feed-image{aspect-ratio:1}.feed-details{border-left:none;border-top:1px solid var(--border);padding:12px 14px}}.image-page{max-width:1200px;margin:0 auto}.image-header{margin-bottom:32px}.image-header h1{color:var(--text-primary);word-break:break-word;margin:0;font-size:28px;font-weight:600}.image-viewer-container{align-items:center;gap:16px;display:flex}.image-nav-btn{background:var(--bg-secondary);border:1px solid var(--border);width:48px;height:48px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:flex}.image-nav-btn:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent)}.image-nav-btn svg{width:24px;height:24px}.image-nav-btn.disabled{opacity:.3;cursor:default;pointer-events:none}.image-viewer{background:var(--bg-secondary);cursor:pointer;border:1px solid var(--border);border-radius:16px;flex:1;justify-content:center;align-items:center;min-height:500px;transition:all .3s;display:flex;position:relative;overflow:hidden}.image-viewer:hover{border-color:var(--accent);box-shadow:0 0 40px var(--accent-glow)}.image-viewer img{object-fit:contain;max-width:100%;max-height:80vh}.zoom-hint{background:var(--bg-tertiary);color:var(--text-secondary);opacity:0;pointer-events:none;border:1px solid var(--border);border-radius:8px;padding:10px 20px;font-size:13px;transition:opacity .3s;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.image-viewer:hover .zoom-hint{opacity:1}.image-info{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;margin-top:32px;padding:28px}.image-info-row{justify-content:space-between;align-items:flex-start;gap:32px;width:100%;display:flex}.image-info dl{grid-template-columns:auto 1fr;gap:12px 24px;margin:0;display:grid}.image-info dt{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.image-info dd{color:var(--text-primary);word-break:break-word;margin:0}.image-actions{flex-direction:row;flex-shrink:0;align-items:flex-start;gap:8px;display:flex}.action-btn-icon{background:var(--bg-tertiary);border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0;text-decoration:none;transition:all .2s;display:flex}.action-btn-icon:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.action-btn-icon:disabled{opacity:.6;cursor:not-allowed}.action-btn-icon svg{flex-shrink:0;width:18px;height:18px}.action-btn-icon.success{background:var(--success-bg,rgba(34,197,94,.1));border-color:var(--success,#22c55e);color:var(--success,#22c55e);text-align:center;margin-top:0;padding:0}.action-btn-icon.danger{background:var(--error-bg,rgba(239,68,68,.1));border-color:var(--error);color:var(--error)}.action-btn-icon.danger:hover:not(:disabled){background:var(--error);color:#fff}.error-page{text-align:center;padding:60px}.error-page a{color:var(--accent);margin-top:20px;font-weight:500;text-decoration:none;display:inline-block}.error-page a:hover{text-decoration:underline}.lightbox{z-index:1000;cursor:pointer;backdrop-filter:blur(10px);background:rgba(0,0,0,.95);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-close{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;font-size:32px;transition:all .2s;display:flex;position:absolute;top:24px;right:24px}.lightbox-close:hover{background:var(--accent);border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.lightbox-content{cursor:default;max-width:100%;max-height:100%;overflow:auto}.lightbox-content img{max-width:none;max-height:none;display:block}.image-description-section{border-bottom:1px solid var(--border);width:100%;margin-bottom:24px;padding-bottom:16px}.description-display{min-height:36px;position:relative}.description-header{position:absolute;top:0;right:0}.description-content{color:var(--text-primary);line-height:1.7}.markdown-content p{margin:0 0 12px}.markdown-content p:last-child{margin-bottom:0}.markdown-content a{color:var(--accent);text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content strong{font-weight:600}.markdown-content em{font-style:italic}.markdown-content code{background:var(--bg-tertiary);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.9em}.markdown-content pre{background:var(--bg-tertiary);border-radius:8px;margin:12px 0;padding:16px;overflow-x:auto}.markdown-content pre code{background:0 0;padding:0}.markdown-content ul,.markdown-content ol{margin:12px 0;padding-left:24px}.markdown-content blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);margin:12px 0;padding-left:16px}.edit-description-btn{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-self:flex-start;padding:8px 16px;font-size:13px;transition:all .2s}.edit-description-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.description-edit{flex-direction:column;gap:12px;display:flex}.description-textarea{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;min-height:120px;color:var(--text-primary);resize:vertical;border-radius:10px;padding:14px 16px;font-family:inherit;font-size:14px;line-height:1.6;transition:all .2s}.description-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.description-textarea::placeholder{color:var(--text-muted)}.description-actions{justify-content:flex-end;gap:12px;display:flex}.description-actions .save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.description-actions .save-btn:hover{background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow)}.image-info .album-selector{background:0 0;border:none;border-radius:0;width:100%;margin:0;padding:0}.image-info .album-selector h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px;font-size:13px;font-weight:500}.image-info .album-checkboxes{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.image-info .album-checkbox{background:var(--bg-tertiary);cursor:pointer;color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;align-items:center;padding:6px 12px;font-size:13px;transition:all .2s;display:inline-flex}.image-info .album-checkbox:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.image-info .album-checkbox:has(input:checked){background:var(--accent);color:#fff;border-color:var(--accent)}.image-info .album-checkbox input[type=checkbox]{display:none}.image-info .album-selector .loading-hint,.image-info .album-selector .empty-hint{color:var(--text-muted);margin:0;font-size:13px}.slideshow-overlay{z-index:1000;cursor:pointer;background:#000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.slideshow-image-container{cursor:default;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.slideshow-image-container img{object-fit:contain;width:100%;height:100%}.slideshow-controls{background:var(--bg-secondary);border:1px solid var(--border);cursor:default;border-radius:12px;align-items:center;gap:16px;padding:12px 20px;display:flex;position:fixed;bottom:32px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px rgba(0,0,0,.3)}.slideshow-control-btn{background:var(--bg-tertiary);border:1px solid var(--border);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:flex}.slideshow-control-btn:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.slideshow-control-btn svg{width:22px;height:22px}.slideshow-counter{color:var(--text-secondary);text-align:center;min-width:60px;font-size:14px}.comments-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;margin-top:32px;padding:28px}.comments-title{color:var(--text-primary);align-items:center;gap:10px;margin:0 0 20px;font-size:18px;font-weight:600;display:flex}.comments-count{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:10px;padding:2px 8px;font-size:13px;font-weight:500}.comment-form{margin-bottom:24px}.comment-input{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;min-height:80px;color:var(--text-primary);resize:vertical;border-radius:10px;padding:14px 16px;font-family:inherit;font-size:14px;line-height:1.5;transition:all .2s}.comment-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.comment-input::placeholder{color:var(--text-muted)}.comment-input:disabled{opacity:.6;cursor:not-allowed}.comment-form-footer{justify-content:space-between;align-items:center;margin-top:12px;display:flex}.char-count{color:var(--text-muted);font-size:12px}.char-count.over-limit{color:var(--error);font-weight:500}.comment-submit-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.comment-submit-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow)}.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed}.sign-in-prompt{color:var(--text-secondary);margin:0 0 24px;font-size:14px}.sign-in-prompt a{color:var(--accent);font-weight:500;text-decoration:none}.sign-in-prompt a:hover{text-decoration:underline}.comments-list{flex-direction:column;gap:16px;display:flex}.comments-loading,.no-comments{color:var(--text-muted);text-align:center;padding:20px 0;font-size:14px}.comment-error{color:var(--error);background:var(--error-bg,rgba(239,68,68,.1));border-radius:8px;margin:0 0 16px;padding:12px 16px;font-size:14px}.comment-item{gap:12px;display:flex}.comment-avatar-link{flex-shrink:0}.comment-content{flex:1;min-width:0}.comment-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.comment-author{color:var(--text-primary);font-size:14px;font-weight:500;text-decoration:none}.comment-author:hover{color:var(--accent)}.comment-time{color:var(--text-muted);font-size:12px}.comment-delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin-left:auto;padding:4px;transition:all .2s;display:flex}.comment-delete-btn:hover{background:var(--error-bg,rgba(239,68,68,.1));color:var(--error)}.comment-delete-btn svg{width:14px;height:14px}.comment-text{color:var(--text-primary);word-wrap:break-word;overflow-wrap:break-word;margin:0;font-size:14px;line-height:1.5}.load-more-btn{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;border-radius:8px;margin-top:16px;padding:12px;font-size:14px;transition:all .2s;display:block}.load-more-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}.upload-page{max-width:600px;margin:0 auto;padding:40px 20px}.upload-page h1{text-align:center;color:var(--text-primary);margin-bottom:40px;font-size:32px;font-weight:700}.upload-form{margin-bottom:32px}.file-drop-zone{background:var(--bg-secondary);border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:16px;padding:60px 24px;transition:all .3s;display:block}.file-drop-zone:hover{border-color:var(--accent);background:var(--bg-tertiary);box-shadow:0 0 30px var(--accent-glow)}.file-drop-zone input[type=file]{display:none}.drop-zone-content{flex-direction:column;align-items:center;gap:12px;display:flex}.drop-icon{filter:grayscale(.3);font-size:56px}.drop-zone-content span{color:var(--text-secondary);font-size:16px}.drop-hint{color:var(--text-muted)!important;font-size:14px!important}.upload-list{flex-direction:column;gap:16px;display:flex}.upload-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:20px;transition:border-color .3s}.upload-item.uploading{border-color:var(--accent)}.upload-item.complete{border-color:var(--success)}.upload-item.error{border-color:var(--error)}.upload-item-info{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.upload-item-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:16px;font-weight:500;overflow:hidden}.upload-item-status{color:var(--text-muted);flex-shrink:0;font-size:13px}.upload-item.complete .upload-item-status{color:var(--success)}.upload-item.error .upload-item-status{color:var(--error)}.upload-item.uploading .upload-item-status{color:var(--accent)}.progress-bar{background:var(--bg-tertiary);border-radius:3px;height:6px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.upload-item.complete .progress-fill{background:var(--success)}.upload-item.error .progress-fill{background:var(--error);width:100%!important}.upload-item.queued .progress-fill{background:var(--text-muted);width:0%!important}.upload-item.uploading .progress-fill{background:linear-gradient(90deg,var(--accent),#a78bfa);animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.upload-actions{gap:12px;margin-top:16px;display:flex}.add-to-albums-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-weight:500;transition:all .2s}.add-to-albums-btn:hover{background:var(--accent-hover)}.auth-page{justify-content:center;align-items:center;min-height:60vh;padding:40px 20px;display:flex}.auth-form-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;width:100%;max-width:440px;padding:48px}.auth-form-container h1{text-align:center;margin:0 0 8px;font-size:32px;font-weight:700}.auth-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:32px}.auth-form{flex-direction:column;gap:20px;display:flex}.auth-footer{text-align:center;color:var(--text-muted);margin-top:24px;font-size:14px}.auth-success,.auth-error{text-align:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;max-width:440px;padding:48px}.auth-success h1,.auth-error h1{margin:16px 0;font-size:28px}.auth-success p,.auth-error p{color:var(--text-secondary);margin:8px 0}.auth-hint{font-size:14px;color:var(--text-muted)!important;margin-top:16px!important}.success-icon,.error-icon{margin-bottom:8px;font-size:64px}.success-icon{color:var(--success)}.error-icon{color:var(--error)}.auth-success .auth-button{margin-top:24px}.auth-verifying{text-align:center;padding:48px}.auth-required{text-align:center;max-width:440px;margin:0 auto;padding:60px 20px}.auth-required h1{margin:0 0 16px;font-size:28px}.auth-required p{color:var(--text-secondary);margin-bottom:24px}.settings-page{max-width:600px;margin:0 auto;padding:20px}.settings-page h1{margin:0 0 40px;font-size:32px;font-weight:700}.settings-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;margin-bottom:24px;padding:28px}.settings-section h2{color:var(--text-primary);margin:0 0 20px;font-size:18px;font-weight:600}.settings-form{flex-direction:column;gap:16px;display:flex}.settings-form .auth-button{align-self:flex-start}.admin-page{max-width:800px;margin:0 auto;padding:20px}.admin-page h1{margin:0 0 40px;font-size:32px;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;display:grid}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:16px;padding:28px;transition:all .2s}.stat-card:hover{border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow)}.stat-value{color:var(--text-primary);margin-bottom:8px;font-size:36px;font-weight:700}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:14px}.users-table-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table th,.users-table td{text-align:left;padding:16px 20px}.users-table th{background:var(--bg-tertiary);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600}.users-table td{border-bottom:1px solid var(--border);color:var(--text-primary)}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:var(--bg-hover)}.user-id{color:var(--text-muted);font-family:monospace;font-size:13px}.clickable-row{cursor:pointer}.clickable-row:hover td{background:var(--bg-hover)}.profile-header{margin-bottom:32px}.profile-header-main{align-items:center;gap:20px;margin-top:16px;display:flex}.profile-header-info{flex:1}.profile-header-info h1{margin:0 0 8px;font-size:28px}.profile-header-actions{align-self:flex-start;gap:8px;margin-top:20px;display:flex}.profile-header h1{margin:16px 0 8px;font-size:28px}.profile-stats{color:var(--text-muted);margin:0}.profile-bio{margin-bottom:32px}.profile-bio .markdown-content{color:var(--text-secondary);line-height:1.6}.profile-bio .markdown-content p{margin:0 0 1em}.profile-bio .markdown-content p:last-child{margin-bottom:0}.profile-bio .markdown-content a{color:var(--accent)}.profile-bio .markdown-content a:hover{text-decoration:underline}.profile-bio .markdown-content strong{color:var(--text-primary);font-weight:600}.profile-bio .markdown-content em{font-style:italic}.profile-bio .markdown-content code{background:var(--bg-tertiary);border-radius:4px;padding:.2em .4em;font-size:.9em}.profile-bio .markdown-content ul,.profile-bio .markdown-content ol{margin:0 0 1em;padding-left:1.5em}.profile-bio .markdown-content li{margin-bottom:.25em}.public-album-page{max-width:1200px;margin:0 auto;padding:24px}.public-album-page .page-header{margin-bottom:32px}.public-album-page .page-header-main{align-items:center;gap:20px;margin-top:16px;display:flex}.public-album-page .page-header-info{flex:1}.public-album-page .page-header-info h1{margin:0 0 8px;font-size:32px;font-weight:700}.public-album-page .page-stats{color:var(--text-muted);margin:0}.public-album-page .page-header-actions{align-self:flex-start;gap:8px;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-header h2{margin:0}.section-header-actions{gap:8px;display:flex}.upload-btn-icon{background:var(--bg-tertiary);border:1px solid var(--border);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.upload-btn-icon:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.upload-btn-icon:disabled{opacity:.6;cursor:not-allowed}.upload-btn-icon svg{flex-shrink:0;width:18px;height:18px}.upload-spinner{font-size:12px;animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.subscribe-icon-btn.subscribed{background:var(--accent);border-color:var(--accent);color:#fff}.subscribe-icon-btn.subscribed:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.users-table .actions-cell{align-items:center;gap:8px;display:flex}.users-table .actions-cell button{cursor:pointer;border-radius:6px;justify-content:center;align-items:center;min-width:80px;height:32px;padding:0 12px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.users-table .approve-btn{background:var(--accent);color:#fff;border:none}.users-table .approve-btn:hover:not(:disabled){background:var(--accent-hover)}.users-table .approve-btn.approved{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.users-table .approve-btn.approved:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.users-table .delete-btn{color:var(--error);border:1px solid var(--error);background:0 0}.users-table .delete-btn:hover:not(:disabled),.users-table .delete-btn.confirm{background:var(--error);color:#fff}.users-table .delete-btn.confirm:hover:not(:disabled){background:#e55555}.users-table .cancel-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.users-table .cancel-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.users-table .actions-cell button:disabled{opacity:.6;cursor:not-allowed}.albums-section{margin-bottom:40px}.albums-section h2,.images-section h2{color:var(--text-secondary);margin-bottom:16px;font-size:18px;font-weight:500}.albums-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.album-card{color:inherit;background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:12px;text-decoration:none;transition:all .2s;display:block;overflow:hidden}a.album-card:hover{border-color:var(--accent);transform:translateY(-2px)}.album-cover{aspect-ratio:16/9;background:var(--bg-tertiary);justify-content:center;align-items:center;display:flex}.album-cover img{object-fit:cover;width:100%;height:100%}.album-info{flex-direction:column;gap:4px;padding:12px;display:flex}.album-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.album-count{color:var(--text-muted);font-size:12px}.albums-page{max-width:1200px;margin:0 auto;padding:24px}.albums-page .page-header{margin-bottom:32px}.albums-page .page-header-main{justify-content:space-between;align-items:center;gap:20px;margin-top:16px;display:flex}.albums-page .page-header-info{flex:1}.albums-page .page-header h1,.albums-page .page-header-info h1{margin:0 0 8px;font-size:32px;font-weight:700}.albums-page .page-stats{color:var(--text-muted);margin:0;font-size:15px}.albums-page .back-link{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;align-items:center;margin-bottom:16px;padding:8px 16px;font-size:14px;text-decoration:none;transition:all .2s;display:inline-flex}.albums-page .back-link:hover{color:var(--text-primary);border-color:var(--accent);background:var(--bg-tertiary)}.create-album-form{gap:12px;max-width:500px;margin-bottom:32px;display:flex}.create-album-form input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:10px;flex:1;padding:14px 16px;font-size:15px}.create-album-form input::placeholder{color:var(--text-muted)}.create-album-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.create-album-form button{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:14px 28px;font-size:15px;font-weight:600;transition:all .2s}.create-album-form button:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-2px)}.create-album-form button:disabled{opacity:.5;cursor:not-allowed}.album-selector{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;margin-bottom:24px;padding:20px}.album-selector h3{color:var(--text-secondary);margin:0 0 16px;font-size:16px;font-weight:500}.album-checkboxes{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.album-checkbox{background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;transition:all .2s;display:flex}.album-checkbox:hover{border-color:var(--accent)}.album-checkbox input[type=checkbox]{accent-color:var(--accent)}.album-checkbox-count{color:var(--text-muted);font-size:12px}.new-album-form{gap:8px;display:flex}.new-album-form input{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.new-album-form input::placeholder{color:var(--text-muted)}.new-album-form input:focus{border-color:var(--accent);outline:none}.new-album-form button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-weight:500;transition:all .2s}.new-album-form button:hover:not(:disabled){background:var(--accent-hover)}.new-album-form button:disabled{opacity:.5;cursor:not-allowed}.albums-page.drag-active{position:relative}.albums-page.drag-active:before{content:"";border:3px dashed var(--accent);pointer-events:none;z-index:10;background:rgba(127,90,240,.1);position:fixed;inset:70px 0 0}.drop-hint-banner{background:var(--bg-secondary);border:2px solid var(--accent);z-index:20;box-shadow:0 20px 60px var(--shadow);text-align:center;pointer-events:none;border-radius:16px;padding:32px 48px;display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.drop-hint-banner.visible{display:block}.drop-hint-banner span{color:var(--accent);font-size:20px;font-weight:600}.empty-state-overlay{text-align:center;color:var(--text-secondary);border:2px dashed var(--border);border-radius:16px;margin-top:24px;padding:80px 20px}.empty-state-overlay p{margin-bottom:12px;font-size:18px}.album-empty-state{cursor:pointer;margin-top:24px}.uploading-tile{background:var(--bg-secondary);border:2px solid var(--border);border-radius:16px;transition:all .3s;position:relative;overflow:hidden}.uploading-tile.queued{border-color:var(--text-muted)}.uploading-tile.uploading{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow);animation:2s ease-in-out infinite upload-glow}@keyframes upload-glow{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 30px var(--accent-glow),0 0 40px var(--accent-glow)}}.uploading-tile.complete{border-color:var(--success)}.uploading-tile.error{border-color:var(--error)}.uploading-tile-preview{background:var(--bg-tertiary);width:100%;height:220px;position:relative;overflow:hidden}.uploading-tile-preview img{object-fit:cover;opacity:.6;width:100%;height:100%}.uploading-tile.complete .uploading-tile-preview img{opacity:1}.uploading-tile-overlay{background:rgba(0,0,0,.4);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.uploading-tile.complete .uploading-tile-overlay{background:rgba(44,182,125,.2)}.uploading-tile.error .uploading-tile-overlay{background:rgba(255,107,107,.3)}.uploading-tile-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;border-top:1px solid var(--border);margin:0;padding:16px;font-size:14px;overflow:hidden}.upload-progress-ring{width:80px;height:80px;position:relative}.upload-progress-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--bg-tertiary);stroke-width:3px}.progress-ring-fill{fill:none;stroke:var(--accent);stroke-width:3px;stroke-linecap:round;transition:stroke-dasharray .3s}.progress-percent{color:#fff;font-size:14px;font-weight:600;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.upload-status-icon{flex-direction:column;align-items:center;gap:8px;display:flex}.upload-status-icon.queued .status-text{color:var(--text-muted);font-size:14px;animation:1.5s ease-in-out infinite pulse}.upload-status-icon.complete .checkmark{color:var(--success);font-size:48px}.upload-status-icon.error .error-icon{color:var(--error);font-size:48px}.upload-status-icon.error .error-text{color:var(--error);text-align:center;max-width:150px;font-size:12px}.upload-complete-actions{justify-content:center;margin-top:24px;display:flex}.uploaded-image-card .image-card-images{width:100%;height:220px;position:relative;overflow:hidden}.uploaded-image-card .preview-bg{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.uploaded-image-card .real-image{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .2s;position:absolute;top:0;left:0}.uploaded-image-card .real-image.loaded{opacity:1}.album-actions{gap:12px;margin-bottom:24px;display:flex}.album-actions .delete-btn{color:var(--error);border:1px solid var(--error);cursor:pointer;background:0 0;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.album-actions .delete-btn:hover{background:var(--error);color:#fff}.album-info-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;margin-top:48px;padding:28px}.album-info-row{justify-content:space-between;align-items:flex-start;gap:32px;display:flex}.album-details dl{grid-template-columns:auto 1fr;gap:12px 24px;margin:0;display:grid}.album-details dt{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:500}.album-details dd{color:var(--text-primary);margin:0}.album-info-panel .album-actions{flex-direction:row;gap:8px;margin-bottom:0;display:flex}.album-actions .action-btn-icon.active{background:var(--accent-bg,rgba(127,90,240,.1));border-color:var(--accent);color:var(--accent)}.visibility-menu-container{position:relative}.visibility-menu-backdrop{z-index:99;position:fixed;inset:0}.visibility-menu{background:var(--bg-secondary);border:1px solid var(--border);min-width:160px;box-shadow:0 8px 32px var(--shadow);z-index:100;border-radius:12px;padding:8px;position:absolute;top:calc(100% + 8px);right:0}.visibility-option{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;transition:all .15s;display:flex}.visibility-option:hover{background:var(--bg-tertiary)}.visibility-option.active{background:var(--accent-bg,rgba(127,90,240,.1));color:var(--accent)}.visibility-option svg{flex-shrink:0;width:18px;height:18px}.find-page{max-width:1200px;margin:0 auto;padding:24px}.find-page .page-header{margin-bottom:32px}.find-page .page-header h1{margin:0 0 8px;font-size:32px;font-weight:700}.find-page .page-subtitle{color:var(--text-muted);margin:0;font-size:15px}.find-page .page-header-row{justify-content:space-between;align-items:flex-start;display:flex}.users-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.user-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;transition:all .2s;display:block;overflow:hidden}.user-card:hover{border-color:var(--accent);box-shadow:0 8px 24px var(--shadow);transform:translateY(-2px)}.user-card-link{color:inherit;text-decoration:none;display:block}.user-card-images{aspect-ratio:4/3;background:var(--bg-tertiary);overflow:hidden}.user-card-grid{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:2px;width:100%;height:100%;display:grid}.user-card-grid img{object-fit:cover;width:100%;height:100%}.user-card-grid img:first-child:last-child{grid-area:1/1/-1/-1}.user-card-grid img:first-child:nth-last-child(2),.user-card-grid img:first-child:nth-last-child(2)~img,.user-card-grid img:first-child:nth-last-child(3){grid-row:span 2}.user-card-empty{width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.user-card-info{border-top:1px solid var(--border);align-items:center;gap:12px;padding:14px;display:flex}.user-card-profile-link{color:inherit;flex:1;align-items:center;gap:12px;min-width:0;text-decoration:none;display:flex}.user-card-profile-link:hover .user-card-name{color:var(--accent)}.user-card-details{flex-direction:column;gap:2px;min-width:0;display:flex}.user-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;transition:color .2s;overflow:hidden}.user-card-stats{color:var(--text-muted);font-size:12px}.subscribe-icon{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.subscribe-icon:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.subscribe-icon:disabled{opacity:.6;cursor:not-allowed}.subscribe-icon.subscribed{background:var(--accent);border-color:var(--accent);color:#fff}.subscribe-icon.subscribed:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.subscribe-icon svg{width:18px;height:18px}.subscribe-icon-loading{font-size:14px}.subscribe-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.subscribe-btn .subscribe-icon{flex-shrink:0;width:18px;height:18px}.subscribe-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 10px var(--accent-glow)}.subscribe-btn:disabled{opacity:.6;cursor:not-allowed}.subscribe-btn.subscribed{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.subscribe-btn.subscribed:hover:not(:disabled){border-color:var(--error);color:var(--error);background:var(--bg-secondary);box-shadow:none}.pending-requests-section{border-bottom:1px solid var(--border);margin-bottom:32px;padding-bottom:24px}.pending-requests-section .section-header{align-items:center;gap:8px;margin:0 0 16px;font-size:18px;font-weight:600;display:flex}.count-badge{background:var(--accent);color:#fff;border-radius:12px;justify-content:center;align-items:center;min-width:24px;height:24px;padding:0 8px;font-size:13px;font-weight:500;display:inline-flex}.pending-requests-list{flex-direction:column;gap:12px;display:flex}.pending-request-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.pending-request-user{align-items:center;gap:12px;display:flex}.pending-request-avatar{object-fit:cover;border-radius:50%;width:40px;height:40px}.pending-request-avatar-placeholder{background:var(--bg-tertiary);border-radius:50%;width:40px;height:40px}.pending-request-name{color:var(--text-primary);font-weight:500}.pending-request-actions{gap:8px;display:flex}.approve-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.approve-btn:hover:not(:disabled){background:var(--accent-hover)}.approve-btn:disabled{opacity:.6;cursor:not-allowed}.block-btn{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.block-btn:hover:not(:disabled){border-color:var(--error);color:var(--error)}.block-btn:disabled{opacity:.6;cursor:not-allowed}.subscriptions-page{max-width:1200px;margin:0 auto;padding:24px}.subscriptions-page .page-header{margin-bottom:32px}.subscriptions-page .page-header h1{margin:0 0 8px;font-size:32px;font-weight:700}.subscriptions-page .page-subtitle{color:var(--text-muted);margin:0;font-size:15px}.subscriptions-page .feed-view,.subscriptions-page .scroll-sentinel,.subscriptions-page .empty-state,.subscriptions-page .loading-message{max-width:600px;margin:0 auto}.modal-overlay{z-index:1000;backdrop-filter:blur(4px);background:rgba(0,0,0,.8);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal,.modal-dialog{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;width:90%;max-width:400px;padding:32px}.modal h2,.modal-dialog h2{color:var(--text-primary);margin:0 0 12px;font-size:24px}.modal p,.modal-dialog p{color:var(--text-secondary);margin:0 0 24px;line-height:1.6}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.cancel-btn{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:12px 24px;font-weight:600;transition:all .2s}.cancel-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-muted)}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-delete-btn{background:var(--error);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-weight:600;transition:all .2s}.confirm-delete-btn:hover:not(:disabled){background:#e55555;box-shadow:0 4px 20px rgba(255,107,107,.3)}.confirm-delete-btn:disabled{opacity:.5;cursor:not-allowed}.delete-album-dialog{max-width:440px}.delete-album-dialog h2,.confirm-name-section{margin-bottom:20px}.confirm-name-section label{color:var(--text-secondary);margin-bottom:8px;font-size:14px;display:block}.confirm-name-input{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:8px;margin-top:8px;padding:12px;font-size:15px}.confirm-name-input:focus{border-color:var(--accent);outline:none}.confirm-name-input::placeholder{color:var(--text-muted)}.delete-images-option{background:var(--bg-tertiary);cursor:pointer;border-radius:8px;align-items:center;gap:10px;margin-bottom:12px;padding:12px;display:flex}.delete-images-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--error);cursor:pointer}.delete-images-option span{color:var(--text-primary);font-size:14px}.delete-warning{color:var(--error);background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.3);border-radius:8px;margin:0 0 20px;padding:12px;font-size:13px;line-height:1.5}.confirm-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-weight:600;transition:all .2s}.confirm-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 20px var(--accent-glow)}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}.create-album-dialog{max-width:360px}.create-album-dialog h2{margin-bottom:20px}.create-album-dialog form{flex-direction:column;gap:16px;display:flex}.create-album-dialog input[type=text]{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:8px;padding:12px;font-size:15px}.create-album-dialog input[type=text]:focus{border-color:var(--accent);outline:none}.create-album-dialog input[type=text]::placeholder{color:var(--text-muted)}.create-album-dialog .form-error{color:var(--error);margin:0;font-size:14px}.add-friend-dialog{max-width:380px}.add-friend-dialog h2{margin-bottom:8px}.add-friend-dialog p{margin-bottom:20px;font-size:14px}.add-friend-dialog form{flex-direction:column;gap:20px;display:flex}.add-friend-dialog input[type=email]{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:8px;padding:14px 16px;font-size:15px;transition:border-color .2s}.add-friend-dialog input[type=email]:focus{border-color:var(--accent);outline:none}.add-friend-dialog input[type=email]::placeholder{color:var(--text-muted)}