.painting-display{display:flex;gap:var(--space-xl);padding:var(--space-lg);background:var(--bg-darkest);border-bottom:1px solid var(--bg-light);margin-bottom:var(--space-md)}.painting-display.portrait{flex-direction:row}.painting-display.landscape{flex-direction:column;align-items:center}.painting-display-image{flex-shrink:0;max-width:25rem;max-height:25rem;position:relative}.painting-display.landscape .painting-display-image{max-width:37.5rem;max-height:21.875rem}.painting-display-image a{cursor:grab;display:block}.painting-display-image a:active{cursor:grabbing}.painting-display-image .react-transform-wrapper{height:100%}.painting-display-image .react-transform-component{width:100%;height:100%}.painting-display-image img{max-width:100%;max-height:25rem;object-fit:contain;border-radius:var(--radius-sm);transition:opacity .2s ease-in-out}.painting-display.landscape .painting-display-image img{max-height:21.875rem}.display-open-btn{bottom:var(--space-sm);right:var(--space-sm);width:2rem;height:2rem;font-size:var(--font-lg);cursor:pointer}.painting-display-hint{position:absolute;bottom:-1.25rem;left:0;right:0;text-align:center;font-size:.6875rem;color:var(--brand-gold);opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.painting-display-image:hover .painting-display-hint{opacity:1}.painting-display-info{display:flex;flex-direction:column;justify-content:center}.painting-display.landscape .painting-display-info{text-align:center;width:100%}.painting-display.landscape .painting-info-actions{justify-content:center}.painting-display-info .painting-info-title{font-size:var(--font-2xl);margin-bottom:var(--space-sm);color:var(--text-primary)}.painting-display-info .painting-info-artist{font-size:1.1rem;color:var(--brand-gold);margin-bottom:var(--space-xs)}.painting-display-info .painting-info-date{color:var(--text-muted)}.painting-display-info .painting-info-details{font-size:.9rem;color:var(--text-dimmed)}.painting-display-info .back-to-grid-btn{margin-top:var(--space-md)}.painting-info-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-sm)}.painting-action-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .625rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-secondary);font-size:var(--font-xs);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.painting-action-btn:hover{color:var(--text-primary);border-color:var(--brand-gold-subtle);background:var(--bg-light)}.painting-action-btn svg{flex-shrink:0}.sidebar-panel{width:4rem;display:flex;flex-direction:column;height:100%;background:var(--bg-darker);border-radius:var(--radius-sm) var(--radius-sm) 0 0;overflow:hidden}.sidebar-panel.sidebar-right{box-shadow:-.25rem 0 1rem #0000004d}.sidebar-panel.sidebar-left{box-shadow:.25rem 0 1rem #0000004d}.sidebar-panel-header{position:relative;display:flex;align-items:center;justify-content:center;padding:.375rem .25rem;font-size:var(--font-xs);text-transform:uppercase;color:var(--text-dimmed);text-align:center;border:none;border-bottom:1px solid var(--bg-light);background:var(--bg-dark);cursor:pointer;flex-shrink:0;width:100%;border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-panel-header:hover{background:var(--bg-medium);color:var(--text-secondary)}.sidebar-panel-header-arrow{position:absolute;top:50%;transform:translateY(-50%);color:var(--brand-gold);opacity:.6;transition:opacity var(--transition-fast)}.sidebar-left .sidebar-panel-header-arrow,.sidebar-right .sidebar-panel-header-arrow{right:.125rem}.sidebar-panel-header:hover .sidebar-panel-header-arrow{opacity:.85}.sidebar-panel-header-label{position:relative;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:3rem}.sidebar-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:var(--space-sm) 0}.sidebar-empty{color:var(--text-dimmed);font-size:var(--font-xs);text-align:center;padding:var(--space-md) var(--space-xs);writing-mode:vertical-rl}.sidebar-thumbnail{background:none;border:2px solid transparent;padding:0;margin:0;cursor:pointer;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 .125rem .375rem #0006;transition:border-color var(--transition-normal),transform var(--transition-normal),box-shadow var(--transition-normal)}.sidebar-thumbnail:hover{border-color:var(--brand-gold);transform:scale(1.05);box-shadow:0 .25rem .625rem #0009}.sidebar-thumbnail img{display:block;object-fit:cover;border-radius:calc(var(--radius-md) - 2px);aspect-ratio:1;background:var(--bg-medium)}.sidebar-thumbnail-container{position:relative;margin:var(--space-xs)}.sidebar-thumbnail-container.active .sidebar-thumbnail{border-color:var(--brand-gold);box-shadow:0 0 0 .125rem var(--brand-gold),0 0 .5rem #d4af3780}.sidebar-remove-btn{position:absolute;top:0;right:0;width:.75rem;height:.75rem;border-radius:50%;background:#dc3c3cd9;color:#fff;border:none;cursor:pointer;opacity:0;transition:opacity var(--transition-fast);display:flex;align-items:center;justify-content:center;z-index:2;padding:0;font-size:.5rem;line-height:1}.sidebar-thumbnail-container:hover .sidebar-remove-btn{opacity:1}.sidebar-remove-btn:hover{background:#dc3c3c}.sidebar-thumbnail-wrapper{position:relative;cursor:grab}.sidebar-thumbnail-wrapper:active{cursor:grabbing}.sidebar-thumbnail-wrapper.is-dragging{opacity:.4}.sidebar-node-thumb{position:relative;overflow:hidden}.sidebar-node-placeholder{background:var(--bg-medium);border-radius:calc(var(--radius-md) - 2px)}.sidebar-node-overlay-name{position:absolute;bottom:0;left:0;right:0;padding:.125rem .1875rem;background:linear-gradient(transparent,#000000bf);color:var(--text-primary);font-size:.4375rem;line-height:1.2;text-align:center;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-shadow:0 1px 2px rgba(0,0,0,.8);border-radius:0 0 calc(var(--radius-md) - 2px) calc(var(--radius-md) - 2px)}.sidebar-open-btn{bottom:.125rem;right:.125rem;width:1rem;height:1rem;font-size:var(--font-xs);border-radius:.1875rem}.collection-manager{position:absolute;top:2rem;left:50%;transform:translate(-50%);background:var(--bg-dark);border:1px solid var(--bg-light);border-radius:var(--radius-md);padding:var(--space-sm);box-shadow:0 .5rem 1.5rem #00000080;z-index:200;display:flex;gap:var(--space-xs);align-items:center;white-space:nowrap}.collection-manager-input{background:var(--bg-darker);border:1px solid var(--bg-lighter);color:var(--text-primary);padding:.25rem .5rem;font-size:var(--font-sm);border-radius:var(--radius-sm);outline:none;width:10rem}.collection-manager-input:focus{border-color:var(--brand-gold-subtle)}.collection-manager-btn{background:var(--bg-medium);border:1px solid var(--bg-lighter);color:var(--text-secondary);padding:.25rem .5rem;font-size:var(--font-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.collection-manager-btn:hover{background:var(--bg-lighter);color:var(--text-primary)}.collection-manager-btn.save:hover{border-color:var(--brand-gold-subtle)}.collection-manager-btn.danger{color:var(--color-error)}.collection-manager-btn.danger:hover{background:var(--color-danger-bg)}.collection-manager-btn:disabled{opacity:.5;cursor:default}.collection-manager-warn{font-size:var(--font-xs);color:var(--color-error)}.collection-manager-actions,.collection-manager-rename,.collection-manager-confirm{display:flex;gap:var(--space-xs);align-items:center}.collection-share-section{display:flex;flex-direction:column;gap:var(--space-xs);min-width:14rem}.collection-share-header{display:flex;justify-content:space-between;align-items:center}.collection-share-title{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.collection-share-form{display:flex;gap:var(--space-xs);align-items:center;flex-wrap:wrap}.collection-share-role{display:flex;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);overflow:hidden}.collection-share-role-btn{background:var(--bg-medium);border:none;color:var(--text-secondary);padding:.2rem .4rem;font-size:var(--font-xs);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.collection-share-role-btn:hover{background:var(--bg-lighter)}.collection-share-role-btn.active{background:var(--brand-gold-subtle);color:var(--text-primary)}.collection-share-error{font-size:var(--font-xs);color:var(--color-error)}.collection-share-loading{font-size:var(--font-xs);color:var(--text-muted)}.collection-share-list{display:flex;flex-direction:column;gap:.2rem;max-height:8rem;overflow-y:auto}.collection-share-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-xs);padding:.15rem 0}.collection-share-name{color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collection-share-badge{padding:.1rem .35rem;border-radius:var(--radius-sm);font-size:.65rem;text-transform:uppercase;font-weight:600;letter-spacing:.03em}.collection-share-badge.viewer{background:var(--bg-lighter);color:var(--text-secondary)}.collection-share-badge.editor{background:var(--brand-gold-subtle);color:var(--text-primary)}.collection-share-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:var(--font-sm);padding:0 .2rem;line-height:1;transition:color var(--transition-fast)}.collection-share-remove:hover{color:var(--color-error)}.collection-share-notice{font-size:var(--font-xs);color:var(--text-secondary);font-style:italic}.collection-symbol-section{display:flex;flex-direction:column;gap:var(--space-xs);min-width:14rem}.symbol-toggle-row{display:flex;align-items:center;gap:var(--space-xs);cursor:pointer;font-size:var(--font-sm);color:var(--text-secondary)}.symbol-toggle-label{-webkit-user-select:none;user-select:none}.symbol-picker{display:flex;gap:.2rem;flex-wrap:wrap;align-items:center}.symbol-preset{background:var(--bg-medium);border:1px solid var(--bg-lighter);color:var(--text-secondary);padding:.2rem .4rem;font-size:var(--font-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);min-width:1.6rem;text-align:center}.symbol-preset:hover{background:var(--bg-lighter);color:var(--text-primary)}.symbol-preset.active{background:var(--brand-gold-subtle);color:var(--text-primary);border-color:var(--brand-gold-subtle)}.symbol-custom-input{width:3rem!important;text-align:center}.symbol-item-types{display:flex;flex-direction:column;gap:.15rem}.symbol-type-checkbox{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-xs);color:var(--text-secondary);cursor:pointer}.symbol-type-checkbox input{accent-color:var(--brand-gold-subtle)}.collections-actions{display:flex;align-items:center;gap:var(--space-xs)}.collections-toolbar-btn{display:flex;align-items:center;justify-content:center;background:var(--bg-dark);border:1px solid var(--brand-gold-subtle);color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.collections-toolbar-btn:hover{background:var(--bg-lighter);color:var(--text-primary);border-color:var(--brand-gold-subtle)}.toolbar-popover{position:relative}.toolbar-popover-panel{position:absolute;bottom:calc(100% + .25rem);right:0;background:var(--bg-dark);border:1px solid var(--bg-light);border-radius:var(--radius-sm);padding:var(--space-xs);box-shadow:0 .5rem 1.5rem #00000080;z-index:300;display:flex;gap:var(--space-xs);align-items:center;white-space:nowrap}.collections-gear-empty{font-size:var(--font-sm);color:var(--text-dimmed);padding:var(--space-xs) var(--space-sm);white-space:nowrap}.collections-gear-item{display:block;width:100%;background:none;border:none;color:var(--text-secondary);font-size:var(--font-sm);text-align:left;padding:var(--space-xs) var(--space-sm);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collections-gear-item:hover{background:var(--bg-light);color:var(--text-primary)}.gear-menu-column{display:flex;flex-direction:column;gap:var(--space-xs);min-width:8rem}.gear-menu-back{background:none;border:none;color:var(--text-muted);font-size:var(--font-sm);cursor:pointer;text-align:left;padding:var(--space-xs) var(--space-sm);border-top:1px solid var(--bg-light);transition:color var(--transition-fast)}.gear-menu-back:hover{color:var(--text-primary)}.toolbar-popover-panel .collection-manager{position:static;transform:none;box-shadow:none;border:none;padding:0}.toolbar-popover-panel .collections-gear-item{display:block}.collapsed-strip-actions .collections-actions{flex-direction:column}.collapsed-strip-column:has(.popup-open){z-index:300;opacity:1}.collapsed-strip-actions .toolbar-popover-panel{top:50%;bottom:auto;left:calc(100% + .25rem);right:auto;transform:translateY(calc(-1 * var(--space-xs) - .5em))}.sidebar-stack{display:flex;flex-shrink:0;position:sticky;top:var(--space-md);height:calc(100vh - var(--space-2xl));align-self:flex-start;z-index:1}.sidebar-stack:has(.popup-open){z-index:300}.sidebar-stack-left,.sidebar-stack-right{flex-direction:row}.collapsed-strip-column{display:flex;flex-direction:column;align-items:center;flex-shrink:0;position:relative;z-index:5}.sidebar-focus-btn{align-self:flex-start;margin:2px}.collapsed-strip-actions{display:flex;justify-content:center;padding:2px}.collapsed-strip{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:2px;flex-shrink:0}.collapsed-tab{writing-mode:vertical-rl;text-orientation:mixed;background:var(--bg-dark);color:var(--text-secondary);cursor:pointer;padding:.5rem .25rem;font-size:var(--font-xs);text-transform:uppercase;white-space:nowrap;border:none;border-radius:var(--radius-sm);box-shadow:0 .125rem .375rem #0006;transition:background var(--transition-normal),color var(--transition-normal),box-shadow var(--transition-normal);position:relative;overflow:hidden}.collapsed-tab:hover{background:var(--bg-medium);box-shadow:0 .25rem .625rem #0009}.collapsed-tab.collapsed-tab-grid-active{background:linear-gradient(to right,var(--bg-dark),var(--bg-darkest));color:var(--brand-gold);cursor:default;font-weight:600;box-shadow:none;border-right:none}.collapsed-tab.collapsed-tab-grid-active .collapsed-tab-label{color:var(--brand-gold)}.sidebar-stack-right .collapsed-tab.collapsed-tab-grid-active{background:linear-gradient(to left,var(--bg-dark),var(--bg-darkest))}.collapsed-tab.collapsed-tab-grid-active:hover{background:linear-gradient(to right,var(--bg-dark),var(--bg-darkest));box-shadow:none}.sidebar-stack-right .collapsed-tab.collapsed-tab-grid-active:hover{background:linear-gradient(to left,var(--bg-dark),var(--bg-darkest))}.collapsed-tab.collapsed-tab-grid-active:hover .collapsed-tab-label{color:var(--brand-gold)}.collapsed-tab.collapsed-tab-sidebar-open{background:#b491281f;color:var(--text-dimmed)}.collapsed-tab.collapsed-tab-sidebar-open:hover{background:#b4912833}.collapsed-tab.collapsed-tab-sidebar-open .collapsed-tab-sidebar-btn{opacity:.7}.collapsed-tab-label{overflow:hidden;text-overflow:ellipsis;display:block;transition:color var(--transition-normal)}.collapsed-tab:hover .collapsed-tab-label{color:var(--text-primary)}.collapsed-tab-sidebar-btn{all:unset;cursor:pointer;position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;padding:.15rem 0;writing-mode:horizontal-tb;opacity:0;transition:opacity var(--transition-normal);background:linear-gradient(to bottom,transparent,rgba(180,145,40,.3) 40%,rgba(180,145,40,.5));color:#b49128b3;border-radius:0 0 var(--radius-sm) var(--radius-sm)}.collapsed-tab:hover .collapsed-tab-sidebar-btn{opacity:1}.collapsed-tab-sidebar-btn:hover{background:linear-gradient(to bottom,transparent,rgba(212,175,55,.4) 40%,rgba(212,175,55,.7));color:#d4af37e6}.collapsed-tab.collapsed-tab-ghost{opacity:.4;border:1px dashed var(--brand-gold-subtle);background:#b4912814;cursor:default;pointer-events:none;animation:ghost-tab-appear .15s ease-out}@keyframes ghost-tab-appear{0%{opacity:0;transform:scaleY(.5)}to{opacity:.4;transform:scaleY(1)}}.collapsed-strip-add-wrapper{position:relative}.collapsed-tab-add{background:var(--bg-dark);border:1px dashed var(--bg-lighter);color:var(--text-dimmed);cursor:pointer;padding:.375rem .5rem;font-size:var(--font-sm);border-radius:var(--radius-sm);transition:background var(--transition-normal),color var(--transition-normal),border-color var(--transition-normal);line-height:1}.collapsed-tab-add:hover{background:var(--bg-lighter);color:var(--text-primary);border-color:var(--brand-gold-subtle)}.sidebar-expanded-group{display:flex;flex-direction:row;height:100%}.sidebar-panel-wrapper{position:relative;height:100%;overflow:hidden;animation:sidebar-slide-in .25s ease-out}.sidebar-panel-wrapper.sidebar-closing{animation:sidebar-slide-out .25s ease-in forwards}@keyframes sidebar-slide-in{0%{width:0;min-width:0}to{width:4rem;min-width:4rem}}@keyframes sidebar-slide-out{0%{width:4rem;min-width:4rem}to{width:0;min-width:0}}.image-drop-target{outline:.125rem solid var(--brand-gold);background:#d4af371a;box-shadow:0 0 .75rem #d4af374d}.image-drop-rejected{outline:.125rem solid rgba(220,60,60,.7);background:#dc3c3c14}.image-drop-rejected:after{content:"";position:absolute;top:50%;left:50%;width:1rem;height:1rem;transform:translate(-50%,-50%);writing-mode:horizontal-tb;border:.125rem solid rgba(220,60,60,.8);border-radius:50%;background:linear-gradient(to top right,transparent calc(50% - 1px),rgba(220,60,60,.8) calc(50% - 1px),rgba(220,60,60,.8) calc(50% + 1px),transparent calc(50% + 1px));pointer-events:none}.sidebar-panel-wrapper+.sidebar-panel-wrapper{border-left:1px solid var(--bg-light)}.image-card{background:var(--bg-dark);border-radius:var(--radius-lg);overflow:hidden;cursor:var(--cursor-interact);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.image-card:hover{transform:translateY(-.25rem);box-shadow:0 .5rem 1.5rem #0006}.image-container{position:relative;aspect-ratio:4 / 5;background:var(--bg-medium);cursor:var(--cursor-interact)}.image-container:active{cursor:grabbing}.image-container.is-dragging{opacity:.4}.image-drag-preview{width:5rem;height:5rem;border-radius:var(--radius-md);object-fit:cover;box-shadow:0 .5rem 1.5rem #00000080;opacity:.5;pointer-events:none}.node-drag-preview{display:inline-flex;padding:.25rem .5rem;background:var(--bg-darker);border:.125rem solid var(--brand-gold);border-radius:var(--radius-md);box-shadow:0 .5rem 1.5rem #00000080;opacity:.85;pointer-events:none;white-space:nowrap}.node-drag-name{font-size:var(--font-sm);color:var(--text-primary)}.image-card img{width:100%;height:100%;object-fit:cover;display:block}.open-in-tab-btn{bottom:var(--space-sm);right:var(--space-sm);width:1.75rem;height:1.75rem;font-size:var(--font-md)}.hq-btn,.display-hq-btn,.sidebar-hq-btn{position:absolute;background:#a0a0a099;color:var(--text-primary);text-decoration:none;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-normal),background var(--transition-normal);border-radius:50%;font-weight:600;font-size:.625rem}.hq-btn:hover,.display-hq-btn:hover,.sidebar-hq-btn:hover{background:#dc3c3ce6;color:var(--text-primary)}.image-container:hover .hq-btn,.painting-display-image:hover .display-hq-btn,.sidebar-thumbnail-container:hover .sidebar-hq-btn{opacity:1}.hq-btn{bottom:var(--space-sm);left:var(--space-sm);width:1.75rem;height:1.75rem}.display-hq-btn{bottom:var(--space-sm);left:var(--space-sm);width:2rem;height:2rem;font-size:.75rem}.sidebar-hq-btn{bottom:var(--space-xs);left:var(--space-xs);width:1rem;height:1rem;font-size:.5rem}.image-card-delete-btn{position:absolute;top:var(--space-sm);right:var(--space-sm);width:1.75rem;height:1.75rem;border-radius:50%;background:#dc3c3cd9;color:var(--text-primary);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-normal),transform var(--transition-fast);z-index:2}.image-card-delete-btn:hover{background:#dc3c3c;transform:scale(1.15)}.image-card-info{padding:.75rem}.image-card-info h3{font-size:var(--font-md);margin-bottom:var(--space-xs)}.image-card-info p{font-size:var(--font-sm);color:var(--text-muted);margin:.125rem 0}.field-link{cursor:var(--cursor-interact);transition:color var(--transition-normal);text-decoration:none;color:inherit}.field-link:hover{color:var(--brand-gold);text-decoration:underline}.field-link:visited{color:inherit}.field-link:hover:visited{color:var(--brand-gold)}.category-badge{display:inline-block;padding:.125rem var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-xs);text-transform:uppercase;margin-top:var(--space-sm)}.category-badge.similar{background:var(--color-success-bg);color:var(--color-success-text)}.category-badge.related{background:var(--color-warning-bg);color:var(--color-warning-text)}.category-badge.discovery{background:var(--color-danger-bg);color:var(--color-error)}.favorite-btn{background:none;border:none;cursor:pointer;font-size:var(--font-md);color:var(--text-dimmed);padding:0 var(--space-xs) 0 0;margin:0;line-height:1;transition:color var(--transition-normal),transform var(--transition-fast)}.favorite-btn:hover{color:var(--brand-gold);transform:scale(1.2)}.favorite-btn.active{color:var(--brand-gold)}.favorite-btn:disabled{opacity:.5;cursor:wait}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(12.5rem,1fr));gap:var(--space-md);padding:var(--space-xs) var(--space-sm)}.image-grid-container{display:flex;flex-direction:column;animation:grid-fade-in .3s ease-out}@keyframes grid-fade-in{0%{opacity:0}to{opacity:1}}.grid-progress{text-align:center;color:var(--text-muted);font-size:var(--font-sm);padding:var(--space-sm) 0}.scroll-sentinel{height:1px;width:100%;visibility:hidden}.loading-more{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl) 0;color:var(--text-muted);font-size:var(--font-md)}.loading-spinner{width:1.25rem;height:1.25rem;border:2px solid var(--bg-lighter);border-top-color:var(--brand-gold);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner--large{width:3rem;height:3rem;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-image-container{position:relative;width:100%;height:100%}.loading-image-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-light)}.loading-image{width:100%;height:100%;object-fit:contain;transition:opacity .2s ease-in-out}.loading-image--loading{opacity:0}.loading-image--loaded{opacity:1}.end-of-results{text-align:center;color:var(--text-dimmed);font-size:var(--font-sm);padding:var(--space-lg) 0;border-top:1px solid var(--bg-light);margin-top:var(--space-md)}.image-viewer{min-height:100vh;background:var(--bg-darkest);display:flex;flex-direction:column;align-items:center;padding:0;padding-bottom:4rem;overflow-y:auto}.image-viewer-controls{display:flex;justify-content:space-between;align-items:center;padding:.75rem var(--space-lg);background:var(--bg-darker);border-bottom:1px solid var(--bg-light)}.image-viewer-hint{color:var(--text-muted);font-size:.8125rem}.image-viewer-info-below{text-align:center;padding:1rem var(--space-lg) 0;margin-top:.5rem}.image-viewer-zoom-hint-gold{font-size:.6875rem;color:var(--brand-gold);display:block;margin-bottom:.75rem}.image-viewer-painting-info{margin-top:.5rem}.image-viewer-painting-info .painting-info-title{font-size:var(--font-xl);font-weight:500;color:var(--text-primary);margin:0}.image-viewer-painting-info .painting-info-artist{font-size:var(--font-md);color:var(--brand-gold);margin:.25rem 0 0}.image-viewer-painting-info .painting-info-date{color:var(--text-muted)}.image-viewer-painting-info .painting-info-details{font-size:var(--font-sm);color:var(--text-muted);margin:.25rem 0 0}.image-viewer-painting-info .painting-info-actions{justify-content:center}.image-viewer-raw-link{color:var(--brand-gold);text-decoration:none;font-size:.8125rem}.image-viewer-raw-link:hover{text-decoration:underline}.image-viewer-container{display:flex;align-items:center;justify-content:center;overflow:hidden;width:100%;flex:1}.image-viewer-container .react-transform-component{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-viewer-container img{width:100%;height:100%;object-fit:contain}.image-viewer-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;text-align:center;color:var(--text-primary)}.image-viewer-loading .loading-spinner{width:3rem;height:3rem;border:3px solid var(--border-subtle);border-top-color:var(--brand-gold);border-radius:50%;animation:hq-spin 1s linear infinite;margin:0 auto 1rem}@keyframes hq-spin{to{transform:rotate(360deg)}}.image-viewer-loading p{margin:.5rem 0}.image-viewer-loading .loading-hint{font-size:.8125rem;color:var(--text-muted)}.image-viewer-container.loading{opacity:.3}.image-viewer-links{display:flex;align-items:center;gap:.75rem}.image-viewer-hq-badge{background:var(--brand-gold);color:var(--bg-darkest);padding:.125rem .5rem;border-radius:.25rem;font-size:.6875rem;font-weight:600;letter-spacing:.025em}.image-viewer-error{position:absolute;top:4rem;left:50%;transform:translate(-50%);background:#dc3545e6;color:#fff;padding:.5rem 1rem;border-radius:.25rem;z-index:5;font-size:.875rem}.viewer-area{flex:1;display:flex;flex-direction:column;min-height:0;position:relative}.viewer-area .image-viewer{min-height:calc(100vh - 2rem)}.viewer-mode .main-content{min-height:100vh}.back-to-grid-link{position:fixed;bottom:var(--space-xl);right:6rem;background:var(--bg-dark);color:var(--text-secondary);border:1px solid var(--brand-gold-subtle);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:var(--font-sm);cursor:pointer;box-shadow:0 .25rem 1rem #0006;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);z-index:100}.back-to-grid-link:hover{background:var(--bg-lighter);color:var(--text-primary);border-color:var(--brand-gold);transform:translateY(-.125rem)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-darkest);padding:1rem}.login-card{background:var(--bg-dark);border-radius:.75rem;padding:2.5rem;width:100%;max-width:24rem;box-shadow:0 .5rem 2rem #0006;border:1px solid var(--bg-light)}.login-title{font-size:2rem;font-weight:300;color:var(--text-primary);margin:0 0 .25rem;text-align:center;letter-spacing:.1em}.login-subtitle{color:var(--text-muted);text-align:center;margin:0 0 2rem;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{display:flex;flex-direction:column;gap:.375rem}.login-field label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.login-field input{padding:.75rem;border:1px solid var(--bg-lighter);border-radius:.375rem;font-size:1rem;background:var(--bg-medium);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.login-field input:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 3px #f5c51826}.login-button{background:var(--brand-gold);color:var(--bg-darkest);border:none;padding:.875rem;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-button:hover:not(:disabled){background:#d4a910}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{background:var(--color-danger-bg);color:var(--color-error);padding:.75rem;border-radius:.375rem;font-size:.875rem;text-align:center}.auth-toggle{color:var(--text-muted);text-align:center;margin:1.25rem 0 0;font-size:.8125rem;cursor:pointer;transition:color .2s}.auth-toggle:hover{color:var(--text-secondary)}.upload-card{max-width:40rem}.upload-form{display:flex;flex-direction:column;gap:.25rem}.upload-image-section{margin-bottom:1rem}.upload-file-input{display:none}.upload-file-label{display:block;cursor:pointer;border:2px dashed var(--bg-lighter);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-normal)}.upload-file-label:hover{border-color:var(--brand-gold-subtle)}.upload-file-label.upload-dragging{border-color:var(--brand-gold);background:#f5c5180d}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem;color:var(--text-dimmed)}.upload-placeholder span{font-size:var(--font-sm)}.upload-hint{font-size:var(--font-xs)!important;color:var(--text-dimmed)}.upload-preview{width:100%;max-height:20rem;object-fit:contain;background:var(--bg-darkest)}.upload-input{padding:.625rem .75rem;border:1px solid var(--bg-lighter);border-radius:.375rem;font-size:.9375rem;background:var(--bg-medium);color:var(--text-primary);width:100%;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.upload-input:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 3px #f5c51826}.upload-radio-group{display:flex;gap:1rem;margin-bottom:.5rem}.upload-radio-label{display:flex;align-items:center;gap:.375rem;cursor:pointer;font-size:var(--font-sm);color:var(--text-secondary)}.upload-radio-label input[type=radio]{accent-color:var(--brand-gold)}.upload-field-row{display:flex;gap:1rem}.upload-field-row .settings-field{flex:1;min-width:0}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-dark);border:1px solid var(--bg-lighter);border-radius:0 0 .375rem .375rem;list-style:none;margin:0;padding:0;max-height:10rem;overflow-y:auto;z-index:100;box-shadow:0 .25rem 1rem #0006}.autocomplete-dropdown li{padding:.5rem .75rem;cursor:pointer;font-size:var(--font-sm);color:var(--text-secondary);transition:background var(--transition-fast)}.autocomplete-dropdown li:hover{background:var(--bg-lighter);color:var(--text-primary)}.upload-btn{padding:.625rem 1.25rem;border:1px solid var(--brand-gold);background:var(--brand-gold);color:var(--bg-darkest);font-size:var(--font-sm);font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-normal),opacity var(--transition-normal)}.upload-btn:hover:not(:disabled){background:var(--brand-gold-bright)}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.upload-btn-secondary{background:transparent;color:var(--text-secondary);border-color:var(--bg-lighter)}.upload-btn-secondary:hover:not(:disabled){background:var(--bg-lighter);color:var(--text-primary)}.upload-submit{margin-top:.5rem;align-self:flex-start}.upload-success{text-align:center;padding:2rem 0;color:var(--text-secondary)}.upload-success p{font-size:var(--font-md);margin-bottom:1.5rem}.upload-success-actions{display:flex;gap:1rem;justify-content:center}@media(max-width:600px){.upload-field-row{flex-direction:column;gap:0}}.page-container{display:flex;align-items:flex-start;justify-content:center;padding:0}.page-card{background:none;border:none;padding:var(--space-lg) 2rem var(--space-md);width:100%;max-width:56rem;box-shadow:none}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.page-title{font-size:var(--font-sm);font-weight:500;color:var(--text-primary);margin:0;letter-spacing:.04em}.page-link{display:flex;align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:0;font-size:var(--font-sm);font-weight:500;letter-spacing:.04em;transition:color .2s}.page-link:hover{color:var(--brand-gold)}.page-tabs{display:flex;justify-content:flex-start;gap:2px}.page-tab{background:var(--bg-medium);border:none;color:var(--text-muted);font-size:var(--font-sm);font-weight:500;letter-spacing:.04em;padding:var(--space-xs) var(--space-md);cursor:pointer;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:color .2s,background .2s}.page-tab:hover{color:var(--text-primary);background:var(--bg-light)}.page-tab.active{background:var(--bg-dark);color:var(--text-primary)}.page-section{background:var(--bg-dark);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm)}.page-tabs+.page-section{border-top-left-radius:0}.profile-other-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-sm);margin-bottom:var(--space-sm);border-bottom:1px solid var(--bg-lighter)}.profile-other-info{display:flex;flex-direction:column;gap:.125rem}.profile-other-name{font-size:var(--font-sm);font-weight:500;color:var(--text-primary);letter-spacing:.04em}.profile-follow-counts{font-size:var(--font-xs);color:var(--text-muted)}.profile-feed-section{margin-top:var(--space-md)}.page-placeholder{font-size:var(--font-sm);color:var(--text-muted);letter-spacing:.04em}.onview-pair{position:relative;display:inline-flex}.onview-pair-toggle{display:inline-flex;align-items:center;justify-content:center;position:relative;width:34px;height:34px;background:var(--bg-dark);border:1px solid var(--bg-lighter);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.onview-pair-toggle:hover{color:var(--text-primary);border-color:var(--brand-gold-subtle)}.onview-pair-toggle.is-paired{color:var(--brand-gold);border-color:var(--brand-gold-subtle)}.onview-pair-dot{position:absolute;top:4px;right:4px;width:7px;height:7px;border-radius:50%;background:var(--brand-gold)}.onview-pair-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:1500;width:250px;padding:14px;background:var(--bg-medium);border:1px solid var(--bg-lighter);border-radius:var(--radius-md);box-shadow:0 8px 28px #00000080}.onview-pair-title{color:var(--brand-gold);font-size:var(--font-sm);font-weight:600;margin-bottom:6px}.onview-pair-hint{color:var(--text-secondary);font-size:var(--font-xs);line-height:1.45;margin:0 0 10px}.onview-pair-status{color:var(--text-primary);font-size:var(--font-sm);margin:0 0 6px}.onview-pair-status strong{color:var(--brand-gold);letter-spacing:1px}.onview-pair-input{width:100%;box-sizing:border-box;padding:8px 10px;margin-bottom:8px;background:var(--bg-dark);border:1px solid var(--bg-lighter);border-radius:var(--radius-md);color:var(--text-primary);font-size:18px;letter-spacing:4px;text-align:center;text-transform:uppercase}.onview-pair-input:focus{outline:none;border-color:var(--brand-gold-subtle)}.onview-pair-btn{width:100%;padding:8px 10px;background:var(--brand-gold);color:#1a1a1a;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:opacity var(--transition-fast)}.onview-pair-btn:hover{opacity:.9}.onview-pair-btn:disabled{opacity:.4;cursor:default}.onview-pair-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--bg-lighter)}.onview-pair-btn-secondary:hover{color:var(--text-primary);border-color:var(--brand-gold-subtle);opacity:1}.onview-pair-error{color:#e0786b;font-size:var(--font-xs);margin:8px 0 0}.search-bar{display:flex;align-items:center}.search-form{display:flex}.search-field-select{padding:var(--searchbar-padding-v) .75rem;font-size:var(--searchbar-font);border:var(--searchbar-border) solid transparent;border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);background:var(--bg-lighter);color:var(--text-primary);cursor:pointer;outline:none}.search-field-select:focus{background:var(--bg-lightest)}.search-field-select option{background:var(--bg-dark);color:var(--text-primary)}.search-input{padding:var(--searchbar-padding-v) var(--space-md);font-size:var(--searchbar-font);border:var(--searchbar-border) solid transparent;border-left:none;border-right:none;border-radius:0;background:var(--bg-light);color:var(--text-primary);width:15rem;outline:none}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{background:var(--bg-light)}.search-btn{padding:var(--searchbar-padding-v) .75rem;font-size:var(--searchbar-font);border:var(--searchbar-border) solid transparent;border-left:none;border-right:none;border-radius:0;background:var(--bg-light);color:var(--brand-gold);cursor:pointer;font-weight:500;transition:background var(--transition-normal);display:flex;align-items:center;justify-content:center}.search-btn:hover{background:var(--bg-light)}.favorites-dropdown{position:relative}.user-dropdown-menu{position:absolute;top:100%;right:0;z-index:300;min-width:10rem;background:var(--bg-dark);border:1px solid var(--bg-lighter);border-radius:var(--radius-md);box-shadow:0 .5rem 1.5rem #00000080;padding:.25rem 0;margin-top:.25rem}.user-menu-item{display:block;width:100%;padding:.5rem .75rem;background:none;border:none;color:var(--text-secondary);font-size:var(--font-sm);text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.user-menu-item:hover{background:var(--bg-light);color:var(--text-primary)}.user-menu-signout:hover{color:var(--color-error)}.user-menu-divider{height:1px;background:var(--bg-light)}.notification-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-error, #e53e3e);color:#fff;font-size:.5625rem;font-weight:700;min-width:1rem;height:1rem;border-radius:.5rem;padding:0 .25rem;margin-left:.375rem;line-height:1;vertical-align:middle}.profile-overlay{background:var(--bg-dark);border:1px solid var(--bg-light);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:var(--space-lg);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.profile-delete-overlay{border-color:var(--color-error)}.profile-overlay-thumb{width:8rem;height:8rem;object-fit:cover;border-radius:var(--radius-md)}.profile-overlay-title{font-size:var(--font-lg);color:var(--text-primary);margin:0;text-align:center}.profile-overlay-prompt{font-size:var(--font-md);color:var(--text-secondary);margin:0}.profile-overlay-actions{display:flex;gap:var(--space-sm)}.profile-overlay-btn{background:none;border:1px solid var(--bg-lighter);color:var(--text-muted);padding:.375rem 1rem;border-radius:var(--radius-sm);font-size:var(--font-sm);cursor:pointer;transition:border-color .2s,color .2s}.profile-overlay-btn:hover{border-color:var(--brand-gold);color:var(--brand-gold)}.profile-overlay-btn:disabled{opacity:.5;cursor:not-allowed}.profile-overlay-btn-delete{border-color:var(--color-error);color:var(--color-error)}.profile-overlay-btn-delete:hover{background:#dc3c3c1a}.profile-overlay-btn-save{border-color:#50b45066;color:var(--color-success-text)}.profile-overlay-btn-save:hover{border-color:var(--color-success-text)}.profile-edit-fields{display:flex;flex-direction:column;gap:.375rem;width:100%}.profile-edit-label{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-sm);color:var(--text-dimmed)}.profile-edit-label span{width:5rem;flex-shrink:0;text-align:right}.profile-edit-label input{flex:1;background:var(--bg-medium);border:1px solid var(--bg-lighter);color:var(--text-primary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:var(--font-sm)}.profile-edit-label input:focus{outline:none;border-color:var(--brand-gold)}.settings-inner{display:flex;flex-direction:column;gap:var(--space-sm)}.settings-form-section{border-top:1px solid var(--bg-lighter);padding-top:var(--space-md)}.settings-form-section:first-child{border-top:none;padding-top:0}.settings-loading{text-align:center;padding:3rem;color:var(--text-muted);font-size:var(--font-sm)}.settings-section-title{font-size:var(--font-sm);font-weight:500;color:var(--text-primary);margin:0 0 var(--space-sm);letter-spacing:.04em}.settings-subsection-title{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.04em;margin:var(--space-sm) 0 var(--space-xs)}.settings-field{display:flex;flex-direction:column;gap:.25rem;margin-bottom:var(--space-sm)}.settings-field label{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.04em}.settings-field input{padding:.5rem .625rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);background:var(--bg-medium);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.settings-field input:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 2px #f5c51826}.settings-field input:disabled{background:var(--bg-darker);color:var(--text-secondary);cursor:not-allowed}.settings-hint{font-size:var(--font-sm);color:var(--text-dimmed)}.settings-toggle-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:var(--space-sm)}.settings-toggle{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-sm);color:var(--text-secondary);cursor:default}.toggle-switch{position:relative;width:2.75rem;height:1.5rem;background:var(--bg-lighter);border:none;border-radius:.75rem;cursor:pointer;transition:background .2s;padding:0}.toggle-switch.on{background:var(--bg-lighter)}.toggle-knob{position:absolute;top:.1875rem;left:.1875rem;width:1.125rem;height:1.125rem;background:var(--text-primary);border-radius:50%;transition:transform .2s}.toggle-switch.on .toggle-knob{transform:translate(1.25rem)}.settings-save-btn{background:var(--bg-lighter);color:var(--text-primary);border:none;border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:500;letter-spacing:.04em;cursor:pointer;transition:background .2s;display:block;margin:0 auto;padding:.4rem 1.5rem}.settings-save-btn:hover:not(:disabled){background:var(--bg-light)}.settings-save-btn:disabled{opacity:.6;cursor:not-allowed}.settings-subsection{margin-bottom:var(--space-sm)}.settings-subsection-label{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.04em;display:flex;align-items:center;gap:.375rem;margin-bottom:.25rem}.settings-subsection-content{padding-left:.75rem;display:flex;flex-direction:column;gap:.25rem}.settings-inline-value{font-size:var(--font-sm);color:var(--text-primary);display:flex;align-items:center;gap:.375rem}.settings-inline-input{padding:.25rem .5rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);background:var(--bg-medium);color:var(--text-primary);width:100%}.settings-inline-input:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 2px #f5c51826}.settings-checkbox{display:flex;align-items:center;gap:.375rem;font-size:var(--font-sm);color:var(--text-secondary);cursor:pointer}.settings-check-box{width:.875rem;height:.875rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--bg-medium);flex-shrink:0;transition:border-color .15s,background .15s}.settings-check-box.checked{border-color:var(--text-primary);background:var(--text-primary);color:var(--bg-darkest)}.settings-msg{padding:.5rem .625rem;border-radius:var(--radius-sm);font-size:var(--font-sm);margin-bottom:var(--space-sm)}.settings-msg-success{background:var(--color-success-bg);color:var(--color-success-text)}.settings-msg-error{background:var(--color-danger-bg);color:var(--color-error)}.upload-list{display:flex;flex-direction:column;gap:0;padding-left:.75rem}.upload-list-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs);border-radius:var(--radius-md);cursor:pointer;transition:background .15s}.upload-list-row:hover{background:var(--bg-light)}.upload-list-row.selected{background:#c8aa321a}.upload-list-thumb-wrap{position:relative;flex-shrink:0}.upload-list-checkbox{position:absolute;top:3px;left:3px;width:1rem;height:1rem;border:1px solid rgba(255,255,255,.6);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:#0006;transition:border-color .15s,background .15s}.upload-list-checkbox.checked{border-color:var(--brand-gold);background:var(--brand-gold);color:var(--bg-darkest)}.upload-list-thumb{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--bg-medium)}.upload-list-meta{display:flex;flex-direction:column;gap:.125rem;min-width:0}.upload-list-title{font-size:var(--font-sm);color:var(--text-primary);font-weight:400;text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-list-field{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-header-links{display:flex;gap:var(--space-sm)}.profile-section-header{display:flex;align-items:center;gap:var(--space-xs);padding:0 0 var(--space-xs)}.profile-section-title{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500;letter-spacing:.04em;text-transform:capitalize}.profile-section-btn{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:none;border:none;color:var(--text-primary);padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s}.profile-section-btn:hover,.profile-section-btn.active{color:var(--brand-gold)}.profile-section-chevron{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;color:var(--text-dimmed);transition:color .2s}.profile-section-chevron:hover{color:var(--brand-gold)}.profile-section-chevron svg{transition:transform .2s}.profile-section-chevron svg.chevron-open{transform:rotate(90deg)}.profile-subsection-header{display:flex;align-items:center;gap:var(--space-xs);padding:2px 0 2px .75rem}.profile-subsection-title{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500;text-transform:capitalize;letter-spacing:.04em}.profile-delete-confirm-btn{background:var(--color-danger-bg);color:var(--bg-darkest);border:1px solid var(--color-error);padding:0 .5rem;border-radius:var(--radius-md);font-size:var(--font-xs);line-height:1.4;cursor:pointer;transition:opacity .15s}.profile-delete-confirm-btn:hover:not(:disabled){opacity:.85}.profile-delete-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.messaging-page{display:flex;min-height:20rem}.conv-list{flex:1;display:flex;flex-direction:column;min-width:0}.conv-list-header{display:flex;align-items:center;gap:var(--space-sm);padding:0 0 var(--space-sm)}.conv-list-title{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.04em}.conv-new-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.125rem .25rem;display:flex;align-items:center;gap:.25rem;border-radius:var(--radius-sm);font-size:var(--font-xs);transition:color var(--transition-fast),background var(--transition-fast)}.conv-new-btn:hover{color:var(--text-primary);background:var(--bg-lighter)}.conv-list-conversations{flex:1;overflow-y:auto;min-width:0}.conv-list-empty{padding:var(--space-md);text-align:center;font-size:var(--font-sm);color:var(--text-muted)}.conv-search{width:auto;padding:.375rem .625rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);background:var(--bg-medium);color:var(--text-primary);margin:0 2rem var(--space-sm)}.conv-search:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 2px #f5c51826}.conv-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.3rem 0;background:none;border:none;border-bottom:1px solid var(--bg-light);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.conv-item:hover,.conv-item.active{background:var(--bg-light)}.conv-item-name{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:8rem;flex-shrink:0}.conv-item.unread .conv-item-name{color:var(--text-primary);font-weight:600}.conv-item-preview{font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.conv-item-time{font-size:var(--font-xs);color:var(--text-dimmed);flex-shrink:0;margin-left:auto}.conv-item-badge{background:var(--brand-gold);color:var(--bg-darkest);font-size:.5625rem;font-weight:700;min-width:1rem;height:1rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;padding:0 .25rem;flex-shrink:0;margin-left:.25rem}.msg-back-btn{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:none;border:none;color:var(--text-muted);padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s}.msg-back-btn:hover{color:var(--text-primary)}.msg-thread{display:flex;flex-direction:column;flex:1;min-width:0}.msg-thread-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-bottom:1px solid var(--bg-lighter)}.msg-thread-header-info{display:flex;flex-direction:column;gap:.0625rem;flex:1;min-width:0}.msg-thread-subject{font-size:var(--font-sm);font-weight:500;color:var(--text-primary);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-thread-name{font-size:var(--font-xs);color:var(--text-muted)}.msg-thread-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column}.msg-loading,.msg-empty{text-align:center;padding:var(--space-md);font-size:var(--font-sm);color:var(--text-muted)}.msg-load-more{background:none;border:none;color:var(--text-muted);font-size:var(--font-xs);cursor:pointer;padding:var(--space-xs);text-align:center;transition:color var(--transition-fast)}.msg-load-more:hover{color:var(--text-primary)}.msg-row{display:flex;align-items:flex-start;gap:.375rem;padding:var(--space-sm);border-bottom:1px solid var(--bg-light)}.msg-row.own{background:var(--bg-light)}.msg-row.selected{background:#c8aa321a}.msg-row-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.msg-row-header{display:flex;align-items:baseline;gap:var(--space-sm)}.msg-row-author{font-size:var(--font-xs);font-weight:600;color:var(--text-primary);letter-spacing:.02em}.msg-row.own .msg-row-author{color:var(--brand-gold)}.msg-row-time{font-size:.625rem;color:var(--text-dimmed);margin-left:auto;flex-shrink:0}.msg-row-content{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;word-break:break-word}.msg-row.own .msg-row-content{color:var(--text-primary)}.compose-bar{display:flex;flex-direction:column;gap:.375rem;padding:var(--space-sm)}.compose-bar-input-row{display:flex;flex-direction:column;gap:.375rem}.compose-input{width:100%;padding:.5rem .625rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);font-family:inherit;background:var(--bg-medium);color:var(--text-primary);resize:vertical;min-height:10rem;flex:1;line-height:1.5}.compose-input:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 2px #f5c51826}.compose-send-btn{align-self:flex-end;background:var(--bg-lighter);border:none;color:var(--text-primary);padding:.3rem .75rem;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:500;display:flex;align-items:center;gap:.375rem;cursor:pointer;transition:background var(--transition-fast)}.compose-send-btn:hover:not(:disabled){background:var(--bg-lightest)}.compose-send-btn:disabled{opacity:.4;cursor:not-allowed}.new-conv-inline{flex:1;display:flex;flex-direction:column;background:var(--bg-medium);min-width:0}.new-conv-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-bottom:1px solid var(--bg-lighter);font-size:var(--font-sm);font-weight:500;color:var(--text-primary);letter-spacing:.04em}.new-conv-form{flex:1;display:flex;flex-direction:column;padding:var(--space-sm);gap:var(--space-sm)}.new-conv-input{width:100%;padding:.375rem .625rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);background:var(--bg-medium);color:var(--text-primary)}.new-conv-input:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 2px #f5c51826}.new-conv-error{font-size:var(--font-xs);color:var(--color-error)}.new-conv-input:disabled{opacity:.6;background:var(--bg-dark)}.new-conv-message{width:100%;padding:.375rem .625rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);font-family:inherit;background:var(--bg-medium);color:var(--text-primary);resize:none;line-height:1.4;flex:1;min-height:6rem}.new-conv-message:focus{outline:none;border-color:var(--brand-gold);box-shadow:0 0 0 2px #f5c51826}.new-conv-submit{width:100%;padding:.375rem;border:none;border-radius:var(--radius-sm);background:var(--bg-lighter);color:var(--text-primary);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.new-conv-submit:hover:not(:disabled){background:var(--bg-lightest)}.new-conv-submit:disabled{opacity:.5;cursor:not-allowed}.msg-trash-btn{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:none;border:none;color:var(--text-muted);padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s}.msg-trash-btn:hover,.msg-trash-btn.active{color:var(--brand-gold)}.msg-delete-confirm-btn{background:var(--color-danger-bg);color:var(--bg-darkest);border:1px solid var(--color-error);padding:.125rem .5rem;border-radius:var(--radius-md);font-size:var(--font-xs);cursor:pointer;transition:opacity .15s}.msg-delete-confirm-btn:hover:not(:disabled){opacity:.85}.msg-delete-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.msg-select-check{width:1rem;height:1rem;border:1px solid var(--text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:transparent;transition:border-color .15s,background .15s;margin-top:.125rem}.msg-select-check.checked{border-color:var(--brand-gold);background:var(--brand-gold);color:var(--bg-darkest)}.msg-row.own .msg-select-check~.msg-row-body{cursor:pointer}.pending-shares{border-bottom:1px solid var(--bg-lighter);padding:var(--space-sm);display:flex;flex-direction:column;gap:.375rem}.pending-shares-title{font-size:var(--font-xs);font-weight:600;color:var(--brand-gold);letter-spacing:.04em}.pending-share-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs)}.pending-share-info{display:flex;flex-direction:column;gap:.0625rem;min-width:0;flex:1}.pending-share-name{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pending-share-owner{font-size:var(--font-xs);color:var(--text-muted)}.pending-share-actions{display:flex;gap:.25rem;flex-shrink:0}.pending-share-btn{background:var(--bg-medium);border:1px solid var(--bg-lighter);color:var(--text-secondary);padding:.15rem .4rem;font-size:var(--font-xs);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.pending-share-btn:hover{background:var(--bg-lighter);color:var(--text-primary)}.pending-share-btn.accept:hover{border-color:var(--brand-gold-subtle)}.pending-share-btn.decline:hover{color:var(--color-error)}.compose-attachment{display:flex;align-items:center;gap:.375rem;padding:.25rem .375rem;background:var(--bg-light);border:1px solid var(--bg-lighter);border-radius:var(--radius-md)}.compose-attachment-thumb{width:2rem;height:2rem;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.compose-attachment-label{font-size:var(--font-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.compose-attachment-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.125rem;display:flex;align-items:center;flex-shrink:0;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.compose-attachment-dismiss:hover{color:var(--text-primary)}.msg-painting-ref{display:flex;align-items:center;gap:.375rem;padding:.25rem;margin-bottom:.25rem;background:#00000026;border-radius:var(--radius-sm)}.msg-painting-thumb{width:1.75rem;height:1.75rem;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.msg-painting-label{font-size:var(--font-xs);color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.follow-btn{padding:.25rem .75rem;border:1px solid var(--bg-lighter);border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:500;letter-spacing:.04em;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);background:var(--bg-lighter);color:var(--text-primary)}.follow-btn:hover{background:var(--bg-lightest)}.follow-btn.following{background:none;border-color:var(--bg-lighter);color:var(--text-secondary)}.follow-btn.following:hover{border-color:var(--color-error);color:var(--color-error)}.follow-btn.loading{opacity:.5;cursor:not-allowed}.activity-feed{display:flex;flex-direction:column;gap:var(--space-sm)}.feed-title{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.04em}.feed-loading,.feed-empty{font-size:var(--font-sm);color:var(--text-muted);padding:var(--space-sm) 0}.feed-items{display:flex;flex-direction:column;gap:.25rem}.feed-item{display:flex;justify-content:space-between;align-items:baseline;padding:var(--space-xs) 0;border-bottom:1px solid var(--bg-light)}.feed-item:last-child{border-bottom:none}.feed-item-text{font-size:var(--font-sm);color:var(--text-secondary);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-item-name{color:var(--text-primary);font-weight:500}.feed-item-time{font-size:var(--font-xs);color:var(--text-dimmed);flex-shrink:0;margin-left:var(--space-sm)}.feed-load-more{background:none;border:none;color:var(--text-muted);font-size:var(--font-sm);cursor:pointer;padding:var(--space-xs) 0;text-align:center;transition:color var(--transition-fast)}.feed-load-more:hover{color:var(--text-primary)}.node-item-list{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-xs) 0}.node-item-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast);cursor:var(--cursor-interact);text-decoration:none;color:inherit}.node-item-row:hover{background:#ffffff0f}.node-item-row:hover .node-item-name{color:var(--brand-gold)}.node-item-thumb{width:2rem;height:2rem;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.node-item-thumb-placeholder{width:2rem;height:2rem;border-radius:var(--radius-sm);flex-shrink:0;background:#ffffff14}.node-item-name{font-size:var(--font-md);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast)}.node-card{background:var(--bg-dark);border-radius:var(--radius-lg);overflow:hidden;cursor:var(--cursor-interact);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.node-card:hover{transform:translateY(-.25rem);box-shadow:0 .5rem 1.5rem #0006}.node-card-inner{position:relative;aspect-ratio:4 / 5;background:var(--bg-medium)}.node-card-inner img{width:100%;height:100%;object-fit:cover;display:block}.node-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:.75rem .5rem;background:linear-gradient(transparent,#000000bf);display:flex;align-items:flex-end;justify-content:center;min-height:3rem}.node-card-name{color:var(--text-primary);font-size:var(--font-md);font-weight:500;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.8);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3}.collection-tabs-header{background:var(--bg-darkest);padding:var(--space-xs) var(--space-sm) 0 var(--space-2xl)}.collection-tab-bar{display:flex;gap:var(--space-xs)}.collection-tab{padding:.25rem .75rem;font-size:var(--font-xs);font-weight:400;background:var(--bg-dark);color:var(--text-secondary);border:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:pointer;transition:color var(--transition-normal),background var(--transition-normal);white-space:nowrap}.collection-tab:hover{color:var(--text-primary)}.collection-tab.active{background:linear-gradient(to bottom,var(--bg-dark),var(--bg-darkest));color:var(--brand-gold);cursor:default}.collection-tab-content{padding:var(--space-sm) 0}.focus-toggle-wrapper{position:sticky;top:calc(var(--space-md) + 2px);z-index:10;width:0;overflow:visible;flex-shrink:0;align-self:flex-start;margin-left:2px}.focus-toggle-btn{display:flex;align-items:center;justify-content:center;background:var(--bg-dark);border:1px solid var(--brand-gold-subtle);color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:opacity .3s ease,background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.focus-toggle-exit{opacity:.5}.focus-toggle-btn:hover{opacity:1;background:var(--bg-lighter);color:var(--text-primary);border-color:var(--brand-gold-subtle)}@keyframes focus-btn-blur-in{0%{filter:blur(4px);opacity:0}to{filter:blur(0);opacity:1}}@keyframes focus-btn-blur-out{0%{filter:blur(0)}to{filter:blur(4px);opacity:0}}.focus-btn-blurring-in{animation:focus-btn-blur-in .3s ease-out forwards}.focus-btn-blurring-out{animation:focus-btn-blur-out .3s ease-in forwards;pointer-events:none}.sidebar-stack.focus-collapse-left,.sidebar-stack.focus-collapse-right{overflow:hidden;animation:focus-collapse .3s ease-in forwards;pointer-events:none}.sidebar-stack.focus-expand-left,.sidebar-stack.focus-expand-right{overflow:hidden;animation:focus-expand .3s ease-out}@keyframes focus-collapse{0%{max-width:20rem}to{max-width:0}}@keyframes focus-expand{0%{max-width:0}to{max-width:20rem}}:root{--brand-gold: #f5c518;--brand-gold-bright: #ffd633;--brand-gold-subtle: rgba(245, 197, 24, .5);--brand-blue: #4C91FF;--bg-darkest: #1a1a1a;--bg-darker: #252526;--bg-dark: #2a2a2a;--bg-medium: #333;--bg-light: #3a3a3a;--bg-lighter: #4a4a4a;--bg-lightest: #555;--text-primary: #fff;--text-secondary: #ccc;--text-muted: #888;--text-dimmed: #666;--color-error: #d97171;--color-success-bg: #2d5a27;--color-success-text: #7fd971;--color-warning-bg: #4a4a27;--color-warning-text: #d9d971;--color-danger-bg: #5a2727;--space-unit: 1rem;--space-xs: calc(var(--space-unit) * .25);--space-sm: calc(var(--space-unit) * .5);--space-md: var(--space-unit);--space-lg: calc(var(--space-unit) * 1.25);--space-xl: calc(var(--space-unit) * 1.5);--space-2xl: calc(var(--space-unit) * 2);--space-3xl: calc(var(--space-unit) * 3.75);--font-xs: .625rem;--font-sm: .75rem;--font-md: .875rem;--font-lg: 1rem;--font-xl: 1.125rem;--font-2xl: 1.5rem;--font-3xl: 2rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--border-gold: 1px solid var(--brand-gold-subtle);--searchbar-font: var(--font-sm);--searchbar-padding-v: .375rem;--searchbar-border: 1px;--cursor-interact: url(/cursors/cursor-hand.svg) 8 0, pointer;--transition-fast: .15s;--transition-normal: .2s}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-darkest);color:var(--text-primary);min-height:100vh}.app{padding:var(--space-sm)}.app-header{text-align:center;margin-bottom:var(--space-md);padding:0 var(--space-lg)}.header-title-row{display:flex;justify-content:center;align-items:baseline;position:relative;margin-bottom:var(--space-xs)}.app-header h1{font-size:var(--font-2xl);margin:0}.header-row{display:flex;justify-content:center;align-items:center;margin-bottom:var(--space-xs)}.favorites-dropdown-toggle{padding:var(--searchbar-padding-v) .75rem;font-size:var(--searchbar-font);border:var(--searchbar-border) solid transparent;border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;background:var(--bg-lighter);color:var(--text-primary);cursor:pointer;transition:background var(--transition-normal)}.favorites-dropdown-toggle:hover{background:var(--bg-lighter)}.image-card-info h3,.image-card-info p{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.painting-display-image .react-transform-wrapper{width:100%;cursor:grab;overflow:hidden}.painting-display-image .react-transform-wrapper:active{cursor:grabbing}.image-viewer-container .react-transform-wrapper{width:100%;cursor:zoom-in;overflow:hidden}.image-viewer-container .react-transform-wrapper:active{cursor:move}.open-in-tab-btn,.display-open-btn,.sidebar-open-btn{position:absolute;background:#0009;color:var(--brand-gold-subtle);text-decoration:none;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-normal),background var(--transition-normal),color var(--transition-normal);border-radius:50%}.open-in-tab-btn:hover,.display-open-btn:hover,.sidebar-open-btn:hover{background:#f5c518cc;color:var(--bg-darkest)}.image-container:hover .open-in-tab-btn,.painting-display-image:hover .display-open-btn,.sidebar-thumbnail-container:hover .sidebar-open-btn{opacity:1}.gold-outline{border:1.5px solid var(--brand-gold-subtle);box-shadow:0 0 .375rem #f5c51826}.gold-outline:hover{border-color:var(--brand-gold);box-shadow:0 0 .5rem #f5c5184d}.loading{text-align:center;padding:var(--space-3xl);color:var(--text-dimmed);font-size:var(--font-xl)}.error{text-align:center;padding:var(--space-3xl);color:var(--color-error);font-size:var(--font-xl)}.empty-message{text-align:center;padding:var(--space-3xl);color:var(--text-muted);font-size:var(--font-lg)}.main-content{display:flex}.panel-drop-zone{position:fixed;top:0;bottom:0;width:8rem;z-index:60;border:2px dashed transparent;transition:border-color var(--transition-fast),background var(--transition-fast);pointer-events:auto}.panel-drop-zone-left{left:0}.panel-drop-zone-right{right:0}.paintings-area{flex:1;min-width:0}.app.with-sidebar .main-content{flex-direction:row}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-darkest)}.auth-loading-spinner{width:2.5rem;height:2.5rem;border:3px solid var(--bg-lighter);border-top-color:var(--brand-gold);border-radius:50%;animation:spin .8s linear infinite}
