:root{color-scheme:dark;--bg: #121015;--surface: #1c181f;--surface2: #26222b;--border: #3a3540;--text: #f4f0f8;--muted: #9a929e;--accent: #c9a962;--accent-dim: #8a7544;--ok: #6bbf8a;--warn: #e8b565;--danger: #e07070;--selected-ring: #22c55e;--selected-ring-soft: rgba(34, 197, 94, .45);--selected-overlay: rgba(34, 197, 94, .26);--compare-overlay: rgba(249, 115, 22, .28);--compare-caption: #fdba74;font-family:DM Sans,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:600;letter-spacing:-.02em}button,input,select{font:inherit}button{cursor:pointer}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app{max-width:1400px;margin:0 auto;padding:1.25rem 1.5rem 2rem}.app-global-busy{pointer-events:none}.app-global-busy--track{position:fixed;top:0;left:0;right:0;z-index:9998;display:block}.app-global-busy--pill{position:fixed;bottom:max(1rem,env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:9998;display:flex;align-items:center;gap:.5rem;max-width:min(92vw,22rem);padding:.55rem 1rem;font-size:.85rem;font-weight:600;color:var(--text);background:#120f16f5;border:1px solid var(--accent-dim);border-radius:999px;box-shadow:0 4px 24px #0000008c,0 0 0 1px #ffffff0a}.app-global-busy-label{text-align:center;line-height:1.3}.app-global-busy-track{height:3px;overflow:hidden;background:#00000059}.app-global-busy-indeterminate{height:100%;width:42%;background:linear-gradient(90deg,transparent,var(--accent),var(--accent-dim),transparent);animation:app-global-busy-slide 1.1s ease-in-out infinite}@keyframes app-global-busy-slide{0%{transform:translate(-120%)}to{transform:translate(320%)}}.loading-spinner{display:inline-block;width:1.35rem;height:1.35rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:loading-spin .65s linear infinite;vertical-align:middle;flex-shrink:0}.loading-spinner--tiny{width:.85rem;height:.85rem;border-width:2px}@keyframes loading-spin{to{transform:rotate(360deg)}}.thumb-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:120px;padding:1rem;color:var(--muted);font-size:.82rem}.thumb-loading-label{font-weight:500}.app-header{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.app-header h1{margin:0;font-size:1.75rem}.tagline{margin:.35rem 0 0;color:var(--muted);font-size:.95rem}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.btn{border:1px solid var(--border);background:var(--surface2);color:var(--text);padding:.45rem .85rem;border-radius:8px;font-weight:600;font-size:.9rem}.btn:hover:not(:disabled){background:#322c38;border-color:var(--accent-dim)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(145deg,#3d3428,#2a2520);border-color:var(--accent);color:#faf6ef}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-ghost{background:transparent}.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem;margin-bottom:1rem}.panel h2{margin:0 0 .75rem;font-size:1.15rem}.quota-grid{display:grid;grid-template-columns:1fr auto auto;gap:.35rem 1rem;align-items:center;font-size:.9rem}.quota-grid-header{font-weight:600;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}.quota-row input[type=number]{width:4rem;padding:.25rem .4rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.sum-row{grid-column:1 / -1;margin-top:.5rem;padding-top:.65rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.sum-ok{color:var(--ok)}.sum-bad{color:var(--warn)}.layout{display:grid;grid-template-columns:220px 1fr;gap:1rem}@media(max-width:900px){.layout{grid-template-columns:1fr}}.folder-list{list-style:none;margin:0;padding:0;max-height:420px;overflow:auto}.folder-list button{width:100%;text-align:left;padding:.45rem .55rem;margin-bottom:.25rem;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text);font-size:.85rem}.folder-list button:hover{background:var(--surface2)}.folder-list button.active{border-color:var(--accent);background:#2e2820}.folder-meta{color:var(--muted);font-size:.75rem}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem}.thumb-wrap{position:relative;border-radius:10px;overflow:hidden;border:2px solid transparent;background:var(--surface2);aspect-ratio:1}.thumb-wrap.in-compare:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--compare-overlay);pointer-events:none;z-index:1;border-radius:8px}.thumb-wrap.selected{border-color:var(--selected-ring);box-shadow:0 0 0 2px var(--selected-ring-soft),0 0 22px #22c55e47}.thumb-wrap.selected:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--selected-overlay);pointer-events:none;z-index:2;border-radius:8px}.thumb-label,.thumb-actions{z-index:3}.thumb-wrap.disabled{opacity:.45;pointer-events:none}.thumb-wrap img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}.thumb-actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:.25rem;padding:.35rem;background:linear-gradient(transparent,#000000bf)}.thumb-actions button{flex:1;font-size:.7rem;padding:.2rem;border:none;border-radius:4px;background:#ffffff26;color:#fff}.thumb-actions button:hover{background:#ffffff47}.thumb-actions button.thumb-btn-in-compare{background:#f9731659;color:#fff;font-size:.62rem;line-height:1.1;padding:.22rem .12rem}.thumb-actions button.thumb-btn-in-compare:hover{background:#f973168c}.thumb-label{position:absolute;top:0;left:0;right:0;padding:.25rem .35rem;font-size:.65rem;color:#eee;background:linear-gradient(rgba(0,0,0,.65),transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compare-dock{position:sticky;bottom:0;z-index:3;margin-top:1rem}.compare-dock-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem 1rem;padding:.55rem .85rem;background:var(--surface);border:1px solid var(--accent-dim);border-radius:12px;box-shadow:0 -6px 28px #00000038}.compare-dock--open .compare-dock-header{border-radius:12px 12px 0 0;border-bottom-color:transparent}.compare-dock-header-main{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem .75rem}.compare-dock-header h3{margin:0;font-size:1rem}.compare-dock-badge{font-size:.75rem;color:var(--muted)}.compare-dock-header-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;flex-shrink:0}.compare-dock-clear:disabled{opacity:.45;cursor:not-allowed}.compare-dock-toggle{flex-shrink:0}.compare-dock-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1)}.compare-dock--open .compare-dock-body{grid-template-rows:1fr}.compare-dock-body-inner{overflow:hidden;min-height:0}.compare-dock .compare-panel{margin:0;padding:.35rem .85rem .85rem;background:var(--surface);border:1px solid var(--accent-dim);border-top:none;border-radius:0 0 12px 12px}@media(prefers-reduced-motion:reduce){.compare-dock-body{transition:none}}.compare-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.65rem;align-items:stretch}.compare-slot{border-radius:10px;overflow:hidden;background:var(--bg);border:1px dashed var(--border);display:flex;flex-direction:column;min-height:200px;position:relative}.compare-slot-empty{align-items:center;justify-content:center;color:var(--muted);font-size:.8rem}.compare-slot--album{border-style:solid;border-color:var(--selected-ring);box-shadow:0 0 0 2px var(--selected-ring-soft),0 0 18px #22c55e38}.compare-slot--album .compare-slot-image-wrap{position:relative}.compare-slot--album .compare-slot-image-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--selected-overlay);pointer-events:none;z-index:1;border-radius:6px}.compare-slot--album .compare-slot-image-wrap img{position:relative;z-index:0}.compare-slot-image-wrap{flex:1;min-height:120px;display:flex;align-items:center;justify-content:center;padding:1.75rem .35rem .35rem}.compare-slot-image-wrap img{max-width:100%;max-height:220px;width:auto;height:auto;object-fit:contain;cursor:zoom-in}.compare-slot-loading{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-size:.85rem}.compare-slot .rm{position:absolute;top:6px;right:6px;z-index:3;width:1.65rem;height:1.65rem;border:none;border-radius:4px;background:#0000008c;color:#fff;font-size:1.1rem;line-height:1;cursor:pointer}.compare-slot .rm:hover{background:#000000b8}.compare-slot-filename{flex-shrink:0;padding:.3rem .45rem .15rem;font-size:.68rem;font-weight:600;color:var(--muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#0003;border-top:1px solid var(--border)}.compare-slot-actions{position:relative;z-index:2;display:flex;gap:.35rem;padding:.4rem;background:var(--surface2);border-top:1px solid var(--border)}.compare-slot-btn{flex:1;font-size:.72rem;font-weight:600;padding:.4rem .3rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}.compare-slot-btn:hover:not(:disabled){background:#322c38}.compare-slot-btn:disabled{opacity:.45;cursor:not-allowed}.compare-slot-btn-primary{background:linear-gradient(145deg,#3d3428,#2a2520);border-color:var(--accent);color:#faf6ef}.compare-slot-btn-primary:hover:not(:disabled){filter:brightness(1.06)}.selection-float{position:fixed;top:6.75rem;right:max(.75rem,env(safe-area-inset-right,0px));z-index:8000;max-width:min(16rem,calc(100vw - 1.5rem));padding:.65rem .9rem;background:#1c181ff5;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 36px #00000080;pointer-events:none}.selection-float-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.selection-float-folder{margin-top:.2rem;font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:14rem}.selection-float-count{margin-top:.2rem;font-size:1.28rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--selected-ring);text-shadow:0 0 24px rgba(34,197,94,.25)}.selection-float-detail{margin-top:.3rem;font-size:.75rem;color:var(--muted)}.selection-float-sync{display:flex;align-items:center;gap:.4rem;margin-top:.45rem;padding-top:.45rem;border-top:1px solid rgba(255,255,255,.08);font-size:.72rem;font-weight:600;color:var(--accent)}@media(max-width:600px){.selection-float{top:auto;bottom:5.5rem;right:.65rem;left:auto;max-width:calc(100vw - 1.25rem)}}.photo-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:3.25rem 1rem 1rem;background:#08060af0;cursor:zoom-out}.photo-lightbox-close{position:fixed;top:1rem;right:1rem;z-index:10001;cursor:pointer;border-color:var(--accent)}.photo-lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:10001;width:2.75rem;height:2.75rem;padding:0;border-radius:50%;border:1px solid var(--border);background:#1c181feb;color:var(--text);font-size:1.85rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.photo-lightbox-nav:hover{background:var(--surface2);border-color:var(--accent)}.photo-lightbox-nav--prev{left:max(.75rem,env(safe-area-inset-left,0px))}.photo-lightbox-nav--next{right:max(.75rem,env(safe-area-inset-right,0px))}.photo-lightbox-compare-hint{position:fixed;bottom:max(1rem,env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:10001;font-size:.85rem;color:var(--muted);pointer-events:none}.photo-lightbox-main{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;max-width:min(100vw - 2rem,100%);max-height:min(100dvh - 3rem,100%)}.photo-lightbox-zoom-hint{position:fixed;top:3.4rem;left:max(.75rem,env(safe-area-inset-left,0px));z-index:10001;font-size:.78rem;color:var(--muted);pointer-events:none;font-variant-numeric:tabular-nums;max-width:min(14rem,45vw)}.photo-lightbox-zoomport{overflow:auto;max-width:min(96vw,100%);max-height:min(78vh,100dvh - 10rem);display:flex;align-items:center;justify-content:center;padding:.35rem;cursor:zoom-in;outline:none}.photo-lightbox-album-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.65rem 1rem;margin-top:.5rem;padding:0 .5rem}.photo-lightbox-select-btn:disabled{opacity:.45;cursor:not-allowed}.photo-lightbox-album-hint{font-size:.8rem;color:var(--muted)}.photo-lightbox-caption{margin-top:.65rem;padding:0 .35rem;text-align:center;max-width:min(90vw,42rem)}.photo-lightbox-filename{font-size:1.02rem;font-weight:600;color:var(--text);word-break:break-word;line-height:1.35}.photo-lightbox-path{margin-top:.35rem;font-size:.8rem;font-weight:400;color:var(--muted);word-break:break-all;line-height:1.3}.photo-lightbox--compare .photo-lightbox-filename{color:var(--compare-caption)}.photo-lightbox-zoomport .photo-lightbox-img{position:relative;z-index:1;max-width:min(92vw,100%);max-height:min(70vh,82vh);width:auto;height:auto;object-fit:contain;cursor:zoom-in;box-shadow:0 8px 48px #0000008c}.photo-lightbox-persist-hint{position:fixed;top:3.35rem;left:50%;transform:translate(-50%);z-index:10001;display:flex;align-items:center;gap:.45rem;padding:.35rem .75rem;font-size:.78rem;font-weight:600;color:var(--accent);background:#120f16e0;border:1px solid var(--accent-dim);border-radius:8px;pointer-events:none;max-width:min(90vw,20rem)}.photo-lightbox-loading{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.65rem;min-height:12rem;padding:2rem;color:var(--muted);font-size:.95rem;font-weight:500}.empty-state{color:var(--muted);padding:2rem;text-align:center}.hint{font-size:.85rem;color:var(--muted);margin-top:.5rem}
