:root{--bg:#fffaf3;--paper:#ffffff;--ink:#25201b;--muted:#756f68;--line:#eadfce;--brand:#4f7b62;--brand-ink:#ffffff;--accent:#e7a23f;--soft:#f4eadb;--danger:#b64535}*{box-sizing:border-box}body,html{margin:0;min-height:100%;background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.shell{width:min(1040px,100%);margin:0 auto;padding:18px 18px 96px}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:10;border-bottom:1px solid var(--line);background:rgba(255,250,243,.92);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar-inner{display:flex;align-items:center;gap:14px;width:min(1040px,100%);margin:0 auto;padding:12px 18px}.brand{display:flex;flex-direction:column;margin-right:auto;line-height:1.1}.brand strong{font-size:18px}.brand span,.muted{color:var(--muted);font-size:13px}.nav{display:flex;gap:6px;overflow-x:auto}.button,.nav a,button.button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);padding:0 12px;white-space:nowrap;cursor:pointer}.button.primary{border-color:var(--brand);background:var(--brand);color:var(--brand-ink)}.button.danger{border-color:var(--danger);color:var(--danger)}.hero{display:grid;grid-gap:18px;gap:18px;padding:40px 0 28px}.hero h1,.page-title h1{margin:0;font-size:clamp(30px,5vw,54px);line-height:1.05;letter-spacing:0}.hero p,.page-title p{margin:0;max-width:640px;color:var(--muted);font-size:17px;line-height:1.6}.page-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:20px 0}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:6px;gap:6px}.photo-tile{position:relative;overflow:hidden;aspect-ratio:1;border-radius:8px;background:var(--soft)}.photo-tile img,.photo-tile video{width:100%;height:100%;object-fit:cover;display:block}.tile-meta{position:absolute;inset:auto 0 0;display:flex;justify-content:space-between;gap:8px;padding:30px 8px 8px;color:#fff;font-size:12px;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent)}.panel{border:1px solid var(--line);border-radius:8px;background:var(--paper);padding:16px}.stack{display:grid;grid-gap:12px;gap:12px}.form-row{display:grid;grid-gap:6px;gap:6px}.form-row input,.form-row select,.form-row textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:6px;gap:6px}.day-cell{min-height:118px;border:1px solid var(--line);border-radius:8px;background:var(--paper);padding:8px;overflow:hidden}.day-cell.has-photo{background-size:cover;background-position:50%;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}.day-cell.out-of-month{opacity:.45}.viewer-main{display:flex;flex-direction:column;gap:12px;min-width:0}.viewer-media-inner{display:block;width:100%;will-change:transform;touch-action:pan-y}.photo-nav-bar{display:grid;grid-template-columns:1fr auto 1fr;grid-gap:10px;gap:10px}.photo-nav-card{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--paper);border:1px solid var(--line);border-radius:14px;text-decoration:none;color:inherit;font-weight:600;box-shadow:0 1px 2px rgba(0,0,0,.04);transition:transform .15s ease,box-shadow .15s ease,background .15s ease;min-height:60px}.photo-nav-card:hover{background:var(--soft);box-shadow:0 4px 12px rgba(0,0,0,.08)}.photo-nav-card:active{transform:scale(.985)}.photo-nav-prev{justify-content:flex-start}.photo-nav-next{justify-content:flex-end}.photo-nav-empty{visibility:hidden}.photo-nav-thumb{width:44px;height:44px;border-radius:10px;background-size:cover;background-position:50%;background-color:var(--soft);flex-shrink:0}.photo-nav-label{font-size:14px;color:var(--ink)}.photo-nav-save{justify-content:center;background:var(--brand);color:#fff;border-color:transparent;padding:8px 18px;font:inherit;cursor:pointer}.photo-nav-save:hover{background:color-mix(in srgb,var(--brand) 88%,black)}.photo-nav-save:disabled{opacity:.6;cursor:not-allowed}.photo-nav-save .photo-nav-label{color:#fff}.photo-lightbox{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.94);display:flex;align-items:center;justify-content:center;padding:16px;animation:photo-lightbox-in .18s ease}.photo-lightbox img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.photo-lightbox-close{position:absolute;top:16px;right:16px;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:none;background:rgba(255,255,255,.18);color:#fff;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.photo-lightbox-close:hover{background:rgba(255,255,255,.28)}@keyframes photo-lightbox-in{0%{opacity:0}to{opacity:1}}.upload-row{display:grid;grid-gap:4px;gap:4px}.upload-row-head{display:flex;justify-content:space-between;gap:8px;font-size:13px}.upload-row-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-bar{height:6px;border-radius:4px;background:var(--soft);overflow:hidden}.upload-bar>span{display:block;height:100%;background:var(--brand);transition:width .18s ease}.upload-bar[data-status=error]>span{background:var(--danger)}.upload-bar[data-status=done]>span{background:var(--accent)}.viewer{display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-gap:18px;gap:18px;align-items:start}.viewer-media{position:relative;overflow:hidden;border-radius:8px;background:#111}.viewer-media img,.viewer-media video{display:block;width:100%;max-height:78vh;object-fit:contain}.dropzone{border:2px dashed var(--line);border-radius:8px;background:var(--paper);padding:28px;text-align:center}.bottom-tabs{display:none}@media (max-width:760px){.topbar-inner{align-items:flex-start;flex-direction:column}.nav{display:none}.viewer{grid-template-columns:1fr}.grid{grid-template-columns:repeat(3,1fr)}.calendar-grid{gap:4px}.day-cell{min-height:76px;padding:5px;font-size:12px}.bottom-tabs{position:fixed;z-index:20;right:10px;bottom:10px;left:10px;display:grid;grid-template-columns:repeat(5,1fr);grid-gap:4px;gap:4px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.95);padding:6px;box-shadow:0 10px 30px rgba(38,30,20,.16)}.bottom-tabs a{display:grid;place-items:center;grid-gap:2px;gap:2px;min-height:48px;border-radius:6px;color:var(--muted);font-size:11px}}