: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);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--bottom-nav-h: 60px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh;-webkit-tap-highlight-color:transparent}img{-webkit-user-drag:none}button,input,select{font:inherit}input,select{font-size:16px}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-shell{min-height:100vh;min-height:100dvh}.sidebar{display:contents}.sidebar .brand,.account-strip{display:none}.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;flex-shrink:0}.nav-list{position:fixed;bottom:0;left:0;right:0;z-index:40;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:2px;padding:6px 6px calc(6px + var(--safe-bottom));background:#fffdf8f0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--line)}.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{flex-direction:column;gap:3px;min-height:48px;padding:6px 2px;border-radius:10px;font-size:11px;font-weight:700;color:var(--muted);background:transparent}.nav-item.active{color:var(--accent-strong);background:#e6efed}.main{min-width:0;padding:14px 12px calc(var(--bottom-nav-h) + var(--safe-bottom) + 28px)}.topbar{display:grid;gap:12px;margin-bottom:16px}.topbar-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;min-width:0}.topbar h1{margin:2px 0 0;font-size:clamp(26px,6vw,48px);line-height:1.05;letter-spacing:0;overflow-wrap:anywhere}.eyebrow{margin:0;text-transform:uppercase;font-weight:800;color:var(--muted);font-size:13px}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.search-field{flex:1 1 160px;min-width:0;height:44px;padding:0 12px;display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:10px;background:var(--panel);color:var(--muted)}.search-field input,.login-panel input,.album-create input,.admin-create input,.edit-album-rename 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 14px;border-radius:10px;font-weight:800;text-decoration:none;white-space:nowrap}.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:44px;height:44px;flex-shrink:0;border-radius:10px;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:#000000a8}.text-button{padding:6px 0;background:transparent;color:var(--accent-strong);font-weight:800}.album-actions .text-button{align-self:flex-start}.hidden-input{display:none}.mobile-only{display:inline-flex}.toast{position:fixed;top:calc(10px + var(--safe-top));left:50%;transform:translate(-50%);z-index:100;max-width:calc(100vw - 32px);padding:12px 18px;border-radius:10px;background:#102a2a;color:#fff;box-shadow:var(--shadow)}.view-note{margin:0 0 14px;padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--panel);color:var(--muted);font-size:14px}.trash-note{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.trash-note p{margin:0}.trash-note .danger-button{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.library{display:grid;gap:22px}.drop-area{position:relative;min-height:54vh;min-height:54dvh}.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)}.date-group h2{margin:0 0 8px;font-size:15px;letter-spacing:0}.album-actions{display:flex;flex-direction:column;align-items:stretch;gap:10px}.album-actions>div{display:flex;flex-wrap:wrap;gap:8px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:4px}.photo-tile{position:relative;aspect-ratio:1;border:0;border-radius:6px;overflow:hidden;padding:0;background:#dfdbd1;box-shadow:0 1px #0000000a;user-select:none;-webkit-user-select:none;touch-action:pan-y}.photo-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .18s ease}@media(hover:hover){.photo-tile:hover img{transform:scale(1.035)}}.photo-tile.selectable:not(.is-selected) img{opacity:.5}.tile-checkbox{position:absolute;top:8px;left:8px;width:24px;height:24px;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:6px;top:2px;width:7px;height:11px;border:2px solid white;border-top:0;border-left:0;transform:rotate(45deg)}.tile-cover-btn{position:absolute;bottom:6px;left:6px;width:28px;height:28px;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,.tile-cover-btn:focus-visible{opacity:1}@media(hover:none){.tile-cover-btn{opacity:.9}}.tile-badge{position:absolute;top:6px;right:6px;display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:#102a2abd;color:#fff}.select-bar{position:fixed;left:10px;right:10px;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 10px);z-index:45;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:14px;background:#102a2a;color:#fff;box-shadow:var(--shadow);animation:slideUp .18s ease}@keyframes slideUp{0%{transform:translateY(calc(100% + 20px))}to{transform:translateY(0)}}.select-bar-actions{display:flex;gap:2px}.select-count{font-weight:700;white-space:nowrap}.icon-button.bar{width:42px;height:42px;color:#fff;background:transparent}.icon-button.bar:hover{background:#ffffff24}.icon-button.bar.danger{color:#ffb4a8}.upload-progress{position:fixed;left:10px;right:10px;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 10px);z-index:46;display:grid;gap:8px;padding:14px;border-radius:14px;background:#102a2a;color:#fff;box-shadow:var(--shadow)}.upload-progress span{font-size:14px;font-weight:700}.upload-progress-track{height:6px;border-radius:999px;background:#ffffff2e;overflow:hidden}.upload-progress-bar{height:100%;border-radius:999px;background:#57c4bb;transition:width .2s ease}.album-pick-list{display:grid;gap:8px;max-height:40vh;max-height:40dvh;overflow-y:auto}.album-pick-list button{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:48px;padding:0 14px;border:1px solid var(--line);border-radius:10px;background:#fff;text-align:left}.album-pick-list button span{color:var(--muted);font-size:13px;white-space:nowrap}.album-pick-empty{margin:0;color:var(--muted)}.album-pick-create{display:flex;gap:8px}.album-pick-create input{flex:1;min-width:0;min-height:44px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fff;outline:none}.empty-state,.login-page,.splash{min-height:100vh;min-height:100dvh;display:grid;place-items:center}.empty-state{min-height:50vh;min-height:50dvh;align-content:center;gap:14px;text-align:center}.empty-state h2{margin:0;font-size:24px}.empty-icon{width:74px;height:74px;display:grid;place-items:center;border-radius:18px;background:#e8e1d4;color:#514f49}.login-page{padding:20px;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:clamp(22px,5vw,30px);display:grid;gap:16px;border:1px solid var(--line);border-radius:14px;background:var(--panel);box-shadow:var(--shadow)}.login-brand{margin-bottom:6px}.login-panel h1{margin:0 0 4px;font-size:clamp(28px,7vw,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:16px}.album-create,.admin-create,.users-panel{border:1px solid var(--line);border-radius:12px;background:var(--panel)}.album-create{padding:12px;display:flex;flex-wrap:wrap;gap:8px}.album-create input[type=text],.album-create input:not([type]){flex:1 1 100%}.album-create .album-file-picker,.album-create .primary-button{flex:1 1 auto}.album-file-picker{cursor:pointer}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.album-tile{position:relative;aspect-ratio:1;border-radius:10px;background:#dfdbd1;overflow:hidden;box-shadow:0 1px #0000000a}@media(hover:hover){.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:6px;right:6px;width:40px;height:40px;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;text-align:left}.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:flex;flex-direction:column;height:100vh;height:100dvh;background:#0b0b0b}.viewer-stage{position:relative;flex:1;min-height:0;min-width:0;display:flex;align-items:center;justify-content:center;overflow:hidden;touch-action:none}.viewer-image{max-width:100%;max-height:100%;object-fit:contain;user-select:none;-webkit-user-select:none}.viewer-image.loading{opacity:0}.viewer-backdrop{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(22px) brightness(.7);transform:scale(1.06);pointer-events:none}.viewer-topbar{position:absolute;top:0;left:0;right:0;z-index:3;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:calc(10px + var(--safe-top)) 12px 22px;background:linear-gradient(to bottom,rgba(0,0,0,.55),transparent);pointer-events:none}.viewer-topbar button,.viewer-actions{pointer-events:auto}.viewer-actions{display:flex;gap:6px}.viewer-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:48px;height:64px;display:grid;place-items:center;border:0;border-radius:10px;background:#ffffff21;color:#fff}.viewer-nav.previous{left:14px}.viewer-nav.next{right:14px}@media(hover:none){.viewer-nav{width:36px;height:56px;background:#0003;color:#ffffffbf}.viewer-nav.previous{left:8px}.viewer-nav.next{right:8px}}.info-panel{position:absolute;left:0;right:0;bottom:0;z-index:4;max-height:60vh;max-height:60dvh;overflow-y:auto;padding:10px 18px calc(18px + var(--safe-bottom));border-radius:18px 18px 0 0;background:#fffdf8;color:var(--ink);box-shadow:0 -12px 40px #00000059}.info-grip{width:42px;height:4px;margin:0 auto 14px;border-radius:999px;background:var(--line)}.info-panel h2{margin:0 0 18px;font-size:19px;overflow-wrap:anywhere}.info-panel dl{display:grid;gap:14px;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:20px}.album-pick span{color:var(--muted);font-weight:800;font-size:12px;text-transform:uppercase}.album-pick button{min-height:44px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fff;text-align:left}.modal-backdrop{position:fixed;inset:0;z-index:90;display:flex;align-items:flex-end;justify-content:center;background:#19181670}.modal{width:100%;max-height:92vh;max-height:92dvh;display:grid;grid-template-rows:auto 1fr auto;gap:14px;padding:16px 16px calc(16px + var(--safe-bottom));border-radius:18px 18px 0 0;background:var(--panel);box-shadow:var(--shadow);animation:sheetUp .2s ease}@keyframes sheetUp{0%{transform:translateY(24px);opacity:.6}to{transform:translateY(0);opacity:1}}.confirm-modal{grid-template-rows:none;display:flex;flex-direction:column;gap:12px}.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}.modal-head,.modal-actions{display:flex;align-items:center;justify-content:space-between;gap:14px}.modal-head h2{margin:2px 0 0;font-size:20px}.modal-actions{justify-content:flex-end}.picker-scroll{min-height:160px;overflow-y:auto;padding-right:2px;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:16px}.picker-day-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.picker-day-head h3{margin:0;font-size:14px}.picker-day-toggle{display:inline-flex;align-items:center;gap:8px;border:0;background:none;padding:4px 6px;border-radius:8px;color:var(--accent);font-size:13px;font-weight:600}.day-checkbox{position:relative;width:20px;height:20px;border-radius:50%;border:2px solid var(--accent);background:transparent}.day-checkbox.checked{background:var(--accent)}.day-checkbox.checked:after{content:"";position:absolute;left:4px;top:0;width:6px;height:10px;border:2px solid white;border-top:0;border-left:0;transform:rotate(45deg)}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:6px}.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}.edit-album-body{display:flex;flex-direction:column;gap:20px;align-content:start}.edit-album-rename{display:flex;gap:8px}.edit-album-rename input{flex:1;min-width:0;padding:10px 12px}.danger-zone{display:flex;flex-direction:column;gap:14px;align-items:flex-start;padding-top:16px;border-top:1px solid var(--line)}.check-label{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}.check-label input{width:18px;height:18px;accent-color:var(--accent)}.danger-zone .danger-button{display:inline-flex;align-items:center;gap:8px}.empty-inline{min-height:160px;display:grid;place-items:center;color:var(--muted);border:1px dashed var(--line);border-radius:8px}.shared-page{min-height:100vh;min-height:100dvh;padding:18px 14px 48px}.shared-footer{margin-top:44px;text-align:center;font-size:13px}.shared-footer a,.shared-footer span{color:var(--muted);text-decoration:none}.shared-footer a:hover{text-decoration:underline}.shared-header{display:grid;gap:18px;margin-bottom:18px}.shared-header h1{margin:2px 0 0;font-size:clamp(30px,7vw,64px);line-height:1.05;overflow-wrap:anywhere}.admin-create,.users-panel{padding:14px;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:1fr;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:10px}.user-row div{min-width:0;display:grid;gap:2px}.user-row span{color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis}.switch{display:inline-flex;justify-content:flex-start}.switch input{position:absolute;opacity:0}.switch span{width:46px;height:26px;border-radius:999px;background:#d3cec2;position:relative}.switch span:after{content:"";position:absolute;width:20px;height:20px;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(20px)}.skeleton-grid{margin-top:12px}.skeleton-tile{aspect-ratio:1;border-radius:6px;background:linear-gradient(90deg,#ebe6da,#f8f5ed,#ebe6da);background-size:200% 100%;animation:shimmer 1.3s infinite}@keyframes shimmer{to{background-position:-200% 0}}@media(min-width:900px){.app-shell{display:grid;grid-template-columns:280px 1fr}.sidebar{display:flex;flex-direction:column;position:sticky;top:0;height:100vh;height:100dvh;padding:22px 16px;border-right:1px solid var(--line);background:#fffdf8e6}.sidebar .brand{display:flex}.account-strip{margin-top:auto;padding:12px;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.account-strip div{min-width:0;display:grid;gap:2px}.account-strip span{color:var(--muted);font-size:13px;overflow:hidden;text-overflow:ellipsis}.nav-list{position:static;display:grid;grid-auto-flow:row;grid-auto-columns:unset;gap:6px;margin-top:30px;padding:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-top:0}.nav-item{flex-direction:row;width:100%;justify-content:flex-start;gap:10px;min-height:0;padding:12px 14px;border-radius:8px;font-size:inherit;font-weight:inherit}.nav-item:hover,.nav-item.active{background:#e9e5da;color:var(--ink)}.mobile-only{display:none}.main{padding:28px clamp(18px,4vw,44px) 56px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:26px}.search-field{flex:0 1 360px;min-width:220px}.toast{inset:auto 22px 22px auto;transform:none}.library{gap:28px}.date-group h2{font-size:18px;margin-bottom:12px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px}.photo-tile{border-radius:8px}.album-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px}.album-actions{flex-direction:row;align-items:center;justify-content:space-between;gap:14px}.album-actions>div{justify-content:flex-end}.album-create input[type=text],.album-create input:not([type]){flex:1 1 260px}.album-create .album-file-picker,.album-create .primary-button{flex:0 0 auto}.select-bar{left:296px;right:16px;bottom:16px}.upload-progress{left:auto;right:22px;bottom:22px;width:360px}.empty-state h2{font-size:28px}.viewer.info-open{flex-direction:row}.info-panel{position:static;flex:0 0 340px;max-height:none;height:auto;overflow-y:auto;padding:24px 22px;border-radius:0;box-shadow:none}.info-grip{display:none}.info-panel h2{font-size:22px;margin-bottom:22px}.modal-backdrop{align-items:center;padding:22px}.modal{width:min(920px,100%);max-height:min(760px,90vh);padding:18px;border-radius:14px}.confirm-modal{max-width:460px;padding:22px}.picker-scroll{min-height:220px}.picker-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:10px}.shared-page{padding:28px clamp(18px,4vw,48px) 56px}.shared-header{gap:28px;margin-bottom:26px}.admin-layout{grid-template-columns:minmax(280px,360px) 1fr;align-items:start;gap:20px}.admin-create,.users-panel{padding:18px}.user-row{grid-template-columns:minmax(0,1fr) 120px 70px 44px;gap:12px}.switch{justify-content:center}}
