:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f6f4ee;color:#191816;font-synthesis:none;text-rendering:optimizeLegibility;--bg: #f6f4ee;--panel: #fffdf8;--ink: #191816;--muted: #74716a;--line: #e1ddd4;--accent: #157f78;--accent-strong: #0f625d;--coral: #da5f4f;--gold: #b78915;--shadow: 0 20px 50px rgba(31, 30, 28, .12)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{position:sticky;top:0;height:100vh;padding:22px 16px;display:flex;flex-direction:column;border-right:1px solid var(--line);background:#fffdf8e6;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:18px}.brand-mark{width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:#102a2a;color:#fffdf8;box-shadow:inset 0 -8px 18px #ffffff14}.nav-list{display:grid;gap:6px;margin-top:30px}.nav-item,.text-button,.icon-button,.primary-button,.secondary-button,.danger-button{border:0;display:inline-flex;align-items:center;justify-content:center;gap:10px}.nav-item{width:100%;justify-content:flex-start;padding:12px 14px;border-radius:8px;color:var(--muted);background:transparent}.nav-item:hover,.nav-item.active{background:#e9e5da;color:var(--ink)}.account-strip{margin-top:auto;padding:12px;border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:12px}.account-strip div,.user-row div{min-width:0;display:grid;gap:2px}.account-strip span,.user-row span,.eyebrow{color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis}.main{min-width:0;padding:28px clamp(18px,4vw,44px) 56px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:26px}.topbar h1{margin:2px 0 0;font-size:clamp(30px,4vw,48px);line-height:1;letter-spacing:0}.eyebrow{margin:0;text-transform:uppercase;font-weight:800}.toolbar{display:flex;align-items:center;gap:10px}.search-field{width:min(34vw,360px);min-width:220px;height:44px;padding:0 14px;display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel)}.search-field input,.login-panel input,.album-create input,.admin-create input,.admin-create select,.user-row select{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);outline:none}.search-field input{border:0;background:transparent}.login-panel input,.album-create input,.admin-create input,.admin-create select,.user-row select{min-height:44px;padding:0 12px}.primary-button,.secondary-button,.danger-button{min-height:44px;padding:0 16px;border-radius:8px;font-weight:800;text-decoration:none}.primary-button{background:var(--accent);color:#fff}.primary-button:hover{background:var(--accent-strong)}.secondary-button{background:#ece8dd;color:var(--ink)}.danger-button{background:#fae1dd;color:#8a2017}.wide{width:100%}.icon-button{width:40px;height:40px;border-radius:8px;background:transparent;color:var(--ink)}.icon-button:hover{background:#ece8dd}.icon-button.light{background:#0000006b;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.icon-button.light:hover,.icon-button.light.active{background:#0000009e}.mobile-only-nav{display:none}.confirm-modal{max-width:460px;display:flex;flex-direction:column;gap:12px;padding:22px}.confirm-modal p{margin:0;color:var(--muted)}.confirm-modal input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit}.hidden-input{display:none}.toast{position:fixed;right:22px;bottom:22px;z-index:50;padding:12px 16px;border-radius:8px;background:#102a2a;color:#fff;box-shadow:var(--shadow)}.library{display:grid;gap:28px}.drop-area{position:relative;min-height:54vh}.drop-area.dragging{outline:2px dashed var(--accent);outline-offset:8px}.drop-overlay{position:absolute;inset:0;z-index:10;display:grid;place-items:center;align-content:center;gap:12px;border-radius:8px;background:#f6f4eedb;color:var(--accent-strong);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.back-button{width:max-content}.text-button{padding:0;background:transparent;color:var(--accent-strong);font-weight:800}.date-group h2{margin:0 0 12px;font-size:18px;letter-spacing:0}.album-actions{display:flex;align-items:center;justify-content:space-between;gap:14px}.album-actions>div{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px}.photo-tile{position:relative;aspect-ratio:1;border:0;border-radius:8px;overflow:hidden;padding:0;background:#dfdbd1;box-shadow:0 1px #0000000a}.photo-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .18s ease}.photo-tile:hover img{transform:scale(1.035)}.photo-tile{user-select:none;-webkit-user-select:none}.photo-tile.selectable:not(.is-selected) img{opacity:.5}.tile-checkbox{position:absolute;top:8px;left:8px;width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.9);background:#0000004d;pointer-events:none}.tile-checkbox.checked{background:var(--accent);border-color:var(--accent)}.tile-checkbox.checked:after{content:"";position:absolute;left:5px;top:1px;width:7px;height:11px;border:2px solid white;border-top:0;border-left:0;transform:rotate(45deg)}.select-bar{position:fixed;bottom:0;left:280px;right:0;z-index:30;padding:14px clamp(18px,4vw,44px);display:flex;align-items:center;justify-content:space-between;gap:14px;background:#102a2a;color:#fff;animation:slideUp .18s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.select-bar-actions{display:flex;gap:10px}.tile-cover-btn{position:absolute;bottom:8px;left:8px;width:26px;height:26px;display:grid;place-items:center;border-radius:999px;background:#102a2a99;color:#fff;opacity:0;transition:opacity .15s;cursor:pointer}.photo-tile:hover .tile-cover-btn{opacity:1}.tile-badge{position:absolute;top:8px;right:8px;display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:#102a2abd;color:#fff}.empty-state,.login-page,.splash{min-height:100vh;display:grid;place-items:center}.empty-state{min-height:54vh;align-content:center;gap:14px;text-align:center}.empty-state h2{margin:0;font-size:28px}.empty-icon{width:74px;height:74px;display:grid;place-items:center;border-radius:18px;background:#e8e1d4;color:#514f49}.login-page{padding:24px;background:linear-gradient(135deg,rgba(21,127,120,.12),transparent 38%),linear-gradient(315deg,rgba(218,95,79,.14),transparent 42%),var(--bg)}.login-panel{width:min(100%,430px);padding:30px;display:grid;gap:16px;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow)}.login-brand{margin-bottom:6px}.login-panel h1{margin:0 0 4px;font-size:34px}.login-panel label{display:grid;gap:8px;color:var(--muted);font-weight:700;font-size:13px}.form-error{margin:0;color:#9f2b20;font-weight:700}.albums-layout,.admin-layout{display:grid;gap:20px}.album-create,.admin-create,.users-panel{border:1px solid var(--line);border-radius:8px;background:var(--panel)}.album-create{padding:14px;display:flex;flex-wrap:wrap;gap:10px}.album-create input[type=text],.album-create input:not([type]){flex:1 1 260px}.album-file-picker{cursor:pointer}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px}.album-tile{position:relative;aspect-ratio:1;border-radius:8px;background:#dfdbd1;overflow:hidden;box-shadow:0 1px #0000000a}.album-tile:hover .album-open img,.album-tile:hover .album-open .album-art{transform:scale(1.035)}.album-open{position:absolute;inset:0;width:100%;height:100%;border:0;padding:0;background:transparent;display:block;overflow:hidden}.album-tile>.icon-button{position:absolute;top:8px;right:8px;background:#fffdf8d1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.album-art{width:100%;height:100%;display:grid;place-items:center;background:#dbe9e7;color:var(--accent-strong);transition:transform .18s ease}.album-cover{width:100%;height:100%;object-fit:cover;display:block;transition:transform .18s ease}.album-label{position:absolute;bottom:0;left:0;right:0;padding:22px 10px 10px;background:linear-gradient(to top,rgba(0,0,0,.62),transparent);pointer-events:none}.album-label strong{display:block;font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-label span{font-size:12px;color:#ffffffb8}.viewer{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:#090909}.viewer-toolbar{position:fixed;top:0;left:0;right:0;z-index:2;padding:16px;display:flex;justify-content:space-between}.viewer-actions{display:flex;gap:8px}.viewer-image{max-width:calc(100vw - 420px);max-height:94vh;object-fit:contain}.viewer.info-closed .viewer-image{max-width:96vw}.viewer-nav{position:fixed;top:50%;width:48px;height:64px;display:grid;place-items:center;border:0;border-radius:8px;background:#ffffff21;color:#fff}.viewer-nav.previous{left:18px}.viewer-nav.next{right:378px}.viewer.info-closed .viewer-nav.next,.viewer-nav.next.public{right:18px}.viewer-image.public{max-width:96vw}.viewer.info-open .viewer-actions .icon-button.light{background:#00000012;color:var(--ink)}.viewer.info-open .viewer-actions .icon-button.light:hover,.viewer.info-open .viewer-actions .icon-button.light.active{background:#00000024}.info-panel{position:fixed;top:0;right:0;bottom:0;width:340px;padding:78px 22px 22px;overflow-y:auto;background:#fffdf8;color:var(--ink)}.info-panel h2{margin:0 0 22px;overflow-wrap:anywhere}.info-panel dl{display:grid;gap:16px;margin:0}.info-panel dt{color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.info-panel dd{margin:4px 0 0}.info-actions,.album-pick{display:grid;gap:10px;margin-top:24px}.album-pick span{color:var(--muted);font-weight:800;font-size:12px;text-transform:uppercase}.album-pick button{min-height:38px;border:1px solid var(--line);border-radius:8px;background:#fff;text-align:left}.admin-layout{grid-template-columns:minmax(280px,360px) 1fr;align-items:start}.modal-backdrop{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:22px;background:#19181670}.modal{width:min(920px,100%);max-height:min(760px,90vh);display:grid;grid-template-rows:auto 1fr auto;gap:16px;padding:18px;border-radius:8px;background:var(--panel);box-shadow:var(--shadow)}.modal-head,.modal-actions{display:flex;align-items:center;justify-content:space-between;gap:14px}.modal-head h2{margin:2px 0 0}.picker-grid{min-height:220px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:10px;padding-right:4px}.picker-tile{position:relative;aspect-ratio:1;overflow:hidden;border:2px solid transparent;border-radius:8px;padding:0;background:#dfdbd1}.picker-tile.selected{border-color:var(--accent)}.picker-tile img{width:100%;height:100%;display:block;object-fit:cover}.picker-tile span{position:absolute;left:6px;right:6px;bottom:6px;padding:5px 7px;border-radius:6px;background:#102a2abd;color:#fff;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-inline{min-height:220px;display:grid;place-items:center;color:var(--muted);border:1px dashed var(--line);border-radius:8px}.shared-page{min-height:100vh;padding:28px clamp(18px,4vw,48px) 56px}.shared-header{display:grid;gap:28px;margin-bottom:26px}.shared-header h1{margin:2px 0 0;font-size:clamp(34px,6vw,64px);line-height:1}.admin-create,.users-panel{padding:18px;display:grid;gap:12px}.section-title{display:flex;align-items:center;gap:10px}.section-title h2{margin:0;font-size:19px}.user-list{display:grid;gap:8px}.user-row{display:grid;grid-template-columns:minmax(0,1fr) 120px 70px 42px;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:8px}.switch{display:inline-flex;justify-content:center}.switch input{position:absolute;opacity:0}.switch span{width:42px;height:24px;border-radius:999px;background:#d3cec2;position:relative}.switch span:after{content:"";position:absolute;width:18px;height:18px;top:3px;left:3px;border-radius:50%;background:#fff;transition:transform .15s ease}.switch input:checked+span{background:var(--accent)}.switch input:checked+span:after{transform:translate(18px)}.skeleton-grid{margin-top:18px}.skeleton-tile{aspect-ratio:1;border-radius:8px;background:linear-gradient(90deg,#ebe6da,#f8f5ed,#ebe6da);background-size:200% 100%;animation:shimmer 1.3s infinite}@keyframes shimmer{to{background-position:-200% 0}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:12px;border-right:0;border-bottom:1px solid var(--line)}.brand span{display:none}.nav-list{display:flex;overflow-x:auto;margin-top:14px}.nav-item{width:auto;white-space:nowrap;padding:10px 12px}.account-strip{display:none}.mobile-only-nav{display:inline-flex}.topbar{align-items:stretch;flex-direction:column}.toolbar{flex-wrap:wrap}.search-field{width:100%;min-width:0;flex:1 1 100%}.main{padding-bottom:80px}.photo-grid,.album-grid{grid-template-columns:repeat(auto-fill,minmax(116px,1fr))}.admin-layout{grid-template-columns:1fr}.viewer{display:block}.viewer-image,.viewer-image.public{position:fixed;top:0;left:0;width:100vw;height:100vh;margin:0;padding:72px 2vw 8px;box-sizing:border-box;max-width:none;max-height:none;object-fit:contain}.viewer.info-open .viewer-image{padding-bottom:32vh}.info-panel{top:auto;width:100%;height:32vh;padding-top:18px}.viewer-nav.next{right:18px}.album-actions{align-items:stretch;flex-direction:column}.album-actions>div{justify-content:flex-start}.user-row{grid-template-columns:1fr}.select-bar{left:0}}
