:root{color-scheme:light only;--bg-color: #fdf2f8;--bg-warm: #f9ecf5;--bg-card: #ffffff;--fg-color: #3d1f3a;--secondary-bg-color: #f9ecf5;--tertiary-bg-color: #f3e3f0;--text-body: #6b4a68;--text-title: #3d1f3a;--border-color: #e8cfe4;--primary: #e91e8c;--primary-hover: #d0167a;--primary-glow: rgba(233,30,140,.12);--link-color: #9a7b96;--accent-teal: #1aad6e;--accent-orange: #f07030;--accent-yellow: #d4a017;--accent-purple: #8b3fbd;--accent-coral: #e85670;--font-display: "Caveat", cursive;--font-body: "Patrick Hand", cursive;--stitch: 4px dashed}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{background-color:#fdf2f8;color-scheme:light only}body{font-family:var(--font-body);color:var(--text-body);background-color:#fdf2f8;-webkit-font-smoothing:antialiased;min-height:100vh;min-height:100dvh;overflow-x:hidden}.app{min-height:100vh;min-height:100dvh;background-color:#fdf2f8}.auth-bar{display:flex;justify-content:flex-end;padding:10px 24px;background-color:#f9ecf5;border-bottom:3px dashed var(--border-color)}.user-info{display:flex;align-items:center;gap:10px;font-size:15px}.user-avatar,.user-avatar-fallback{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--accent-teal)}.user-avatar-fallback{background:var(--tertiary-bg-color);color:var(--accent-teal);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.user-name{color:var(--text-title)}.btn-text{background:none;border:none;color:var(--accent-teal);cursor:pointer;font-size:14px;text-decoration:underline;text-decoration-style:wavy;text-underline-offset:4px;text-decoration-color:#1aad6e66;font-family:var(--font-body);transition:color .2s}.btn-text:hover{color:var(--primary);text-decoration-color:var(--primary)}.google-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:50px;border:2px solid var(--border-color);background:var(--bg-card);cursor:pointer;font-family:var(--font-body);font-size:17px;color:var(--fg-color);text-decoration:none;transition:all .25s;box-shadow:0 2px 12px #8b3fbd14}.google-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 20px var(--primary-glow);transform:translateY(-2px)}.google-btn.large{padding:18px 44px;font-size:19px}.error-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 24px;background:#fde8ec;color:var(--accent-coral);font-size:15px;border-bottom:2px solid #f5c6ce}.error-banner button{background:none;border:none;cursor:pointer;color:var(--accent-coral)}.hero{text-align:center;padding:50px 24px 60px;position:relative;overflow:hidden;background-color:#f5e0f0;background-image:radial-gradient(ellipse at 50% 30%,#e91e8c0d,#f5e0f000 50%),radial-gradient(ellipse at 20% 70%,#8b3fbd0a,#f5e0f000 45%),radial-gradient(ellipse at 80% 50%,#1aad6e08,#f5e0f000 40%),linear-gradient(180deg,#f5e0f0,#fdf2f8)}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(3px 3px at 12% 25%,rgba(233,30,140,.15) 50%,transparent 100%),radial-gradient(2px 2px at 88% 15%,rgba(26,173,110,.15) 50%,transparent 100%),radial-gradient(3px 3px at 25% 75%,rgba(139,63,189,.12) 50%,transparent 100%),radial-gradient(2px 2px at 75% 80%,rgba(240,112,48,.12) 50%,transparent 100%),radial-gradient(3px 3px at 50% 10%,rgba(212,160,23,.12) 50%,transparent 100%),radial-gradient(2px 2px at 5% 55%,rgba(233,30,140,.1) 50%,transparent 100%),radial-gradient(3px 3px at 92% 45%,rgba(139,63,189,.1) 50%,transparent 100%),radial-gradient(2px 2px at 35% 5%,rgba(232,86,112,.1) 50%,transparent 100%);opacity:.7;pointer-events:none}.hero>*{position:relative;z-index:1}.hero-cats{display:block;max-width:560px;width:85%;margin:0 auto 16px;pointer-events:none}.hero-name{font-family:var(--font-display);font-size:clamp(52px,9vw,110px);font-weight:700;color:var(--text-title);line-height:1;margin-bottom:8px}.hero-years{font-family:var(--font-body);font-size:20px;color:var(--accent-teal);letter-spacing:.2em;margin-bottom:24px}.hero-epitaph{font-family:var(--font-display);font-size:clamp(24px,4.5vw,34px);color:var(--primary);max-width:550px;margin-inline:auto;line-height:1.2;transform:rotate(-1.5deg)}.nav{display:flex;justify-content:center;background-color:#fff;position:sticky;top:0;z-index:10;border-bottom:3px dashed var(--border-color);gap:4px;padding:0 16px;box-shadow:0 2px 8px #8b3fbd0d}.nav button{font-family:var(--font-body);font-size:17px;padding:12px 28px;border:none;background:none;cursor:pointer;color:var(--link-color);border-bottom:3px solid transparent;transition:all .2s;position:relative;display:flex;align-items:center;gap:8px}.nav button:hover{color:var(--text-title)}.nav button:hover .nav-cat{transform:scale(1.15) rotate(-5deg)}.nav button.active{color:var(--primary);border-bottom-color:var(--primary)}.nav-cat{width:32px;height:32px;object-fit:contain;transition:transform .2s}.nav button.active .nav-cat{transform:scale(1.1)}.nav-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;color:var(--accent-purple);transition:transform .2s}.nav button:hover .nav-icon,.nav button.active .nav-icon{transform:scale(1.1);color:var(--primary)}.content{max-width:1200px;margin:0 auto;padding:48px 24px 100px}.loading{text-align:center;padding:60px 0;color:var(--link-color);font-size:17px}.empty-state{text-align:center;padding:80px 24px;color:var(--link-color);font-size:18px}.sign-in-prompt{text-align:center;padding:40px 24px 60px}.sign-in-divider{width:60px;height:3px;margin:0 auto 40px;background:linear-gradient(90deg,var(--primary),var(--accent-purple),var(--accent-teal));border-radius:2px}.sign-in-prompt p{font-family:var(--font-display);font-size:32px;color:var(--text-title);margin-bottom:12px}.sign-in-sub{font-family:var(--font-body)!important;font-size:17px!important;color:var(--text-body)!important;margin-bottom:36px!important;max-width:400px;margin-inline:auto}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.toolbar-count{font-size:16px;color:var(--link-color)}.toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sort-select{font-family:var(--font-body);font-size:15px;padding:8px 14px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--fg-color);cursor:pointer;transition:border-color .2s}.sort-select:hover{border-color:var(--accent-teal)}.sort-select:focus{outline:none;border-color:var(--primary)}.btn-active{border-color:var(--accent-teal)!important;color:var(--accent-teal)!important}.btn-filter-on{border-color:var(--primary)!important;color:var(--primary)!important}.filter-bar{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap;padding:20px 24px;margin-bottom:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #8b3fbd0d}.filter-field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:140px}.filter-field label{font-size:13px;color:var(--link-color)}.filter-field input{padding:9px 12px;border:2px solid var(--border-color);border-radius:8px;font-family:var(--font-body);font-size:15px;color:var(--fg-color);background:var(--bg-color);transition:border-color .2s}.filter-field input:focus{outline:none;border-color:var(--primary)}.filter-clear{align-self:flex-end;white-space:nowrap}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 14px}.tag-list-lightbox{justify-content:center}.tag-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--tertiary-bg-color);color:var(--accent-purple);font-size:14px;line-height:1;border:1px solid var(--border-color)}.tag-chip-link{cursor:pointer;transition:all .15s;font-family:var(--font-body)}.tag-chip-link:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}.tag-filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 16px;margin-bottom:20px;border-radius:12px;background:var(--secondary-bg-color);border:1px solid var(--border-color)}.tag-filter-chip{display:inline-flex;align-items:center;padding:6px 14px;border-radius:999px;background:var(--bg-color);color:var(--accent-purple);font-family:var(--font-body);font-size:14px;line-height:1;border:1.5px solid var(--border-color);cursor:pointer;transition:all .15s;white-space:nowrap}.tag-filter-chip:hover{border-color:var(--primary);color:var(--primary)}.tag-filter-active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px var(--primary-glow)}.tag-filter-active:hover{background:var(--primary-hover)}.tag-filter-clear{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#e91e8c1a;color:var(--primary);border:none;font-size:18px;line-height:1;cursor:pointer;transition:all .15s}.tag-filter-clear:hover{background:var(--primary);color:#fff}.tag-chip-removable{cursor:pointer;background:#e91e8c14;color:var(--primary);border:1px solid rgba(233,30,140,.16)}.tag-view-header{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--accent-purple);text-align:center;margin:16px 0 28px;letter-spacing:-.5px}.tag-section{margin-bottom:40px}.tag-section-title{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--fg-color);margin-bottom:16px;padding-bottom:8px;border-bottom:3px dashed var(--border-color)}.tag-input-wrap{display:flex;flex-direction:column;gap:8px}.tag-input{display:flex;flex-wrap:wrap;gap:8px;padding:10px 12px;border:2px solid var(--border-color);border-radius:10px;background:var(--bg-color)}.tag-input input{min-width:180px;flex:1;border:none;background:transparent;font-family:var(--font-body);font-size:16px;color:var(--fg-color)}.tag-input input:focus{outline:none}.tag-input-help{font-size:13px;color:var(--link-color)}.lightbox-edit-form .tag-input{background:#ffffff14;border-color:#ffffff38}.lightbox-edit-form .tag-input input{color:#fff}.lightbox-edit-form .tag-chip{background:#ffffff1f;color:#fff;border-color:#fff3}.btn{font-family:var(--font-body);font-size:16px;padding:12px 28px;border-radius:50px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .2s;border:2px solid transparent}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 3px 12px var(--primary-glow)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 5px 20px var(--primary-glow)}.btn-outline{background:var(--bg-card);color:var(--fg-color);border:2px solid var(--border-color)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.lightbox .btn-outline,.lightbox-edit-actions .btn-outline{background:#ffffff1f;color:#ffffffd9;border-color:#ffffff4d}.lightbox .btn-outline:hover,.lightbox-edit-actions .btn-outline:hover{background:#fff3;color:#fff;border-color:#ffffff80}.btn-sm{padding:8px 18px;font-size:14px}.photo-group{margin-bottom:48px}.photo-group:last-child{margin-bottom:0}.photo-group-header{font-family:var(--font-display);font-size:30px;font-weight:600;color:var(--accent-purple);margin-bottom:18px;padding-bottom:8px;border-bottom:3px dashed var(--border-color)}.photo-group-header--muted{color:var(--link-color)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:32px}.photo-card{position:relative;cursor:pointer;background:#fff;padding:10px 10px 40px;border-radius:4px;transition:transform .3s ease,box-shadow .3s ease}.photo-card:nth-child(5n+1){transform:rotate(-2deg);box-shadow:4px 4px 16px #e91e8c1a,0 1px 4px #00000014}.photo-card:nth-child(5n+2){transform:rotate(1.5deg);box-shadow:4px 4px 16px #1aad6e1a,0 1px 4px #00000014}.photo-card:nth-child(5n+3){transform:rotate(-.8deg);box-shadow:4px 4px 16px #8b3fbd1a,0 1px 4px #00000014}.photo-card:nth-child(5n+4){transform:rotate(1.8deg);box-shadow:4px 4px 16px #f070301a,0 1px 4px #00000014}.photo-card:nth-child(5n+5){transform:rotate(-1.2deg);box-shadow:4px 4px 16px #d4a0171a,0 1px 4px #00000014}.photo-card img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;border-radius:2px}.photo-card:hover{transform:rotate(0) translateY(-8px) scale(1.03)!important;box-shadow:0 12px 32px #e91e8c1f,0 4px 12px #0000001a!important;z-index:2}.photo-overlay{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;height:40px;display:flex;align-items:center;color:#6b4a68;font-family:var(--font-display);font-weight:600;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:40px;cursor:pointer;background:#3d1f3af5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto;-webkit-overflow-scrolling:touch}.lightbox img{max-width:92%;max-height:78vh;object-fit:contain;border-radius:6px;border:3px solid rgba(255,255,255,.15);cursor:default;box-shadow:0 8px 40px #0006}.lightbox-close{position:absolute;top:20px;right:28px;color:#fff9;background:none;border:none;cursor:pointer;font-size:16px;font-family:var(--font-body);transition:color .2s;z-index:2}.lightbox-close:hover{color:#fff}.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;font-size:28px;cursor:pointer;transition:all .2s;z-index:2;border-radius:50%}.lightbox-arrow:hover{background:var(--primary);border-color:var(--primary)}.lightbox-prev{left:16px}.lightbox-next{right:16px}.lightbox-info{text-align:center;margin-top:20px;cursor:default;min-width:280px}.lightbox-caption{color:#fff;font-family:var(--font-display);font-size:26px}.lightbox-meta{font-size:14px;margin-top:4px;color:#fff9}.lightbox-counter{font-size:13px;margin-top:10px;color:#ffffff59}.lightbox-actions{display:flex;gap:10px;justify-content:center;margin-top:12px}.lightbox-edit-btn,.lightbox-delete-btn{background:none;cursor:pointer;font-size:14px;font-family:var(--font-body);padding:6px 16px;border-radius:20px;transition:all .2s}.lightbox-edit-btn{border:1px solid rgba(255,255,255,.25);color:#ffffffb3}.lightbox-edit-btn:hover{border-color:#fff;color:#fff;background:#ffffff14}.lightbox-delete-btn{border:1px solid rgba(232,86,112,.4);color:var(--accent-coral)}.lightbox-delete-btn:hover{border-color:var(--accent-coral);background:#e8567026}.lightbox-edit-form{display:flex;flex-direction:column;gap:10px;max-width:380px;margin:0 auto}.lightbox-edit-input{padding:10px 14px;border:2px solid rgba(255,255,255,.2);border-radius:8px;font-family:var(--font-body);font-size:16px;color:#fff;background:#ffffff1a}.lightbox-edit-input:focus{outline:none;border-color:var(--primary)}.lightbox-edit-actions{display:flex;gap:10px;justify-content:center;margin-top:4px}.upload-zone{border:3px dashed var(--border-color);padding:44px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-warm);margin-bottom:24px;border-radius:12px;word-break:break-word}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:var(--tertiary-bg-color)}.upload-zone-text{color:var(--text-title);font-family:var(--font-display);margin-top:8px;font-size:22px}.upload-zone-hint{font-size:14px;color:var(--link-color);margin-top:6px}.exif-status{text-align:center;padding:8px;font-size:14px;color:var(--accent-purple);font-style:italic}.exif-info{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;padding:10px 16px;margin-bottom:16px;background:var(--secondary-bg-color);border-radius:10px;border:1px solid var(--border-color);font-size:15px;color:var(--fg-color)}.exif-file-list{padding:12px 16px;margin-bottom:16px;background:var(--secondary-bg-color);border-radius:10px;border:1px solid var(--border-color)}.exif-file-list-title{font-size:14px;font-weight:600;color:var(--accent-purple);margin-bottom:8px}.exif-file-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:4px 0;font-size:14px;color:var(--fg-color)}.exif-file-row+.exif-file-row{border-top:1px solid var(--border-color);padding-top:6px;margin-top:2px}.exif-file-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px;min-width:0;flex-shrink:1}.exif-file-row--muted{color:var(--link-color);font-style:italic}.duplicate-warn{padding:12px 16px;margin-bottom:16px;background:#fef3e2;border-radius:10px;border:1.5px solid #f0c060}.duplicate-warn-title{font-size:15px;font-weight:600;color:#9a6400;margin-bottom:8px}.duplicate-warn-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:5px 0;font-size:14px;color:#7a5000}.duplicate-warn-row+.duplicate-warn-row{border-top:1px solid #f0d89c;padding-top:7px;margin-top:2px}.duplicate-remove-btn{margin-left:auto;background:none;border:1px solid #d4a030;color:#9a6400;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:all .15s;flex-shrink:0}.duplicate-remove-btn:hover{background:#e8a020;color:#fff;border-color:#e8a020}.upload-progress{margin-bottom:8px}.upload-progress-bar{height:8px;background:var(--tertiary-bg-color);border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent-purple));border-radius:4px;transition:width .3s ease}.upload-progress-text{font-size:14px;color:var(--text-body);margin-top:6px;text-align:center}.story-card{margin-bottom:32px;background:var(--bg-card);position:relative;border-radius:0 12px 12px 0;border:1px solid var(--border-color);border-left:none;box-shadow:0 2px 8px #8b3fbd0d;transition:transform .2s,box-shadow .2s;overflow:hidden}.story-card:hover{transform:translate(4px);box-shadow:0 4px 16px #e91e8c14}.story-card:nth-child(4n+1){border-left:5px solid var(--primary)}.story-card:nth-child(4n+2){border-left:5px solid var(--accent-teal)}.story-card:nth-child(4n+3){border-left:5px solid var(--accent-orange)}.story-card:nth-child(4n+4){border-left:5px solid var(--accent-purple)}.story-cover{width:100%;aspect-ratio:5 / 2;overflow:hidden;background:var(--tertiary-bg-color)}.story-cover-img{display:block;width:100%;height:100%;object-fit:cover}.story-card-body{padding:28px 32px 32px 36px}.story-card:not(.story-card--has-cover) .story-card-body{padding-top:32px}.story-image-frame{width:100%;aspect-ratio:5 / 2;margin-bottom:16px;border-radius:8px;overflow:hidden;background:var(--tertiary-bg-color)}.story-image{display:block;width:100%;height:100%;object-fit:cover;object-position:center}.story-album{margin:24px 0 20px;padding-top:20px;border-top:2px dashed var(--border-color)}.story-album-header{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}.story-album-label{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--accent-purple)}.story-album-count{font-size:14px;color:var(--link-color)}.story-album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}.story-album-thumb{position:relative;cursor:pointer;background:#fff;padding:6px 6px 26px;border-radius:3px;box-shadow:2px 2px 10px #8b3fbd14,0 1px 3px #0000000f;transition:transform .25s ease,box-shadow .25s ease}.story-album-thumb:nth-child(odd){transform:rotate(-1.5deg)}.story-album-thumb:nth-child(2n){transform:rotate(1.2deg)}.story-album-thumb:hover{transform:rotate(0) translateY(-4px) scale(1.04)!important;box-shadow:0 8px 24px #e91e8c1f;z-index:2}.story-album-thumb img{width:100%;aspect-ratio:1;object-fit:cover;display:block;border-radius:2px}.form-gallery-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;margin-bottom:16px}.form-gallery-thumb{position:relative;border-radius:6px;overflow:hidden;background:var(--tertiary-bg-color);aspect-ratio:1}.form-gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.form-gallery-thumb-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#e85670d9;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;box-shadow:0 1px 4px #0003}.form-gallery-thumb-remove:hover{background:var(--accent-coral);transform:scale(1.15)}.story-title{font-family:var(--font-display);font-size:clamp(32px,5vw,48px);font-weight:600;color:var(--text-title);margin-bottom:16px;line-height:1.1}.story-body{font-family:var(--font-body);font-size:18px;line-height:1.7;color:var(--text-body);white-space:pre-wrap;margin-bottom:20px}.story-meta{font-size:14px;color:var(--link-color);display:flex;align-items:center;gap:16px;padding-top:16px;border-top:1px dashed var(--border-color)}.story-edit,.story-delete{background:none;border:none;color:var(--accent-coral);cursor:pointer;font-size:14px;font-family:var(--font-body);transition:opacity .2s}.story-edit{color:var(--accent-purple)}.story-edit:hover,.story-delete:hover{opacity:.7}.timeline{position:relative;max-width:800px;margin:0 auto}.timeline:before{content:"";position:absolute;left:139px;top:8px;bottom:8px;width:2px;background:repeating-linear-gradient(to bottom,var(--border-color) 0px,var(--border-color) 6px,transparent 6px,transparent 14px)}.tl-item{position:relative;margin-bottom:32px;display:grid;grid-template-columns:120px 1fr;gap:40px;align-items:start}.tl-item:before{content:"";position:absolute;left:132px;top:14px;width:16px;height:16px;border-radius:50%;z-index:1;border:3px solid var(--bg-color)}.tl-item:nth-child(4n+1):before{background:var(--primary);box-shadow:0 0 6px #e91e8c40}.tl-item:nth-child(4n+2):before{background:var(--accent-teal);box-shadow:0 0 6px #1aad6e40}.tl-item:nth-child(4n+3):before{background:var(--accent-orange);box-shadow:0 0 6px #f0703040}.tl-item:nth-child(4n+4):before{background:var(--accent-purple);box-shadow:0 0 6px #8b3fbd40}.tl-year{font-family:var(--font-display);font-size:44px;font-weight:700;text-align:right}.tl-item:nth-child(4n+1) .tl-year{color:var(--primary)}.tl-item:nth-child(4n+2) .tl-year{color:var(--accent-teal)}.tl-item:nth-child(4n+3) .tl-year{color:var(--accent-orange)}.tl-item:nth-child(4n+4) .tl-year{color:var(--accent-purple)}.tl-content{background:var(--bg-card);padding:18px 22px;border-radius:10px;border:1px solid var(--border-color);box-shadow:0 2px 8px #8b3fbd0d}.tl-item:nth-child(4n+1) .tl-content{border-left:4px solid var(--primary)}.tl-item:nth-child(4n+2) .tl-content{border-left:4px solid var(--accent-teal)}.tl-item:nth-child(4n+3) .tl-content{border-left:4px solid var(--accent-orange)}.tl-item:nth-child(4n+4) .tl-content{border-left:4px solid var(--accent-purple)}.tl-image-frame{width:100%;aspect-ratio:5 / 2;margin-bottom:10px;border-radius:6px;overflow:hidden;background:var(--tertiary-bg-color)}.tl-image{display:block;width:100%;height:100%;object-fit:cover;object-position:center}.tl-title{font-family:var(--font-display);font-size:28px;color:var(--text-title);margin-bottom:6px;font-weight:600}.tl-desc{font-size:17px;color:var(--text-body);line-height:1.5}.tl-meta{display:flex;align-items:center;gap:12px;margin-top:10px;padding-top:8px;border-top:1px dashed var(--border-color)}.tl-author{font-size:13px;color:var(--link-color)}.tl-edit,.tl-delete{background:none;border:none;color:var(--accent-coral);cursor:pointer;font-size:13px;font-family:var(--font-body);transition:opacity .2s}.tl-edit{color:var(--accent-purple)}.tl-edit:hover,.tl-delete:hover{opacity:.7}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#3d1f3ad9;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow-y:auto;-webkit-overflow-scrolling:touch}.modal{background:var(--bg-card);padding:40px;max-width:580px;width:100%;max-height:90vh;overflow-y:auto;position:relative;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 12px 48px #8b3fbd1f}.modal h3{font-family:var(--font-display);font-size:42px;font-weight:700;color:var(--text-title);margin-bottom:24px;padding-right:24px}.modal-close{position:absolute;top:18px;right:18px;background:none;border:none;cursor:pointer;color:var(--link-color);transition:color .2s}.modal-close:hover{color:var(--primary)}.modal-actions{display:flex;gap:14px;justify-content:flex-end;margin-top:32px;padding-top:18px;border-top:1px dashed var(--border-color)}.form-section-divider{border-top:2px dashed var(--border-color);margin:24px 0 16px}.form-section-title{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--accent-purple);margin-bottom:4px}.form-section-hint{font-size:14px;color:var(--link-color);margin-bottom:14px;line-height:1.4}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:15px;color:var(--text-body);margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px 14px;border:2px solid var(--border-color);border-radius:8px;font-family:var(--font-body);font-size:17px;color:var(--fg-color);background:var(--bg-color);resize:vertical;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.image-pick{display:flex;align-items:center;gap:10px;padding:12px 14px;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;transition:border-color .2s;background:var(--bg-color)}.image-pick:hover{border-color:var(--primary)}.image-pick-placeholder{display:flex;align-items:center;gap:8px;color:var(--link-color);font-size:15px}.image-pick-name{color:var(--accent-teal);font-size:15px}.focal-picker-wrap{display:grid;gap:14px}.focal-picker{margin-top:12px;display:grid;gap:10px}.focal-picker-image-wrap{position:relative;display:inline-block;align-self:center;max-width:100%;border-radius:12px;overflow:hidden;border:2px solid var(--border-color);cursor:move;background:var(--bg-warm)}.focal-picker img{display:block;max-width:100%;max-height:260px;width:auto;height:auto;background:var(--bg-card)}.focal-rect{position:absolute;transform:translate(-50%,-50%);border:2px solid #fff;box-shadow:0 0 0 9999px #3d1f3a47,0 0 0 2px var(--primary),0 2px 12px #0000002e;border-radius:12px;pointer-events:none}.focal-hint{padding:8px 10px;border-radius:12px;background:#ffffffd1;color:var(--text-title);font-size:14px;text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.focal-preview-label{font-size:14px;color:var(--link-color)}.focal-preview-card{padding:0;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);box-shadow:0 2px 8px #8b3fbd0d;overflow:hidden}.crop-preview-media{display:block;width:100%;height:100%;object-fit:cover}.activity-list{display:grid;gap:18px;max-width:820px;margin:0 auto}.activity-card{padding:22px 24px;border:1px solid var(--border-color);border-left:5px solid var(--accent-purple);border-radius:0 12px 12px 0;background:var(--bg-card);box-shadow:0 2px 8px #8b3fbd0d}.activity-card-link{cursor:pointer;transition:all .2s}.activity-card-link:hover{border-left-color:var(--primary);box-shadow:0 4px 16px #e91e8c1a;transform:translate(4px)}.activity-line{color:var(--text-body);font-size:18px;margin-bottom:8px}.activity-title{color:var(--text-title);font-family:var(--font-display);font-size:34px;line-height:1.05}.activity-subtitle{margin-top:8px;color:var(--text-body);font-size:16px;white-space:pre-wrap}.activity-meta{margin-top:12px;color:var(--link-color);font-size:14px;display:flex;align-items:center;justify-content:space-between}.activity-goto{color:var(--primary);font-weight:600;font-size:14px}.footer{text-align:center;padding:48px 24px;border-top:3px dashed var(--border-color);background-color:#f9ecf5;background-image:radial-gradient(ellipse at 50% 0%,#e91e8c08,#fdf2f800 50%),linear-gradient(180deg,#fdf2f8,#f9ecf5)}.footer-text{font-family:var(--font-display);font-size:30px;color:var(--primary);margin-bottom:8px}.footer-sub{font-size:15px;color:var(--link-color)}@media(max-width:768px){.hero{padding:28px 16px 32px}.hero-cats{max-width:280px}.hero-epitaph{transform:rotate(-1deg)}.nav{gap:0;padding:0;justify-content:stretch}.nav button{flex:1;padding:8px 4px 6px;font-size:12px;white-space:nowrap;flex-direction:column;gap:2px;justify-content:center;text-align:center}.nav-cat,.nav-icon{width:26px;height:26px}.content{padding:24px 14px 80px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.photo-card{padding:5px 5px 24px}.photo-card:nth-child(5n+1),.photo-card:nth-child(5n+2),.photo-card:nth-child(5n+3),.photo-card:nth-child(5n+4),.photo-card:nth-child(5n+5){transform:rotate(0)}.photo-overlay{height:24px;font-size:11px;padding:3px 6px}.photo-group{margin-bottom:32px}.photo-group-header{font-size:22px;margin-bottom:12px}.story-card{margin-bottom:24px}.story-card-body{padding:18px 16px 22px 20px}.story-card:hover{transform:none}.story-title{margin-bottom:10px}.story-album-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.story-album-thumb{padding:4px 4px 18px}.story-album-thumb:nth-child(odd),.story-album-thumb:nth-child(2n){transform:rotate(0)}.story-album-label{font-size:22px}.timeline:before{left:19px}.tl-item{grid-template-columns:1fr;gap:4px;padding-left:40px;margin-bottom:24px}.tl-item:before{left:11px;top:6px;width:14px;height:14px}.tl-year{text-align:left;font-size:30px}.tl-content{padding:14px 16px}.tl-title{font-size:22px}.tl-desc{font-size:15px}.tl-meta{flex-wrap:wrap;gap:8px}.lightbox{padding:12px}.lightbox img{max-width:100%;max-height:65vh;border-width:2px}.lightbox-arrow{width:36px;height:36px;font-size:20px}.lightbox-prev{left:6px}.lightbox-next{right:6px}.lightbox-close{top:10px;right:12px}.lightbox-caption{font-size:20px}.lightbox-info{min-width:auto;max-width:90vw}.lightbox-edit-form{max-width:100%}.modal-backdrop{padding:12px}.modal{padding:24px 18px;max-height:92vh}.modal h3{font-size:34px;margin-bottom:18px}.modal-actions{margin-top:24px}.activity-title{font-size:26px}.activity-card{padding:16px 18px}.activity-card-link:hover{transform:none}.filter-bar{padding:14px;gap:10px}.tag-filter-bar{padding:8px 12px;gap:6px}.tag-filter-chip{padding:5px 10px;font-size:13px}.sign-in-prompt{padding:24px 16px 40px}.sign-in-prompt p{font-size:24px}.google-btn.large{padding:14px 32px;font-size:17px}.footer{padding:36px 16px}.footer-text{font-size:24px}.tag-view-header{font-size:28px}.form-section-title{font-size:24px}.auth-bar{padding:8px 14px}.user-info{font-size:13px;gap:8px}}@media(max-width:480px){.toolbar{flex-direction:column;align-items:stretch;gap:10px}.toolbar-count{text-align:center}.toolbar-actions{width:100%;justify-content:center;flex-wrap:wrap}.photo-grid{grid-template-columns:repeat(2,1fr);gap:10px}.photo-card{padding:4px 4px 20px}.photo-overlay{height:20px;font-size:10px}.nav button{padding:6px 2px 5px;font-size:11px}.nav-cat,.nav-icon{width:22px;height:22px}.hero-cats{max-width:220px}.story-cover{aspect-ratio:3 / 2}.story-card-body{padding:14px 12px 18px 16px}.story-meta{flex-wrap:wrap;gap:8px;font-size:13px}.btn{padding:10px 20px;font-size:14px}.btn-sm{padding:7px 14px;font-size:13px}.lightbox img{max-height:60vh}.lightbox-arrow{width:32px;height:32px;font-size:18px}.lightbox-caption{font-size:18px}.lightbox-meta{font-size:12px}.tl-year{font-size:26px}.tl-title{font-size:20px}.sort-select{font-size:13px;padding:6px 10px}}
