:root{--bg: #faf6f0;--surface: #ffffff;--ink: #2e2a25;--muted: #8a8077;--brand: #7c6a5a;--brand-dark: #5d4f42;--accent: #c9a24b;--line: #e9e1d6;--error: #b4402f;--radius: 14px;--shadow: 0 10px 30px rgba(60, 48, 36, .08)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column}.site-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--line);background:#ffffffb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);position:sticky;top:0;z-index:10}.brand{font-family:Georgia,Times New Roman,serif;font-size:1.4rem;color:var(--brand-dark);text-decoration:none;letter-spacing:.02em}.amp{color:var(--accent);font-style:italic}.site-nav a{color:var(--brand);text-decoration:none;font-weight:600;padding:.4rem .9rem;border-radius:999px;border:1px solid var(--line)}.site-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:2rem 1.5rem 3rem}.site-footer{text-align:center;color:var(--muted);padding:1.5rem;border-top:1px solid var(--line);font-size:.9rem}.muted{color:var(--muted)}.center{text-align:center}.btn{display:inline-block;border:none;border-radius:999px;padding:.8rem 1.7rem;font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .06s ease,background .2s ease,box-shadow .2s ease}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow)}.btn-primary:not(:disabled):hover{background:var(--brand-dark);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--brand-dark);border:1px solid var(--line);padding:.55rem 1rem;font-size:.9rem}.btn-ghost:not(:disabled):hover{background:#fff}.field{display:flex;flex-direction:column;gap:.35rem;margin:1.2rem 0}.field span{font-weight:600;font-size:.9rem}.field input{padding:.75rem .9rem;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:var(--surface)}.field input:focus{outline:2px solid var(--accent);outline-offset:1px}.form-error{color:var(--error);font-weight:600}.hero{text-align:center;padding:3rem 1rem}.hero-kicker{text-transform:uppercase;letter-spacing:.25em;color:var(--accent);font-size:.8rem;margin-bottom:.5rem}.hero-title{font-family:Georgia,serif;font-size:clamp(2.6rem,8vw,4.6rem);margin:.2rem 0 1rem;color:var(--brand-dark);font-weight:500}.hero-subtitle{max-width:520px;margin:0 auto 2rem;color:var(--muted);font-size:1.1rem}.upload-page h1{font-family:Georgia,serif;color:var(--brand-dark);font-weight:500}.dropzone{border:2px dashed var(--line);border-radius:var(--radius);background:var(--surface);padding:2.5rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s ease,background .2s ease;margin:1rem 0 1.5rem}.dropzone:hover,.dropzone--active{border-color:var(--accent);background:#fffdf8}.dropzone-inner{display:flex;flex-direction:column;gap:.3rem;align-items:center}.dropzone-icon{font-size:2rem}.upload-list{list-style:none;margin:0 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.6rem}.upload-item{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem;display:grid;grid-template-columns:1fr auto;gap:.4rem 1rem;align-items:center}.upload-item-head{display:flex;justify-content:space-between;gap:1rem;grid-column:1 / -1}.upload-item-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60vw}.upload-item-size{color:var(--muted);font-size:.85rem;white-space:nowrap}.upload-item-status{font-size:.85rem;font-weight:600;color:var(--muted);text-align:right}.upload-item--done .upload-item-status{color:#3f7d4f}.upload-item--error{border-color:#e7c4bd}.upload-item-error{color:var(--error);font-size:.88rem;margin:0;grid-column:1 / -1}.progress{grid-column:1 / 2;height:8px;background:var(--line);border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:var(--accent);width:0;transition:width .2s ease}.upload-actions{display:flex;flex-direction:column;gap:.8rem;align-items:flex-start}.upload-thanks{color:#3f7d4f;font-weight:600;margin:0}.login{max-width:380px;margin:3rem auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}.login h1{font-family:Georgia,serif;font-weight:500;color:var(--brand-dark);margin-top:0}.login-form{display:flex;flex-direction:column}.login-form .btn{margin-top:.5rem}.gallery-toolbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.gallery-toolbar h1{font-family:Georgia,serif;font-weight:500;color:var(--brand-dark);margin:0}.gallery-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.seg{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--surface)}.seg button{border:none;background:transparent;padding:.5rem 1rem;cursor:pointer;font-weight:600;color:var(--muted)}.seg .seg-on{background:var(--brand);color:#fff}.moment{margin-bottom:2rem}.moment-title{font-family:Georgia,serif;font-weight:500;color:var(--brand-dark);border-bottom:1px solid var(--line);padding-bottom:.4rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.6rem}.tile{position:relative;aspect-ratio:1 / 1;border:none;padding:0;border-radius:10px;overflow:hidden;cursor:pointer;background:var(--line)}.tile img{width:100%;height:100%;object-fit:cover;display:block}.tile-video{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--brand-dark);background:linear-gradient(135deg,#efe7da,#e3d6c4)}.tile-star{position:absolute;top:6px;right:8px;color:var(--accent);text-shadow:0 1px 2px rgba(0,0,0,.4);font-size:1.1rem}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#191410d9;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:50}.lightbox-content{position:relative;max-width:92vw;max-height:90vh;background:var(--surface);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.lightbox-content img,.lightbox-content video{max-width:92vw;max-height:72vh;object-fit:contain;background:#000}.lightbox-meta{padding:.8rem 1.1rem}.lightbox-caption{font-weight:600;margin:0 0 .2rem}.lightbox-close{position:absolute;top:.6rem;right:.6rem;border:none;background:#00000080;color:#fff;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1rem}@media (max-width: 600px){.site-main{padding:1.5rem 1rem 2.5rem}.grid{grid-template-columns:repeat(auto-fill,minmax(105px,1fr))}}
