*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#faf9f7;--text:#2c2c2c;--text-muted:#6b6b6b;--accent:#8b7355;--accent-light:#c4a882;--card-bg:#fff;--border:#e8e4df;--radius:8px;--shadow:0 2px 8px #0000000f;--shadow-lg:0 8px 32px #0000001f;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--sidebar-width:260px}html{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}body{min-height:100dvh}.header{border-bottom:1px solid var(--border);background:var(--card-bg);z-index:10;justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex;position:sticky;top:0}.header h1{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:1.5rem;font-weight:300}.header-actions{align-items:center;gap:.75rem;display:flex}.btn-logout{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:color .2s,background .2s;display:flex}.btn-logout:hover{color:var(--text);background:#0000000f}.view-toggle-desktop{border:1px solid var(--border);border-radius:var(--radius);background:var(--border);flex-wrap:wrap;gap:2px;display:flex;overflow:hidden}.view-toggle-desktop .btn{white-space:nowrap;border:none;border-radius:0;padding:.3rem .6rem;font-size:.7rem}.view-toggle-mobile{display:none;position:relative}.view-toggle-trigger{justify-content:center;min-width:100px}.view-menu-backdrop{z-index:19;position:fixed;inset:0}.view-menu-dropdown{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:20;min-width:140px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden}.view-menu-item{width:100%;color:var(--text);font-family:var(--font);text-align:left;cursor:pointer;background:0 0;border:none;padding:.65rem 1rem;font-size:.85rem;transition:background .1s;display:block}.view-menu-item:hover{background:#0000000a}.view-menu-item.active{background:var(--accent);color:#fff;font-weight:500}.tag-filter-dropdown{display:none;position:relative}@media (width<=900px){.tag-filter-dropdown{display:block}}.tag-filter-trigger{white-space:nowrap}.tag-menu-backdrop{z-index:19;position:fixed;inset:0}.tag-menu-dropdown{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:20;min-width:220px;max-width:360px;max-height:320px;margin-top:4px;padding:.75rem;position:absolute;top:100%;right:0;overflow-y:auto}.tag-menu-pills{flex-wrap:wrap;gap:.4rem;display:flex}.btn{border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;font-family:var(--font);cursor:pointer;background:var(--card-bg);color:var(--text);align-items:center;gap:.5rem;padding:.5rem 1.25rem;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--accent-light)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-light);border-color:var(--accent-light)}.btn-secondary{background:0 0}.btn-sm{padding:.35rem .85rem;font-size:.75rem}.main-layout{min-height:calc(100dvh - 60px);display:flex}.content-area{flex:1;min-width:0;overflow:hidden}.sidebar{width:var(--sidebar-width);border-left:1px solid var(--border);background:var(--card-bg);flex-shrink:0;height:calc(100dvh - 60px);padding:1rem 0;position:sticky;top:60px;overflow-y:auto}.sidebar-section{border-bottom:1px solid var(--border);padding:.75rem 1.25rem}.sidebar-section:last-child{border-bottom:none}.sidebar-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem;font-size:.7rem;font-weight:600}.sidebar-stats{color:var(--text-muted);font-size:.8rem}.sidebar-btn{justify-content:center;width:100%;padding:.4rem .75rem;font-size:.8rem}.sidebar-tags{flex-wrap:wrap;gap:.35rem;display:flex}.sidebar-toggle{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.8rem;display:flex}.sidebar-toggle input[type=checkbox]{appearance:none;background:var(--border);cursor:pointer;border-radius:10px;flex-shrink:0;width:34px;height:20px;transition:background .2s;position:relative}.sidebar-toggle input[type=checkbox]:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.sidebar-toggle input[type=checkbox]:checked{background:var(--accent)}.sidebar-toggle input[type=checkbox]:checked:after{transform:translate(14px)}.tag-pill{border:1px solid var(--border);font-size:.7rem;font-family:var(--font);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:100px;align-items:center;gap:.25rem;padding:.25rem .65rem;transition:all .15s;display:inline-flex}.tag-pill:hover{border-color:var(--accent-light);color:var(--accent)}.tag-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.tag-count{opacity:.7;font-size:.6rem}.photo-grid-wrapper{padding:1.25rem}.photo-grid{columns:4;column-gap:.75rem}.photo-grid .photo-card{break-inside:avoid;margin-bottom:.75rem}@media (width<=1400px){.photo-grid{columns:3}}@media (width<=1000px){.photo-grid{columns:2}:root{--sidebar-width:220px}}@media (width<=768px){.main-layout{flex-direction:column}.sidebar{display:none}.photo-grid{columns:2}.photo-grid-wrapper{padding:.75rem}.header{z-index:10;flex-direction:row;gap:.5rem;padding:.75rem 1rem;position:sticky;top:0}.header h1{font-size:1.1rem}.view-toggle-desktop{display:none}.view-toggle-mobile{display:block}.tag-pill{padding:.4rem .75rem;font-size:.75rem}.photo-select-btn{opacity:.6}.photo-set-cover-btn,.photo-hide-btn,.photo-delete-btn{opacity:.7}.photo-select-btn{width:36px;height:36px;font-size:18px}.photo-set-cover-btn,.photo-hide-btn{width:40px;height:40px}.photo-delete-btn{width:38px;height:38px}.selection-bar{width:auto;left:1rem;right:1rem;transform:none}.lightbox-action-btn{width:44px;height:44px}.lightbox-nav{padding:.75rem;font-size:2.5rem}.lightbox-close{font-size:2rem;top:.75rem;right:.75rem}.btn-back,.btn-logout{width:40px;height:40px}.album-card-actions{opacity:1}.album-action-btn{width:40px;height:40px}}@media (width<=480px){.photo-grid{columns:1}}.photo-card,.photo-thumb{position:relative}.photo-card{border-radius:var(--radius);background:var(--card-bg);box-shadow:var(--shadow);cursor:pointer;transition:transform .2s,box-shadow .2s;overflow:hidden}.photo-select-btn{z-index:2;color:#fff;cursor:pointer;opacity:0;background:#00000059;border:2px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:14px;line-height:1;transition:opacity .15s,background .15s;display:flex;position:absolute;top:6px;left:6px}.photo-card:hover .photo-select-btn,.photo-thumb:hover .photo-select-btn,.photo-select-btn.checked{opacity:1}.photo-select-btn.checked{background:var(--accent);border-color:var(--accent)}.photo-selected{outline:3px solid var(--accent);outline-offset:-3px}.photo-selected img{opacity:.75}.photo-hidden img{opacity:.4;filter:grayscale(.5)}.photo-hidden-badge{z-index:2;text-transform:uppercase;letter-spacing:.05em;color:#fffc;background:#0009;border-radius:4px;padding:.15rem .45rem;font-size:.6rem;font-weight:600;position:absolute;top:6px;left:6px}.photo-cover-badge{z-index:2;text-transform:uppercase;letter-spacing:.05em;color:#1a1a1a;background:#ffc832d9;border-radius:4px;align-items:center;gap:.25rem;padding:.15rem .45rem;font-size:.6rem;font-weight:600;display:flex;position:absolute;top:6px;right:6px}.photo-cover-badge svg{flex-shrink:0}.photo-set-cover-btn{z-index:3;color:#fffc;cursor:pointer;opacity:0;background:#0000008c;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:opacity .15s,background .15s;display:flex;position:absolute;bottom:6px;right:6px}.photo-card:hover .photo-set-cover-btn,.photo-thumb:hover .photo-set-cover-btn{opacity:1}.photo-set-cover-btn:hover{color:#1a1a1a;background:#ffc832d9}.photo-hide-btn{z-index:3;color:#fffc;cursor:pointer;opacity:0;background:#0000008c;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:opacity .15s,background .15s;display:flex;position:absolute;bottom:6px;left:6px}.photo-card:hover .photo-hide-btn,.photo-thumb:hover .photo-hide-btn{opacity:1}.photo-hide-btn:hover{color:#fff;background:#dc3c3ccc}.photo-hide-btn.is-hidden{opacity:1;color:#fff;background:#50c878b3}.photo-hide-btn.is-hidden:hover{background:#50c878e6}.photo-delete-btn{color:#fff;cursor:pointer;opacity:0;z-index:3;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:opacity .15s,background .15s;display:flex;position:absolute;bottom:6px;right:40px}.photo-delete-confirm{z-index:5;border-radius:var(--radius);background:#000000d9;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex;position:absolute;inset:0}.photo-delete-confirm p{color:#fff;margin:0;font-size:.85rem}.photo-delete-confirm-actions button{border-radius:var(--radius);cursor:pointer;border:none;padding:.25rem .75rem;font-size:.8rem}.btn-confirm-yes{color:#fff;background:#dc3545}.btn-confirm-no{color:#fff;background:#fff3}.photo-delete-btn{z-index:3;color:#fffc;cursor:pointer;opacity:0;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:opacity .15s,background .15s;display:flex;position:absolute;top:6px;right:6px}.photo-card:hover .photo-delete-btn,.photo-thumb:hover .photo-delete-btn{opacity:1}.photo-delete-btn:hover{color:#fff;background:#dc3545d9}.photo-delete-confirm{z-index:10;border-radius:inherit;color:#fff;background:#000000bf;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:.85rem;display:flex;position:absolute;inset:0}.photo-delete-confirm p{margin:0;font-weight:500}.photo-delete-confirm-actions{gap:.4rem;display:flex}.btn-confirm-yes{color:#fff;cursor:pointer;background:#dc3545;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.8rem}.btn-confirm-yes:hover{background:#b02a37}.btn-confirm-no{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.8rem}.btn-confirm-no:hover{background:#ffffff59}.lightbox-action-btn.is-delete:hover{color:#fff;background:#dc354599}.delete-confirm-inline{color:#ffffffe6;align-items:center;gap:.4rem;font-size:.85rem;display:flex}.delete-confirm-inline .btn-confirm-yes,.delete-confirm-inline .btn-confirm-no{padding:.2rem .6rem;font-size:.75rem}.selection-bar{z-index:100;background:var(--card-bg);border:1px solid var(--border);color:var(--text);border-radius:999px;align-items:center;gap:1rem;padding:.65rem 1.25rem;font-size:.9rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #00000040}.selection-bar-actions{gap:.5rem;display:flex}.photo-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.photo-card img{width:100%;height:auto;display:block}.photo-tags{background:linear-gradient(#0000,#00000080);flex-wrap:wrap;gap:.25rem;padding:1.5rem .5rem .5rem;display:flex;position:absolute;bottom:0;left:0;right:0}.photo-tag{color:var(--text);background:#ffffffd9;border-radius:100px;padding:.15rem .5rem;font-size:.65rem}.photo-grid-thumbs{grid-template-columns:repeat(auto-fill,minmax(120px,180px));gap:4px;display:grid}.photo-thumb{aspect-ratio:1;cursor:pointer;border-radius:4px;transition:transform .15s,box-shadow .15s;overflow:hidden}.photo-thumb:hover{box-shadow:var(--shadow-lg);z-index:1;position:relative;transform:scale(1.03)}.photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}@media (width<=768px){.photo-grid-thumbs{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:3px}}.scroll-sentinel{height:1px}.lightbox-overlay{z-index:100;background:#000000eb;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{align-items:flex-start;gap:1rem;max-width:90vw;max-height:90vh;display:flex;position:relative;overflow:hidden}.lightbox-content img{object-fit:contain;border:2px solid #fff3;border-radius:8px;flex-shrink:0;max-width:65vw;max-height:88vh;box-shadow:0 4px 24px #0006}.lightbox-close{color:#fff;cursor:pointer;opacity:.7;z-index:101;background:0 0;border:none;font-size:2.5rem;line-height:1;transition:opacity .15s;position:fixed;top:1rem;right:1.5rem}.lightbox-close:hover{opacity:1}.lightbox-nav{color:#fff;cursor:pointer;opacity:.5;z-index:101;background:0 0;border:none;padding:1rem;font-size:4rem;line-height:1;transition:opacity .15s;position:fixed;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{opacity:1}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.lightbox-info{color:var(--text);border-radius:var(--radius);width:300px;max-height:88vh;box-shadow:var(--shadow-lg);background:#fff;flex-shrink:0;padding:1.25rem;overflow-y:auto}.lightbox-description{margin-bottom:1rem;font-size:1rem;line-height:1.5}.lightbox-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.lightbox-tags .photo-tag{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:999px;padding:.3rem .7rem;font-size:.9rem}.lightbox-tags .photo-tag-removable{cursor:pointer}.lightbox-tags .photo-tag-removable:hover{background:#fce8e8;border-color:#e88}.lightbox-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:1rem;padding-top:.75rem;display:flex}.lightbox-footer-actions{gap:.5rem;display:flex}.lightbox-action-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);background:var(--bg);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;text-decoration:none;transition:color .15s,background .15s;display:flex}.lightbox-action-btn:hover{color:var(--text);background:var(--border)}.lightbox-action-btn.active{color:#fff;background:#dc5050b3;border-color:#0000}.lightbox-action-btn.active:hover{background:#64b464b3}.lightbox-action-btn.is-cover{color:#50c878;background:#50c87833;border-color:#50c878}.lightbox-action-btn.is-delete:hover{color:#dc3545;background:#fce8e8;border-color:#dc3545}.delete-confirm-inline{border-radius:var(--radius);color:var(--text);background:#fce8e8;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.9rem;display:flex}.delete-confirm-inline .btn-confirm-yes{padding:.2rem .6rem;font-size:.8rem}.delete-confirm-inline .btn-confirm-no{background:var(--bg);color:var(--text);border:1px solid var(--border);padding:.2rem .6rem;font-size:.8rem}.delete-confirm-inline .btn-confirm-no:hover{background:var(--border)}.btn-danger:hover{background:#b02a37}.lightbox-counter{color:var(--text-muted);font-size:.85rem}.lightbox-tags-section{margin-bottom:1rem}.lightbox-section-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.tag-remove{opacity:.4;margin-left:.3rem;font-size:1.1em}.photo-tag-removable:hover .tag-remove{opacity:1}.tag-suggestions{flex-wrap:wrap;gap:.35rem;margin-top:.5rem;display:flex}.tag-pill-edit{border:1px dashed var(--border);font-size:.85rem;font-family:var(--font);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:100px;align-items:center;padding:.3rem .7rem;transition:all .15s;display:inline-flex}.tag-pill-edit:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#8b735514}.tag-pill-edit:disabled{opacity:.4;cursor:not-allowed}.tag-editor-new{gap:.4rem;display:flex}.tag-new-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);font-size:.95rem;font-family:var(--font);outline:none;flex:1;padding:.45rem .75rem}.tag-new-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #8b735526}.tag-new-input::placeholder{color:var(--text-muted)}.btn-add-tag{background:var(--accent);color:#fff;border-radius:var(--radius);width:36px;font-size:1.2rem;font-family:var(--font);cursor:pointer;border:none;transition:all .15s}.btn-add-tag:hover:not(:disabled){background:var(--accent-light)}.btn-add-tag:disabled{opacity:.3;cursor:not-allowed}@media (width<=900px){.lightbox-content{flex-direction:column;align-items:center;overflow-y:auto}.lightbox-content img{max-width:90vw;max-height:60vh}.lightbox-info{width:90vw;max-height:none}}.loading{justify-content:center;padding:4rem;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem;font-size:1.1rem}.error-banner{color:#991b1b;background:#fef2f2;border-bottom:1px solid #fecaca;padding:.75rem 2rem;font-size:.875rem}.code-gate{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;display:flex}.code-gate-card{background:var(--card-bg);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow-lg);border-radius:12px;width:90vw;max-width:380px;padding:3rem 2.5rem}.code-gate-title{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-size:1.75rem;font-weight:300}.code-gate-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.9rem}.code-gate-form{gap:.5rem;display:flex}.code-gate-input{border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;font-family:var(--font);text-align:center;letter-spacing:.15em;outline:none;flex:1;padding:.65rem 1rem;transition:border-color .15s}.code-gate-input:focus{border-color:var(--accent-light)}.code-gate-btn{flex-shrink:0}.code-gate-error{color:#991b1b;margin-top:1rem;font-size:.85rem}.header-left{align-items:center;gap:.5rem;display:flex}.btn-back{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:color .2s,background .2s;display:flex}.btn-back:hover{color:var(--text);background:#0000000f}.album-picker{background:var(--bg);min-height:100dvh}.album-picker-content{max-width:900px;margin:0 auto;padding:2rem}.album-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.album-card{background:var(--card-bg);border:1px solid var(--border);cursor:pointer;text-align:center;font-family:var(--font);border-radius:12px;flex-direction:column;padding:0;transition:all .2s;display:flex;position:relative;overflow:hidden}.album-card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent-light);transform:translateY(-3px)}.album-card-cover{background:var(--bg);justify-content:center;align-items:center;width:100%;height:140px;display:flex;overflow:hidden}.album-card-cover img{object-fit:cover;width:100%;height:100%}.album-card-cover-icon{color:var(--text-muted);opacity:.35}.album-card-body{width:100%;padding:.85rem 1rem;position:relative}.album-card-name{color:var(--text);margin-bottom:.2rem;font-size:1.1rem;font-weight:500}.album-card-count{color:var(--text-muted);font-size:.78rem}.album-card-folder{color:var(--text-muted);opacity:.5;margin-top:.15rem;font-family:monospace;font-size:.65rem}.album-card-actions{opacity:0;justify-content:center;align-items:center;gap:.15rem;margin-top:.3rem;transition:opacity .15s;display:flex}.album-card:hover .album-card-actions{opacity:1}.album-action-btn{width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.album-action-btn:hover{color:var(--text);background:#0000000f}.spinner-sm{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:13px;height:13px;animation:.6s linear infinite spin}.album-rename-form{width:100%}.album-rename-input{border:1px solid var(--accent-light);border-radius:var(--radius);width:100%;font-size:1.05rem;font-weight:500;font-family:var(--font);text-align:center;background:0 0;outline:none;padding:.35rem .5rem}.album-create-form{gap:.5rem;margin-bottom:1.5rem;display:flex}.album-create-input{border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:var(--font);outline:none;flex:1;padding:.5rem .85rem;transition:border-color .15s}.album-create-input:focus{border-color:var(--accent-light)}.share-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.share-panel h3{margin-bottom:.25rem;font-size:1rem;font-weight:600}.share-panel-hint{color:var(--text-muted);margin-bottom:.75rem;font-size:.8rem}.share-album-list{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.share-album-item{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.share-album-item input[type=checkbox]{accent-color:var(--accent)}.share-panel-actions{align-items:center;gap:.5rem;display:flex}.share-link-row{flex:1;gap:.5rem;display:flex}.share-link-input{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);background:var(--bg);outline:none;flex:1;padding:.4rem .65rem;font-family:monospace;font-size:.75rem}@media (width<=600px){.album-grid{grid-template-columns:1fr}.album-picker-content{padding:1rem}}.upload-modal-overlay{z-index:9000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upload-modal{background:var(--card-bg);border-radius:var(--radius-lg,12px);flex-direction:column;width:min(480px,92vw);max-height:80vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}.upload-modal-header{justify-content:space-between;align-items:center;padding:1.25rem 1.5rem .75rem;display:flex}.upload-modal-header h3{color:var(--text);font-size:1rem;font-weight:600}.upload-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.upload-modal-close:hover{color:var(--text)}.upload-progress-overall{align-items:center;gap:.75rem;padding:0 1.5rem 1rem;display:flex}.upload-progress-bar{background:var(--border,#e5e5e5);border-radius:4px;flex:1;height:8px;overflow:hidden}.upload-progress-bar.small{height:4px}.upload-progress-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .2s}.upload-progress-fill.complete{background:#50c878}.upload-progress-fill.has-errors{background:#e67e22}.upload-progress-pct{color:var(--text-muted);text-align:right;min-width:3ch;font-size:.8rem;font-weight:600}.upload-file-list{flex:1;max-height:360px;padding:0 1.5rem;overflow-y:auto}.upload-file-row{border-bottom:1px solid var(--border,#eee);justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.upload-file-row:last-child{border-bottom:none}.upload-file-info{flex:1;align-items:baseline;gap:.5rem;min-width:0;display:flex}.upload-file-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;overflow:hidden}.upload-file-row.done .upload-file-name{color:var(--text-muted)}.upload-file-size{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.7rem}.upload-file-progress{flex-shrink:0;justify-content:flex-end;align-items:center;width:80px;display:flex}.upload-file-status-text{color:var(--text-muted);font-size:.75rem}.upload-file-status-text.success{color:#50c878;font-size:1rem;font-weight:700}.upload-file-status-text.error{color:#dc3545;font-size:1rem;font-weight:700}.upload-modal-footer{justify-content:flex-end;padding:.75rem 1.5rem 1.25rem;display:flex}.album-action-delete:hover{color:#dc3545!important;background:#dc354514!important}.modal-overlay{z-index:9000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--card-bg);border-radius:var(--radius-lg,12px);width:min(420px,90vw);padding:1.5rem;box-shadow:0 20px 60px #0000004d}.modal-dialog h3{margin-bottom:.75rem;font-size:1.05rem;font-weight:600}.modal-dialog p{color:var(--text-muted);margin-bottom:1.25rem;font-size:.9rem;line-height:1.5}.modal-actions{justify-content:flex-end;gap:.5rem;display:flex}.btn-danger{color:#fff;background:#dc3545;border:1px solid #dc3545}.btn-danger:hover{background:#b02a37;border-color:#b02a37}.delete-progress{margin:1rem 0}.delete-status{color:var(--text-muted);margin-top:.5rem;font-size:.85rem}.delete-status.success{color:#50c878;font-weight:500}.delete-status.error{color:#dc3545;font-weight:500}.slideshow{z-index:1000;cursor:pointer;background:#000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.slideshow-img{object-fit:contain;max-width:100%;max-height:100%;transition:opacity .4s}.slideshow-img.fade-out{opacity:0}.slideshow-img.fade-in{opacity:1}.slideshow-overlay{text-align:center;color:#fffc;pointer-events:none;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.slideshow-counter{font-variant-numeric:tabular-nums;margin-bottom:.5rem;font-size:.85rem}.slideshow-tags{flex-wrap:wrap;justify-content:center;gap:.35rem;display:flex}.slideshow-nav{color:#fff;cursor:pointer;opacity:0;z-index:10;background:#0000004d;border:none;padding:.5rem 1rem;font-size:3rem;transition:opacity .2s;position:absolute;top:50%;transform:translateY(-50%)}.slideshow:hover .slideshow-nav{opacity:.7}.slideshow-nav:hover{background:#00000080;opacity:1!important}.slideshow-prev{border-radius:0 var(--radius) var(--radius) 0;left:0}.slideshow-next{border-radius:var(--radius) 0 0 var(--radius);right:0}.slideshow-exit{color:#fff;cursor:pointer;z-index:10;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:2rem;transition:background .2s;display:flex;position:absolute;top:1rem;right:1rem}.slideshow-exit:hover{background:#000000b3}.slideshow-controls{z-index:10;position:absolute;bottom:1rem;right:1.5rem}.slideshow-playpause{color:#fff;cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .2s;display:flex}.slideshow-playpause:hover{background:#000000b3}.slideshow-empty{color:#fff9;font-size:1.25rem}.mosaic{padding:4px}.mosaic-row{margin-bottom:4px;display:flex}.mosaic-item{cursor:pointer;position:relative;overflow:hidden}.mosaic-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.mosaic-item:hover img{transform:scale(1.05)}.photo-wall{min-height:60vh;padding:1.5rem;position:relative;overflow:hidden}.photo-wall-grid{grid-template-columns:repeat(auto-fill,minmax(150px,200px));justify-content:center;gap:.75rem;padding:1rem;display:grid}.wall-item{cursor:pointer;background:#fff;max-width:200px;padding:5px 5px 18px;transition:transform .3s,box-shadow .3s;overflow:hidden;box-shadow:2px 3px 10px #00000021}.wall-item img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.wall-item:hover{box-shadow:4px 6px 20px #00000040;z-index:100!important;transform:scale(1.03)rotate(0)!important}.timeline{max-width:1200px;margin:0 auto;padding:2rem 1rem}.timeline-empty{text-align:center;color:var(--text-muted);padding:4rem 0;font-size:1.1rem}.timeline-day{margin-bottom:3rem}.timeline-date{color:var(--text);border-bottom:2px solid var(--accent-light);margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.4rem;font-weight:400}.timeline-section{margin-bottom:2rem;margin-left:1.5rem;position:relative}.timeline-section:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:-1rem}.timeline-time-label{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.9rem;font-weight:500;position:relative}.timeline-time-label:before{content:"";background:var(--accent);border-radius:50%;width:10px;height:10px;position:absolute;top:50%;left:-1.35rem;transform:translateY(-50%)}.timeline-photos{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px;display:grid}.timeline-photo{cursor:pointer;border-radius:4px;overflow:hidden}.timeline-photo img{aspect-ratio:1;object-fit:cover;width:100%;transition:transform .3s;display:block}.timeline-photo:hover img{transform:scale(1.05)}.comparison{max-width:1400px;margin:0 auto;padding:1.5rem}.comparison-controls{justify-content:center;gap:4px;margin-bottom:1rem;display:flex}.comparison-selectors{justify-content:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.comparison-select-btn{border:2px dashed var(--border);background:var(--card-bg);border-radius:var(--radius);cursor:pointer;color:var(--text-muted);padding:.5rem 1.25rem;font-size:.85rem;transition:all .2s}.comparison-select-btn:hover,.comparison-select-btn.is-picking{border-color:var(--accent);color:var(--accent)}.comparison-picker-hint{text-align:center;color:var(--accent);margin-bottom:1rem;font-size:.85rem}.comparison-picker-grid{border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:4px;max-height:300px;padding:4px;display:grid;overflow-y:auto}.comparison-picker-item{cursor:pointer;border:2px solid #0000;border-radius:4px;overflow:hidden}.comparison-picker-item img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.comparison-picker-item:hover{border-color:var(--accent-light)}.comparison-picker-item.is-selected{border-color:var(--accent)}.comparison-view{margin-top:1rem}.comparison-side-by-side{grid-template-columns:1fr 1fr;gap:8px;display:grid}.comparison-pane{border-radius:var(--radius);background:#f0f0f0;overflow:hidden}.comparison-pane img{width:100%;height:auto;display:block}.comparison-slider{border-radius:var(--radius);cursor:ew-resize;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.comparison-slider-bg{width:100%;display:block}.comparison-slider-clip{position:absolute;inset:0;overflow:hidden}.comparison-slider-clip img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;top:0;left:0}.comparison-slider-handle{z-index:5;width:4px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.comparison-slider-line{background:#fff;width:100%;height:100%;box-shadow:0 0 8px #0006}.comparison-empty{text-align:center;color:var(--text-muted);padding:4rem 0;font-size:1.1rem}.photo-map{justify-content:center;align-items:center;min-height:60vh;padding:3rem;display:flex}.photo-map-placeholder{text-align:center;color:var(--text-muted)}.photo-map-placeholder svg{color:var(--accent-light);margin-bottom:1rem}.photo-map-placeholder h3{color:var(--text);margin-bottom:.5rem;font-size:1.3rem;font-weight:400}.photo-map-placeholder p{margin-bottom:.5rem}.photo-map-hint{opacity:.7;font-size:.8rem;line-height:1.6}@media (width<=768px){.photo-wall-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.wall-item{padding:4px 4px 16px}.timeline-photos{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.comparison-side-by-side{grid-template-columns:1fr}.comparison-slider{touch-action:none}}.image-editor-overlay{z-index:1000;background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.image-editor{flex-direction:column;align-items:center;gap:1rem;max-width:100vw;max-height:100dvh;padding:1rem;display:flex;overflow-y:auto}.editor-toolbar{gap:.5rem;display:flex}.editor-canvas-wrap{border-radius:var(--radius);border:2px solid #fff3;flex-shrink:0;position:relative;overflow:hidden}.editor-canvas-wrap.is-processing .editor-pulse-overlay{pointer-events:none;background:#ff3c5026;animation:1.5s ease-in-out infinite editor-pulse;position:absolute;inset:0}@keyframes editor-pulse{0%,to{opacity:.1}50%{opacity:.4}}.crop-controls{border-radius:var(--radius);background:#ffffff1a;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.crop-ratios{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.crop-ratio-btn{border-radius:var(--radius);color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff4d;padding:.35rem .75rem;font-size:.85rem;transition:background .15s}.crop-ratio-btn:hover{background:#ffffff26}.crop-ratio-btn.active{background:var(--accent);border-color:var(--accent)}.crop-custom-ratio{color:#fff;align-items:center;gap:.3rem;display:flex}.crop-ratio-input{border-radius:var(--radius);color:#fff;text-align:center;background:#ffffff1a;border:1px solid #ffffff4d;width:3rem;padding:.3rem .4rem;font-size:.85rem}.crop-actions{gap:.5rem;margin-left:auto;display:flex}.image-editor .btn-secondary{color:#fff;background:#ffffff26;border:1px solid #ffffff4d}.image-editor .btn-secondary:hover{background:#ffffff40}.image-editor .btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent-light)}.image-editor .btn-primary:hover{background:var(--accent-light)}.image-editor .btn:disabled{opacity:.4;cursor:not-allowed}.eraser-controls{border-radius:var(--radius);color:#fff;background:#ffffff1a;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.eraser-brush-size{align-items:center;gap:.5rem;display:flex}.eraser-brush-size label{opacity:.8;font-size:.85rem}.brush-slider{width:100px;accent-color:var(--accent)}.brush-size-label{opacity:.7;min-width:3rem;font-size:.8rem}.eraser-stroke-actions{gap:.4rem;display:flex}.eraser-prompt-section{align-items:center;gap:.5rem;display:flex}.eraser-prompt-input{border-radius:var(--radius);color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;width:180px;padding:.35rem .6rem;font-size:.85rem}.eraser-prompt-input::placeholder{color:#fff6}.eraser-actions{gap:.5rem;margin-left:auto;display:flex}.inpaint-result-actions{gap:.5rem;display:flex}.lightbox-modified-badge{border:1px solid var(--accent-light);border-radius:var(--radius);background:#8b735514;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.4rem .75rem;display:flex}.lightbox-modified-badge span{color:var(--accent);font-size:.85rem;font-weight:500}.edited-badge{color:var(--accent);font-size:.75rem;font-weight:500}.editor-error-toast{color:#fff;border-radius:var(--radius);z-index:1001;background:#e74c3c;align-items:center;gap:.75rem;padding:.6rem 1.2rem;font-size:.9rem;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.editor-error-toast button{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.2rem;line-height:1}@media (width<=768px){.image-editor{padding:.5rem}.crop-controls,.eraser-controls{flex-direction:column;align-items:stretch}.crop-actions,.eraser-actions{justify-content:stretch;margin-left:0}.crop-actions button,.eraser-actions button{flex:1}.eraser-prompt-input{width:100%}.brush-slider{flex:1;width:100%}}.drop-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#8b735526;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drop-overlay-content{border:3px dashed var(--accent);color:var(--accent);background:#ffffffe6;border-radius:16px;flex-direction:column;align-items:center;gap:1rem;padding:3rem 4rem;display:flex}.drop-overlay-content svg{opacity:.7}.drop-overlay-content span{font-size:1.2rem;font-weight:500}
