@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";body{margin:0;padding:0}:root{--font-display:"Outfit", sans-serif;--font-sans:"Plus Jakarta Sans", sans-serif;--bg-primary:#080612;--bg-secondary:#0f0b24;--glass-bg:#120e2aa6;--glass-border:#ffffff14;--glass-border-hover:#ffffff2e;--text-primary:#f3f1fd;--text-secondary:#9a95ba;--text-muted:#5e597c;--accent-primary:#8a2be2;--accent-secondary:#00f0ff;--accent-pink:#ff007f;--shadow-sm:0 4px 12px #0003;--shadow-lg:0 16px 40px #0006;--shadow-accent:0 0 25px #8a2be24d;--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--border-radius-sm:8px;--border-radius-md:16px;--border-radius-lg:24px;--theme-transition:background-color .3s ease, color .3s ease, border-color .3s ease}[data-theme=light]{--bg-primary:#f4f0fe;--bg-secondary:#ebe5ff;--glass-bg:#ffffffbf;--glass-border:#8a2be21f;--glass-border-hover:#8a2be247;--text-primary:#1a0a3c;--text-secondary:#5a4a8a;--text-muted:#9a8ec8;--accent-primary:#7b22d4;--accent-secondary:#0090b8;--accent-pink:#cc005f;--shadow-sm:0 4px 12px #8a2be21a;--shadow-lg:0 16px 40px #8a2be226;--shadow-accent:0 0 25px #8a2be233}*{box-sizing:border-box;margin:0;padding:0}*,:before,:after{transition:background-color .28s,border-color .28s,box-shadow .28s}.image-card,.image-card *,.toast,.toast *,.spinner{transition:none}.image-card{will-change:transform, opacity;transition:transform var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal), opacity var(--transition-normal);transform:translate(0,0)}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);min-height:100vh;overflow-x:hidden}body:not([data-theme=light]){background-image:radial-gradient(circle at 10% 20%,#8a2be226 0%,#0000 40%),radial-gradient(circle at 90% 80%,#00f0ff14 0%,#0000 45%);background-attachment:fixed}[data-theme=light] body,body[data-theme=light]{background-image:radial-gradient(circle at 10% 20%,#8a2be214 0%,#0000 40%),radial-gradient(circle at 90% 80%,#0090b80f 0%,#0000 45%);background-attachment:fixed}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.image-card:focus-visible{outline:2px solid var(--accent-primary);outline-offset:3px;border-color:var(--accent-primary)}button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--glass-border);border:2px solid var(--bg-primary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);transition:border-color var(--transition-normal), box-shadow var(--transition-normal)}.glass-panel:hover{border-color:var(--glass-border-hover)}.app-header{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);background:#080612b3;margin-bottom:2rem;position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;max-width:1600px;margin:0 auto;padding:1rem 2rem;display:flex}.logo-section{align-items:center;gap:.75rem;display:flex}.logo-icon{color:var(--accent-secondary);filter:drop-shadow(0 0 8px #00f0ff80)}.logo-text{font-family:var(--font-display);background:linear-gradient(135deg, var(--text-primary) 30%, var(--text-secondary));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.5rem;font-weight:800}.logo-badge{color:var(--accent-secondary);background:#00f0ff1a;border:1px solid #00f0ff33;border-radius:20px;margin-left:.25rem;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.nav-actions{align-items:center;gap:1rem;display:flex}.btn{border-radius:var(--border-radius-sm);font-family:var(--font-sans);cursor:pointer;transition:transform var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);border:1px solid #0000;outline:none;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #8a2be2b3);color:#fff;box-shadow:0 4px 15px #8a2be24d}.btn-primary:hover{background:linear-gradient(135deg, #963cf0, var(--accent-primary));box-shadow:0 6px 20px #8a2be280, var(--shadow-accent)}.btn-secondary{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--glass-border-hover);background:#ffffff14}.btn-accent{color:var(--accent-secondary);background:#00f0ff1a;border:1px solid #00f0ff33}.btn-accent:hover{background:#00f0ff33;box-shadow:0 0 15px #00f0ff4d}.user-profile{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:30px;align-items:center;gap:.75rem;padding:.4rem .8rem;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;text-shadow:0 1px 2px #0000004d;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.user-email{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:.85rem;overflow:hidden}.app-container{grid-template-columns:240px 1fr;gap:2.5rem;max-width:1600px;margin:0 auto;padding:0 2rem 4rem;display:grid}.sidebar-panel{flex-direction:column;gap:1.1rem;max-height:calc(100vh - 130px);padding:1.25rem;display:flex;position:sticky;top:90px;overflow-y:auto}.sidebar-panel::-webkit-scrollbar{width:4px}.sidebar-panel::-webkit-scrollbar-track{background:0 0}.sidebar-panel::-webkit-scrollbar-thumb{background:var(--glass-border-hover);border-radius:4px}.filter-section{flex-direction:column;gap:.4rem;display:flex}.filter-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-left:3px solid var(--accent-primary);padding-left:.5rem;font-size:.95rem;font-weight:700}.filter-options{flex-direction:column;gap:.5rem;display:flex}.filter-btn{border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:1px solid #0000;justify-content:space-between;align-items:center;padding:.45rem .65rem;font-size:.85rem;font-weight:500;display:flex}.filter-btn:hover{color:var(--text-primary);background:#ffffff08}.filter-btn.active{color:var(--text-primary);background:#8a2be21f;border-color:#8a2be240;font-weight:600}.filter-count{color:var(--text-muted);background:#ffffff0d;border-radius:10px;padding:.15rem .4rem;font-size:.75rem}.filter-btn.active .filter-count{color:var(--text-primary);background:#8a2be233}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;display:grid}.stat-card{align-items:center;gap:1rem;padding:1rem;display:flex}.stat-icon-wrapper{border-radius:var(--border-radius-sm);justify-content:center;align-items:center;width:42px;height:42px;display:flex}.stat-info{flex-direction:column;display:flex}.stat-val{font-family:var(--font-display);font-size:1.35rem;font-weight:800}.stat-lbl{color:var(--text-secondary);font-size:.75rem}.stat-mini-bar{background:#ffffff0f;border-radius:2px;height:3px;margin-top:.4rem;overflow:hidden}.stat-mini-fill{border-radius:2px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.stat-sub{color:var(--text-muted);margin-top:.2rem;font-size:.65rem}.stat-chart-card{flex-direction:column;align-items:flex-start;gap:0}.stat-bar-chart{align-items:flex-end;gap:.35rem;width:100%;height:44px;margin-top:.25rem;display:flex}.stat-bar-col{flex-direction:column;flex:1;align-items:center;gap:.2rem;min-width:0;display:flex}.stat-bar-fill{border-radius:3px 3px 0 0;width:100%;transition:height .8s cubic-bezier(.4,0,.2,1)}.stat-bar-label{color:var(--text-muted);text-align:center;font-size:.6rem;font-weight:600}.search-controls{align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.search-input-wrapper{flex:1;position:relative}.search-icon{color:var(--text-muted);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-input{border-radius:var(--border-radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:all var(--transition-fast);padding:.8rem 1rem .8rem 2.8rem;font-size:.95rem}.search-input:focus{border-color:#8a2be280;outline:none;box-shadow:0 0 15px #8a2be233}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.image-card{border-radius:var(--border-radius-md);aspect-ratio:3/4;cursor:pointer;background:var(--bg-secondary);border:1px solid var(--glass-border);will-change:transform, opacity;transition:transform var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal), opacity var(--transition-normal);position:relative;overflow:hidden;transform:translate(0,0)}.image-card.animating-out{opacity:0!important;pointer-events:none!important;transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1)!important;transform:scale(.8)translateY(-15px)!important}.image-card:hover{border-color:var(--glass-border-hover);box-shadow:var(--shadow-lg), 0 0 20px #8a2be226;transform:translateY(-5px)}.card-img-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.card-img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.image-card:hover .card-img{transform:scale(1.06)}.card-overlay{opacity:0;transition:opacity var(--transition-normal);z-index:2;background:linear-gradient(#0000 0%,#08061266 40%,#080612e6 100%);flex-direction:column;justify-content:flex-end;padding:1.25rem;display:flex;position:absolute;inset:0}.image-card:hover .card-overlay{opacity:1}.card-title{font-family:var(--font-display);margin-bottom:.5rem;font-size:1rem;font-weight:700}.card-tags{flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;display:flex}.tag{text-transform:uppercase;border-radius:4px;padding:.15rem .45rem;font-size:.7rem;font-weight:600}.tag-faces{color:var(--accent-secondary);background:#00f0ff26;border:1px solid #00f0ff40}.tag-env{color:#d09eff;background:#8a2be226;border:1px solid #8a2be240}.tag-shot{color:var(--text-primary);border:1px solid var(--glass-border);background:#ffffff14}.card-meta-row{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-top:.25rem;font-size:.75rem;display:flex}.btn-fav-toggle{-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);width:36px;height:36px;color:var(--text-primary);cursor:pointer;z-index:5;transition:all var(--transition-fast);background:#08061299;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:.75rem;right:.75rem}.btn-fav-toggle:hover{background:#080612e6;transform:scale(1.1)}.btn-fav-toggle.is-fav{color:var(--accent-pink);filter:drop-shadow(0 0 5px #ff007f66);background:#ff007f1a;border-color:#ff007f4d}.btn-dislike-toggle{-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);width:36px;height:36px;color:var(--text-primary);cursor:pointer;z-index:5;transition:all var(--transition-fast);background:#08061299;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:.75rem;left:.75rem}.btn-dislike-toggle:hover{background:#080612e6;transform:scale(1.1)}.btn-dislike-toggle.is-disliked{color:#f90;filter:drop-shadow(0 0 5px #ff99004d);background:#ff990026;border-color:#ff99004d}.loading-trigger{flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;padding:3rem 0;display:flex}.spinner{border:3px solid #8a2be21a;border-top-color:var(--accent-primary);will-change:transform;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.skeleton-card{border-radius:var(--border-radius-md);aspect-ratio:3/4;background:var(--bg-secondary);border:1px solid var(--glass-border);position:relative;overflow:hidden}.skeleton-shimmer{will-change:background-position;background:linear-gradient(90deg,#0000 0%,#ffffff0a 40%,#ffffff12 50%,#ffffff0a 60%,#0000 100%) 0 0/200% 100%;animation:1.6s ease-in-out infinite shimmer;position:absolute;inset:0}.skeleton-bottom{flex-direction:column;gap:.5rem;padding:1rem;display:flex;position:absolute;bottom:0;left:0;right:0}.skeleton-line.short{width:60%}.no-results{text-align:center;color:var(--text-secondary);flex-direction:column;grid-column:1/-1;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.no-results-icon{color:var(--text-muted)}.modal-overlay{-webkit-backdrop-filter:blur(12px);z-index:1000;background:#05030aeb;justify-content:center;align-items:center;padding:2rem;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}.lightbox-content{border-radius:var(--border-radius-lg);width:100%;max-width:1200px;height:82vh;max-height:900px;box-shadow:var(--shadow-lg);border:1px solid var(--glass-border);background:var(--bg-secondary);grid-template-columns:1fr 340px;display:grid;position:relative;overflow:hidden}.lightbox-img-pane{background:#000;justify-content:center;align-items:center;height:100%;display:flex;position:relative;overflow:hidden}.lightbox-img{object-fit:contain;max-width:100%;max-height:100%;display:block}.lightbox-info-pane{border-left:1px solid var(--glass-border);background:var(--glass-bg);flex-direction:column;height:100%;display:flex;overflow:hidden}.lightbox-details{scrollbar-width:thin;scrollbar-color:var(--glass-border-hover) transparent;flex-direction:column;flex:1;gap:1.25rem;padding:1.5rem 1.5rem 1rem;display:flex;overflow-y:auto}.lightbox-details::-webkit-scrollbar{width:4px}.lightbox-details::-webkit-scrollbar-track{background:0 0}.lightbox-details::-webkit-scrollbar-thumb{background:var(--glass-border-hover);border-radius:4px}.lightbox-actions{border-top:1px solid var(--glass-border);background:var(--glass-bg);flex-direction:column;flex-shrink:0;gap:.6rem;padding:1rem 1.5rem 1.25rem;display:flex}.lightbox-header{flex-direction:column;gap:.4rem;display:flex}.lightbox-title{font-family:var(--font-display);font-size:1.35rem;font-weight:800;line-height:1.2}.lightbox-section-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.4rem;font-size:.82rem;font-weight:700}.lightbox-tags-grid{flex-direction:column;gap:0;display:flex}.lightbox-tag-row{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.lightbox-tag-row:last-child{border-bottom:none}.lightbox-tag-lbl{color:var(--text-secondary);flex-shrink:0;min-width:0;font-size:.82rem}.btn-close-modal{border:1px solid var(--glass-border);color:#fff;cursor:pointer;width:44px;height:44px;transition:all var(--transition-fast);z-index:1100;-webkit-backdrop-filter:blur(8px);background:#0f0a1ed9;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;top:1rem;right:1rem}.btn-close-modal:hover{background:#ffffff26;transform:rotate(90deg)}.btn-lightbox-nav{color:#fff;cursor:pointer;width:42px;height:42px;transition:background var(--transition-fast), transform var(--transition-fast);z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f0a1ebf;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.btn-lightbox-nav.prev{left:.75rem}.btn-lightbox-nav.next{right:.75rem}.btn-lightbox-nav:hover{border-color:var(--accent-primary);background:#8a2be280}.auth-card{flex-direction:column;gap:1.5rem;width:100%;max-width:420px;padding:2.5rem;display:flex}.auth-header{text-align:center;flex-direction:column;gap:.5rem;display:flex}.auth-title{font-family:var(--font-display);font-size:1.75rem;font-weight:800}.auth-subtitle{color:var(--text-secondary);font-size:.85rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.form-input{border-radius:var(--border-radius-sm);border:1px solid var(--glass-border);color:#fff;width:100%;font-family:var(--font-sans);transition:border-color var(--transition-fast);background:#ffffff0a;padding:.75rem 1rem;font-size:.9rem}.form-input:focus{border-color:var(--accent-primary);outline:none}.auth-toggle-btn{color:var(--accent-secondary);cursor:pointer;background:0 0;border:none;font-size:.85rem;font-weight:600}.auth-toggle-btn:hover{text-decoration:underline}.auth-mode-indicator{color:var(--accent-secondary);background:#00f0ff1a;border:1px solid #00f0ff33;border-radius:30px;align-self:center;padding:.5rem 1rem;font-size:.8rem;font-weight:600}.auth-mode-indicator.supabase{color:#3ecf8e;background:#3ecf8e1a;border:1px solid #3ecf8e33}.folder-selector-wrapper{margin-top:1rem}.folder-grid{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.folder-bubble{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.8rem;display:flex}.folder-bubble:hover{border-color:var(--glass-border-hover);color:var(--text-primary);background:#ffffff14}.folder-bubble.selected{color:#fff;background:#8a2be226;border-color:#8a2be266;font-weight:600}.btn-create-folder{border:1px dashed var(--text-muted);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:20px;padding:.4rem .8rem;font-size:.8rem}.btn-create-folder:hover{border-color:var(--text-secondary);color:var(--text-secondary)}.folder-input-form{gap:.5rem;margin-top:.5rem;display:flex}.folder-input{border:1px solid var(--glass-border);color:#fff;background:#0003;border-radius:20px;flex:1;padding:.35rem .75rem;font-size:.8rem}.folder-input:focus{border-color:var(--accent-primary);outline:none}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=1024px){.app-container{grid-template-columns:1fr}.sidebar-panel{width:100%;position:static}.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.header-container{padding:1rem}.app-container{padding:0 1rem 2rem}.search-controls{flex-direction:column;align-items:stretch}.dashboard-stats{grid-template-columns:1fr}.lightbox-content{grid-template-columns:1fr;height:90vh}.lightbox-info-pane{border-left:none;border-top:1px solid var(--glass-border);padding:1.5rem}}.sidebar-folder-item:hover{color:#fff!important;background:#ffffff0a!important}.sidebar-folder-item:hover .btn-delete-sidebar-folder{opacity:1!important}.btn-delete-sidebar-folder:hover{color:var(--accent-pink)!important}.card-broken-link{text-align:center;border-radius:var(--border-radius-md);background:radial-gradient(circle,#ff007f0d 0%,#0000 70%);border:1px solid #ffffff05;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:1.5rem;display:flex}.card-print-notes{display:none}@media print{body{color:#000!important;font-family:var(--font-sans)!important;background:#fff!important;min-height:auto!important}.app-header,.sidebar-panel,.dashboard-stats,.search-controls,.loading-trigger,.btn-fav-toggle,.btn-dislike-toggle,.user-profile,.nav-actions,.logo-badge,.btn-close-modal,.btn-lightbox-nav,.lightbox-actions,.folder-input-form,.btn-create-folder{display:none!important}.app-container{max-width:100%!important;margin:0!important;padding:0!important;display:block!important}main{width:100%!important;margin:0!important;padding:0!important}.gallery-grid{page-break-inside:auto!important;grid-template-columns:repeat(2,1fr)!important;gap:20px!important;display:grid!important}.image-card{page-break-inside:avoid!important;break-inside:avoid!important;box-shadow:none!important;aspect-ratio:auto!important;background:#fff!important;border:1px solid #ccc!important;flex-direction:column!important;height:auto!important;display:flex!important}.card-img-wrapper{background:#eee!important;height:250px!important}.card-img{object-fit:cover!important;height:100%!important}.card-overlay{opacity:1!important;color:#000!important;background:#fff!important;border-top:1px solid #eee!important;padding:10px!important;position:relative!important}.tag{color:#000!important;background:0 0!important;border:1px solid #777!important}.card-print-notes{color:#444!important;text-shadow:none!important;border-top:1px dashed #ddd!important;margin-top:8px!important;padding-top:5px!important;font-size:.8rem!important;font-style:italic!important;display:block!important}}.notes-suggestion-chip{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:.75rem;font-family:var(--font-sans);background:#ffffff0d;border-radius:12px;align-items:center;padding:.25rem .6rem;font-weight:500;display:inline-flex}.notes-suggestion-chip:hover{color:#fff!important;background:#8a2be226!important;border-color:#8a2be259!important}.sidebar-divider{background:var(--glass-border);opacity:.5;height:1px;margin:.5rem 0}.profile-selector-section{flex-direction:column;gap:.4rem;display:flex}.profile-select-wrapper{flex-direction:column;gap:.4rem;display:flex;position:relative}.profile-select{border-radius:var(--border-radius-sm);border:1px solid var(--glass-border);color:#fff;width:100%;font-size:.8rem;font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition-fast);background:#0003;outline:none;padding:.45rem .65rem;font-weight:600}.profile-select:focus{border-color:var(--accent-primary)}.profile-actions{gap:.35rem;display:flex}.profile-input{border-radius:var(--border-radius-sm);border:1px solid var(--glass-border);color:#fff;background:#0003;flex:1;padding:.35rem .6rem;font-size:.75rem}.profile-input:focus{border-color:var(--accent-primary);outline:none}.btn-profile-action{border:1px solid var(--glass-border);color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;justify-content:center;align-items:center;padding:.35rem;display:flex}.btn-profile-action:hover{color:#fff;border-color:var(--glass-border-hover);background:#ffffff1a}.btn-profile-action.delete:hover{color:var(--accent-pink);background:#ff007f26;border-color:#ff007f4d}.backup-section{flex-direction:column;gap:.4rem;display:flex}.backup-buttons{grid-template-columns:1fr 1fr;gap:.4rem;display:grid}.btn-backup{border:1px solid var(--glass-border);color:var(--text-secondary);border-radius:var(--border-radius-sm);font-size:.75rem;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;justify-content:center;align-items:center;gap:.3rem;padding:.45rem .5rem;font-weight:600;display:flex}.btn-backup:hover{border-color:var(--glass-border-hover);color:#fff;background:#ffffff14}.dataset-loading{min-height:300px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:.9rem;font-style:italic;display:flex}.btn-danger{color:#fff;border-radius:var(--border-radius-sm);cursor:pointer;transition:opacity var(--transition-fast);background:linear-gradient(135deg,#e53e3e,#c53030);border:none;padding:.55rem 1.25rem;font-size:.85rem;font-weight:600}.btn-danger:hover{opacity:.85}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:.6rem;width:calc(100vw - 3rem);max-width:380px;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--border-radius-sm);-webkit-backdrop-filter:blur(20px)saturate(1.8);color:#fff;pointer-events:all;will-change:transform, opacity;border:1px solid #ffffff1a;align-items:center;gap:.65rem;padding:.8rem 1rem;font-size:.85rem;font-weight:500;display:flex;box-shadow:0 8px 32px #00000080}.toast-success{background:#10b9812e;border-color:#10b98159}.toast-error{background:#ef44442e;border-color:#ef444459}.toast-warning{background:#f59e0b2e;border-color:#f59e0b59}.toast-info{background:#6366f12e;border-color:#6366f159}.toast-icon{flex-shrink:0;font-size:1rem;line-height:1}.toast-success .toast-icon{color:#34d399}.toast-error .toast-icon{color:#f87171}.toast-warning .toast-icon{color:#fbbf24}.toast-info .toast-icon{color:#818cf8}.toast-message{flex:1;line-height:1.4}.toast-close{color:#ffffff73;cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:0 .1rem;font-size:1.1rem;line-height:1}.toast-close:hover{color:#fff}.toast-enter{animation:.32s cubic-bezier(.34,1.56,.64,1) forwards toastIn}.toast-exit{animation:.32s forwards toastOut}@keyframes toastIn{0%{opacity:0;transform:translate(100%)scale(.85)}to{opacity:1;transform:translate(0,0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(0,0)scale(1)}to{opacity:0;transform:translate(60%)scale(.85)}}.confirm-backdrop{-webkit-backdrop-filter:blur(6px);z-index:9998;background:#04020fbf;justify-content:center;align-items:center;padding:1rem;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{border-radius:var(--border-radius-md);text-align:center;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:420px;padding:2rem;animation:.22s cubic-bezier(.34,1.56,.64,1) confirmIn;display:flex}@keyframes confirmIn{0%{opacity:0;transform:scale(.88)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.confirm-icon{background:#f59e0b1a;border:1px solid #f59e0b33;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:2.5rem;line-height:1;display:flex}.confirm-message{color:var(--text-primary);max-width:320px;margin:0;font-size:.95rem;line-height:1.55}.confirm-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:.5rem;display:flex}.sort-wrapper{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.sort-select{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--border-radius-sm);color:var(--text-primary);font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239a95ba'/%3E%3C/svg%3E");background-position:right .6rem center;background-repeat:no-repeat;outline:none;padding:.5rem 1.8rem .5rem .75rem;font-size:.8rem;font-weight:500}.sort-select:hover,.sort-select:focus{border-color:var(--accent-primary);background-color:#8a2be214}.sort-select option{color:var(--text-primary);background:#0f0b24}.cheatsheet-backdrop{-webkit-backdrop-filter:blur(8px);z-index:9990;background:#04020fb3;justify-content:center;align-items:center;padding:1rem;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.cheatsheet-panel{border-radius:var(--border-radius-md);width:100%;max-width:420px;padding:1.75rem;animation:.22s cubic-bezier(.34,1.56,.64,1) confirmIn}.cheatsheet-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.cheatsheet-title{color:var(--text-primary);margin:0;font-size:1rem;font-weight:700}.cheatsheet-close{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;display:flex}.cheatsheet-close:hover{color:#fff;background:#ffffff0f}.cheatsheet-list{flex-direction:column;gap:.65rem;margin:0;padding:0;list-style:none;display:flex}.cheatsheet-item{align-items:center;gap:1rem;display:flex}.cheatsheet-kbd{min-width:80px;color:var(--accent-secondary);text-align:center;background:#8a2be21f;border:1px solid #8a2be24d;border-bottom:2px solid #8a2be280;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:.3rem .6rem;font-family:monospace;font-size:.78rem;font-weight:600;display:inline-flex}.cheatsheet-desc{color:var(--text-secondary);font-size:.85rem}.cheatsheet-footer{color:var(--text-muted);text-align:center;margin:1.25rem 0 0;font-size:.75rem}.cheatsheet-footer .cheatsheet-kbd{min-width:auto;padding:.1rem .4rem}.hamburger-btn{border:1px solid var(--glass-border);border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:.45rem;display:none}.hamburger-btn:hover{border-color:var(--glass-border-hover);background:#ffffff0f}.sidebar-overlay-mask{z-index:149;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;background:#04020f99;transition:opacity .25s;display:none;position:fixed;inset:0}.sidebar-overlay-mask.visible{opacity:1;pointer-events:all}@media (width<=1024px){.hamburger-btn{display:flex}.sidebar-overlay-mask{display:block}.sidebar-panel{z-index:150;border-right:1px solid var(--glass-border);will-change:transform;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);top:0;left:0;overflow-y:auto;transform:translate(-110%);position:fixed!important}.sidebar-overlay-active .sidebar-panel{transform:translate(0)}}.skeleton-card{pointer-events:none;cursor:default;border-color:var(--glass-border)!important}.skeleton-img{aspect-ratio:3/4;border-radius:var(--border-radius-sm) var(--border-radius-sm) 0 0;background:var(--glass-border);width:100%}.skeleton-footer{flex-direction:column;padding:.6rem .75rem .75rem;display:flex}.skeleton-line{background:var(--glass-border);border-radius:6px;height:10px}.shimmer{background:linear-gradient(90deg, var(--glass-border) 25%, var(--glass-border-hover) 50%, var(--glass-border) 75%);background-size:200% 100%;animation:1.6s linear infinite shimmer}.theme-toggle{position:relative;overflow:hidden}.theme-toggle svg{transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s}.theme-toggle:hover svg{transform:rotate(20deg)scale(1.15)}[data-theme=light] .app-header{background:#f8f5ffeb;border-bottom-color:#8a2be226}[data-theme=light] .glass-panel{background:#fffc;border-color:#8a2be224;box-shadow:0 4px 20px #8a2be214,0 1px 3px #0000000f}[data-theme=light] .sidebar-panel{background:#f5f0fff2}[data-theme=light] .search-input{color:var(--text-primary);background:#ffffffe6}[data-theme=light] .search-input::placeholder{color:var(--text-muted)}[data-theme=light] .btn-secondary{color:var(--text-primary);background:#8a2be20f;border-color:#8a2be226}[data-theme=light] .btn-secondary:hover{background:#8a2be21f;border-color:#8a2be24d}[data-theme=light] .image-card{background:#ffffffb3;border-color:#8a2be21a}[data-theme=light] .image-card:hover{border-color:#8a2be24d;box-shadow:0 8px 30px #8a2be21f}[data-theme=light] .stat-card{background:#fffc}[data-theme=light] .filter-badge{color:var(--accent-primary);background:#8a2be21a;border-color:#8a2be233}[data-theme=light] .sort-select{color:var(--text-primary);background:#ffffffe6;border-color:#8a2be233}[data-theme=light] .cheatsheet-kbd{color:var(--accent-primary);background:#8a2be214}[data-theme=light] .lightbox-backdrop{background:#f0ebffeb}[data-theme=light] .logo-badge{color:var(--accent-primary);background:#8a2be21a;border-color:#8a2be233}[data-theme=light] .user-avatar{background:var(--accent-primary)}[data-theme=light] .spinner{border-color:#8a2be233;border-top-color:var(--accent-primary)}[data-theme=light] .shimmer{background:linear-gradient(90deg,#8a2be20f 25%,#8a2be21f 50%,#8a2be20f 75%) 0 0/200% 100%;animation:1.6s linear infinite shimmer}@media (width>=1536px){.app-container{grid-template-columns:260px 1fr;gap:3rem;max-width:1800px}.gallery-grid{grid-template-columns:repeat(5,1fr);gap:1.75rem}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:1.25rem}.header-container{max-width:1800px}}@media (width>=1280px) and (width<=1535px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=1024px) and (width<=1279px){.app-container{grid-template-columns:220px 1fr;gap:1.75rem;padding:0 1.5rem 3rem}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:.75rem}.stat-val{font-size:1.15rem}.stat-lbl{font-size:.7rem}}@media (width<=1023px){.app-container{grid-template-columns:1fr;gap:0;padding:0 1.25rem 3rem}.sidebar-panel{width:min(300px,85vw)!important}.header-container{gap:.75rem;padding:.75rem 1.25rem}.logo-text{font-size:1.25rem}.logo-badge{display:none}.nav-actions{gap:.5rem}.mode-indicator-label{display:none}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.25rem}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1rem}.search-controls{flex-flow:wrap;gap:.75rem;margin-bottom:1.25rem}.search-input-wrapper{flex:1;min-width:200px}.modal-overlay{align-items:flex-end;padding:0}.lightbox-content{border-radius:16px 16px 0 0;grid-template-rows:42vh 1fr;grid-template-columns:1fr;width:100%;max-width:100%;height:94dvh;max-height:none}.lightbox-img-pane{border-radius:16px 16px 0 0;height:100%;padding:.75rem}.lightbox-info-pane{border-left:none;border-top:1px solid var(--glass-border);height:100%}.btn-lightbox-nav.prev{left:.5rem}.btn-lightbox-nav.next{right:.5rem}}@media (width<=639px){.header-container{padding:.6rem 1rem}.nav-actions{gap:.35rem}.nav-tab-label{display:none}.nav-fav-count{display:inline}.btn-print-mobile-hide,.user-email{display:none}.user-profile{gap:.4rem;padding:.3rem .5rem}.app-container{padding:0 .75rem 2.5rem}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.85rem}.stat-card{gap:.5rem;padding:.65rem}.stat-icon-wrapper{flex-shrink:0;width:32px;height:32px}.stat-val{font-size:1.05rem}.stat-lbl{font-size:.66rem}.stat-sub{font-size:.6rem}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.search-controls{flex-direction:column;gap:.5rem;margin-bottom:.85rem}.sort-wrapper,.sort-select{width:100%}.logo-text{font-size:1.05rem}.modal-overlay{align-items:flex-end;padding:0}.lightbox-content{border-radius:16px 16px 0 0;grid-template-rows:38vh 1fr;grid-template-columns:1fr;width:100%;max-width:100%;height:96dvh;max-height:none}.lightbox-img-pane{border-radius:16px 16px 0 0;height:100%;max-height:38vh;padding:.6rem}.lightbox-info-pane{border-left:none;border-top:1px solid var(--glass-border);height:100%;max-height:calc(96dvh - 38vh)}.btn-close-modal{width:38px;height:38px;top:.75rem;right:.75rem}.btn-lightbox-nav{width:34px;height:34px}.btn-lightbox-nav.prev{left:.4rem}.btn-lightbox-nav.next{right:.4rem}.lightbox-actions{gap:.45rem;padding:.75rem 1rem 1rem}.lightbox-actions .btn{padding:.55rem 1rem;font-size:.85rem}.lightbox-details{gap:.9rem;padding:1rem 1rem .75rem}.lightbox-title{font-size:1.1rem}.btn-fav-toggle,.btn-dislike-toggle{width:32px;height:32px;font-size:15px}.card-overlay{opacity:1!important;background:linear-gradient(#0000 40%,#000000bf 100%)!important}.tag{padding:.1rem .35rem!important;font-size:.6rem!important}.card-meta-row{font-size:.65rem!important}.toast-container{width:auto;max-width:100%;bottom:1rem;left:.75rem;right:.75rem}.zoom-controls{padding:.3rem .6rem!important}}@media (width<=479px){.header-container{padding:.5rem .75rem}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:.4rem}.btn-fav-toggle,.btn-dislike-toggle{width:30px;height:30px}.stat-card{padding:.55rem}.stat-val{font-size:.95rem}.dashboard-stats{grid-template-columns:repeat(2,1fr);gap:.4rem}.search-input{padding:.65rem .9rem .65rem 2.4rem;font-size:.875rem}.lightbox-content{grid-template-rows:35vh 1fr;height:97dvh}.lightbox-img-pane{max-height:35vh}}@media (width>=640px) and (width<=1023px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:.9rem}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:.8rem}.stat-val{font-size:1.2rem}}@media (hover:none) and (pointer:coarse){.card-overlay{opacity:1!important;background:linear-gradient(#0000 45%,#000000ad 100%)!important}.btn-fav-toggle,.btn-dislike-toggle{min-width:36px;min-height:36px}.filter-btn{min-height:40px;padding:.6rem .65rem}.image-card:hover,.image-card:hover .card-img{transform:none}.image-card:active{transition:transform .1s;transform:scale(.97)}}@media (hover:hover) and (pointer:fine){.image-card:hover{transform:translateY(-5px)}}@media (width<=844px) and (orientation:landscape){.modal-overlay{align-items:center;padding:.5rem}.lightbox-content{border-radius:var(--border-radius-lg);grid-template-rows:1fr;grid-template-columns:1fr 280px;height:90dvh}.lightbox-img-pane{border-radius:0;height:100%;max-height:none}.lightbox-info-pane{border-left:1px solid var(--glass-border);border-top:none;max-height:none}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}}
