@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700&family=Literata:opsz,wght@7..72,500&display=swap";:root{--background: #f6f9ef;--surface: #fcfff9;--ink: #20340f;--muted: #5a6f46;--accent: #5f9735;--accent-strong: #497626;--danger: #a13a27;--shadow: 0 14px 32px rgba(34, 64, 19, .12)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Space Grotesk,sans-serif;color:var(--ink);background:radial-gradient(1200px circle at 10% 20%,rgba(126,171,88,.15),transparent 60%),radial-gradient(900px circle at 90% 80%,rgba(168,201,92,.18),transparent 70%),var(--background)}body.account-mode{background:radial-gradient(1200px circle at 10% 20%,rgba(84,124,48,.28),transparent 60%),radial-gradient(900px circle at 90% 80%,rgba(100,140,57,.24),transparent 70%),#12210b}body.account-mode h3,body.account-mode strong{color:var(--ink)}h1,h2,h3{margin:0;font-family:Literata,serif}a{color:inherit;text-decoration:none}button,input{font:inherit}.page-shell,.landing-shell,.auth-shell{width:min(1120px,94vw);margin:0 auto;min-height:100vh;padding:1.4rem 0 4rem}.auth-shell{display:flex;flex-direction:column}.auth-main{flex:1;display:grid;place-items:center}.app-topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.2rem}.topbar-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:.6rem}.brand-link{display:inline-flex;align-items:center;gap:.62rem;font-family:Literata,serif;font-size:1.3rem;font-weight:700;letter-spacing:.01em}body.account-mode .brand-link{color:#e8f4dd}.brand-logo{width:100px;height:90px;object-fit:contain;border-radius:12px;padding:.18rem}.auth-card,.panel,.timeline-item,.album-card{border:1px solid rgba(95,151,53,.22);border-radius:18px;background:linear-gradient(160deg,#fcfff9f2,#f2f9e9e6);box-shadow:var(--shadow)}.auth-card{width:min(460px,95vw);padding:2rem}.auth-card>.secondary-button{margin-top:.9rem}.auth-card p{color:var(--muted)}.auth-form,.album-form,.upload-form{display:grid;gap:.8rem;margin-top:1.1rem}.upload-dropzone{border:1px dashed rgba(73,118,38,.45);border-radius:12px;padding:.7rem;background:#fcfff98c}.upload-dropzone.is-active{border-color:var(--accent);background:#5f97351f}.upload-dropzone p{margin:0 0 .5rem;color:var(--muted);font-size:.92rem}.auth-form label{display:grid;gap:.3rem;color:var(--muted)}.album-input-title{font-size:1.06rem;font-weight:600;padding:.8rem .92rem}.album-input-meta{font-size:.9rem;padding:.54rem .74rem}input{border:1px solid rgba(73,118,38,.25);border-radius:12px;padding:.62rem .76rem;background:#fff}button{border:0;border-radius:12px;padding:.62rem .86rem;cursor:pointer;transition:transform .12s ease,filter .12s ease}button:hover{transform:translateY(-1px);filter:brightness(1.03)}.auth-form button,.album-form button,.upload-form button{color:#f8fff2;background:var(--accent)}.secondary-button{color:var(--accent-strong);background:#5f97351f}.secondary-link-button,.primary-link-button{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:.62rem .86rem;transition:transform .12s ease,filter .12s ease}.secondary-link-button:hover,.primary-link-button:hover{transform:translateY(-1px);filter:brightness(1.03)}.secondary-link-button{color:var(--accent-strong);background:#5f97351f}.primary-link-button{color:#f8fff2;background:var(--accent)}.link-button{padding:0;background:transparent;color:var(--accent-strong);border-radius:0}.danger-button{background:#a13a271f;color:var(--danger)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.page-header p{margin:.5rem 0 0;color:var(--muted)}body.account-mode .page-header h1{color:#eaf7dc}.edit-mode-badge{display:inline-flex;margin-top:.7rem;padding:.35rem .62rem;border-radius:999px;background:#182c0f57;color:#d9edc8;border:1px solid rgba(114,161,75,.45);font-size:.8rem;font-weight:600;letter-spacing:.01em}.landing-hero{margin-top:4.2rem;max-width:780px}.landing-hero h2{font-size:clamp(1.9rem,4vw,3rem);line-height:1.12}.landing-hero p{margin:1rem 0 0;color:var(--muted);font-size:1.06rem;line-height:1.5}.landing-cta-row{margin-top:1.3rem}.public-feed{margin-top:2.4rem}.public-feed>h3{margin-bottom:.8rem}.muted-copy{color:var(--muted)}.public-timeline{width:min(100%,980px);margin:0 auto}.public-timeline-list{position:relative;--timeline-photo-width: clamp(220px, 30vw, 320px);--timeline-gap: 1rem;--timeline-node-col: 40px;--timeline-rail-x: calc( var(--timeline-photo-width) + var(--timeline-gap) + (var(--timeline-node-col) / 2) );display:grid;gap:1rem}.public-timeline-list:before{content:"";position:absolute;top:1.25rem;bottom:1.25rem;left:var(--timeline-rail-x);width:2px;transform:translate(-50%);background:#5f973559}.public-timeline-entry{display:grid;grid-template-columns:var(--timeline-photo-width) var(--timeline-node-col) minmax(0,1fr);gap:1rem;align-items:start;padding:.35rem 0}.public-timeline-photo img{width:100%;max-width:100%;height:auto;display:block;border-radius:16px}.public-timeline-node{position:relative;z-index:1;display:grid;place-items:start center;padding-top:.2rem}.public-timeline-dot{width:12px;height:12px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 3px #5f973538,0 0 0 7px #5f973514}.public-photo-meta h3{margin:0}.public-photo-meta p{margin:.35rem 0 0;color:var(--muted)}.panel{padding:1rem;margin-bottom:1.4rem}.masonry-grid{column-count:4;column-gap:1rem}.album-card{break-inside:avoid;margin-bottom:1rem;overflow:hidden}.album-card img,.timeline-item img{width:100%;height:auto;display:block}.photo-frame{position:relative}.photo-location-badge{position:absolute;left:.5rem;bottom:.5rem;max-width:calc(100% - 1rem);padding:.2rem .45rem;border-radius:999px;background:#20340fc7;color:#f8fff2;font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-meta{padding:.8rem}.album-meta p{color:var(--muted);margin:.35rem 0}.placeholder-tile{min-height:160px;display:grid;place-items:center;background:repeating-linear-gradient(45deg,#5f97350f,#5f97350f 12px,#5f97351c 12px,#5f97351c 24px);color:var(--muted)}.timeline{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.9rem;align-items:start}.timeline-item{padding:.8rem;display:grid;gap:.55rem}.timeline-item header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .52rem;border-radius:999px;font-size:.82rem;text-transform:capitalize}.status-ready{background:#5f973533}.status-pending{background:#ab912033}.status-failed{background:#a13a2733}.error-box{padding:.55rem .7rem;border-radius:10px;background:#a13a271a;color:var(--danger)}@media (max-width: 980px){.page-shell,.landing-shell,.auth-shell{width:min(1120px,96vw);padding:1rem 0 3rem}.public-timeline-list{--timeline-photo-width: clamp(180px, 32vw, 260px)}.masonry-grid{column-count:3}.timeline{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.app-topbar,.page-header{flex-direction:column;align-items:flex-start}.app-topbar{width:100%}.topbar-actions{width:100%;justify-content:flex-start}.topbar-actions .secondary-button,.topbar-actions .secondary-link-button,.topbar-actions .primary-link-button{width:100%;justify-content:center}.landing-hero{margin-top:2.5rem}.panel{padding:.85rem;margin-bottom:1rem}.timeline-item header{flex-wrap:wrap;gap:.45rem}.upload-dropzone p{font-size:.86rem}.masonry-grid{column-count:2}.public-timeline-entry{grid-template-columns:1fr}.public-timeline-list:before{display:none}.public-timeline-node{display:none}.timeline{grid-template-columns:1fr}}@media (max-width: 520px){.page-shell,.landing-shell,.auth-shell{width:min(1120px,97vw);padding:.8rem 0 2rem}.auth-card{padding:1.2rem}.auth-form button,.album-form button,.upload-form button,.secondary-button,.secondary-link-button,.primary-link-button{width:100%}.masonry-grid{column-count:1}.brand-link{font-size:1.15rem}.brand-logo{width:88px;height:80px}}
