@font-face{font-family:Ogg;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/ogg-regular.woff2)format("woff2")}@font-face{font-family:Ogg;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/ogg-bold.woff2)format("woff2")}:root{--color-bg:#f0ebd8;--color-surface:#e8e4cf;--color-surface-mid:#ded8c2;--color-border:#e8e6d1;--color-border-dark:#e0dac2;--color-text-primary:#1e2a2a;--color-text-secondary:#5c6464;--color-accent:#527575;--color-accent-text:#fdfcf0;--color-waveform:#527575;--color-warn:#fff8dc;--font-display:"Ogg", Georgia, "Times New Roman", serif;--font-body:"Wix Madefor Text", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-size-title:56px;--font-size-heading:30px;--font-size-body:20px;--font-size-caption:15px;--line-height-body:1.7;--spacing-page:60px;--max-width:1560px;--radius-card:8px;--watermark-opacity:.06}[data-theme=dark]{--color-bg:#1a1f1f;--color-surface:#242b2b;--color-surface-mid:#2d3535;--color-border:#3a4242;--color-border-dark:#4a5454;--color-text-primary:#e8ece8;--color-text-secondary:#9aacac;--color-accent:#7aabab;--color-accent-text:#1a1f1f;--color-waveform:#7aabab;--color-warn:#2d2a1a;--watermark-opacity:.03}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-body);line-height:var(--line-height-body);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:var(--font-body);cursor:pointer}.page-container{max-width:var(--max-width);padding:0 var(--spacing-page) 60px;z-index:1;margin:0 auto;position:relative}.page-title{font-family:var(--font-display);font-size:var(--font-size-title);color:var(--color-accent);text-align:center;text-transform:capitalize;letter-spacing:-.01em;margin:40px 0 8px;font-weight:400}.nav-logo{text-align:center;padding:16px 0 12px}.nav-bar{border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);margin-bottom:40px;margin-left:calc(-1 * var(--spacing-page));margin-right:calc(-1 * var(--spacing-page));padding:12px 0;padding-left:var(--spacing-page);padding-right:var(--spacing-page);justify-content:space-between;align-items:center;display:flex}.nav-bar a{font-family:var(--font-body);color:var(--color-text-secondary);white-space:nowrap;padding-bottom:4px;font-size:16px;font-weight:500;transition:color .2s}.nav-bar a:hover{color:var(--color-accent)}.nav-bar a.active{color:var(--color-accent);border-bottom:2px solid var(--color-accent)}.nav-logout{border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0;border-radius:4px;padding:4px 12px;font-size:14px;transition:color .2s,border-color .2s}.nav-logout:hover{color:var(--color-accent);border-color:var(--color-accent)}.watermark{pointer-events:none;z-index:0;opacity:.04;object-fit:contain;width:700px;height:auto;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.btn-accent{background:var(--color-accent);color:var(--color-accent-text);font-family:var(--font-display);font-size:var(--font-size-body);border-radius:var(--radius-card);letter-spacing:.02em;border:none;padding:14px 36px;font-weight:600;transition:opacity .2s}.btn-accent:hover{opacity:.85}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card)}.timeline-section{margin-bottom:40px}.timeline-decade{font-size:var(--font-size-caption);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);margin-bottom:16px;padding-bottom:6px}.timeline-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.timeline-grid.three-col{grid-template-columns:repeat(3,1fr)}.thumb{aspect-ratio:4/3;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);justify-content:center;align-items:center;width:100%;display:flex}.thumb-caption{font-size:var(--font-size-caption);color:var(--color-text-secondary);text-align:center;margin-top:6px}.privacy-toggle{border:1px solid var(--color-border);border-radius:20px;gap:0;margin-bottom:24px;display:inline-flex;overflow:hidden}.privacy-toggle button{color:var(--color-text-secondary);border:none;border-right:1px solid var(--color-border);background:0 0;padding:6px 14px;font-size:13px}.privacy-toggle button:last-child{border-right:none}.privacy-toggle button.active{background:var(--color-accent);color:var(--color-accent-text)}.waveform{flex:1;align-items:flex-end;gap:2px;height:48px;display:flex}.waveform-bar{background:var(--color-waveform);border-radius:1px;width:3px}.audio-player{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);align-items:center;gap:12px;padding:12px 16px;display:flex}.play-btn{background:var(--color-accent);width:36px;height:36px;color:var(--color-accent-text);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.audio-time{font-size:var(--font-size-caption);color:var(--color-text-secondary);white-space:nowrap}.video-thumb{position:relative}.video-thumb .play-overlay{color:var(--color-text-secondary);font-size:28px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.carousel{aspect-ratio:16/9;border-radius:var(--radius-card);width:100%;margin-bottom:20px;position:relative;overflow:hidden}.carousel-slide{opacity:0;width:100%;height:100%;transition:opacity .6s;position:absolute;top:0;left:0}.carousel-slide.active{opacity:1}.carousel-dots{justify-content:center;gap:8px;display:flex}.carousel-dot{border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:50%;width:10px;height:10px}.carousel-dot.active{background:var(--color-accent);border-color:var(--color-accent)}.family-tree-container{justify-content:center;width:100%;padding:40px 0;display:flex}.spine{flex-direction:column;align-items:center;gap:0;display:flex;position:relative}.spine:before{content:"";background:var(--color-border);z-index:0;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.spine-row{align-items:center;width:560px;padding:28px 0;display:flex;position:relative}.spine-row-center{justify-content:center;gap:0}.spine-row:before{content:"";background:var(--color-border);z-index:0;height:1.5px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.spine-dot{z-index:2;background:var(--color-accent);border:2px solid var(--color-bg);width:10px;min-width:10px;height:10px;box-shadow:0 0 0 1.5px var(--color-accent);border-radius:50%;position:relative}.spine-branch{z-index:1;flex:1;gap:10px;display:flex;position:relative}.spine-left{justify-content:flex-end;padding-right:20px}.spine-right{justify-content:flex-start;padding-left:20px}.tree-node{background:var(--color-surface);border:1px solid var(--color-border);min-width:120px;height:40px;font-family:var(--font-body);color:var(--color-text-primary);white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;padding:0 16px;font-size:13px;display:flex}.tree-node-self{border-color:var(--color-accent);z-index:2;background:var(--color-bg);border-width:1.5px;min-width:130px;font-weight:700;position:relative}.theme-toggle{z-index:100;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:6px;padding:0;display:flex;position:fixed;top:16px;right:20px}.theme-toggle-track{background:var(--color-surface-mid);border:1px solid var(--color-border);border-radius:42px;align-items:center;width:156px;height:84px;padding:0 12px;transition:background .3s;display:flex;position:relative}.theme-toggle-thumb{background:var(--color-accent);border-radius:50%;width:66px;height:66px;transition:transform .3s;position:absolute;left:9px}[data-theme=dark] .theme-toggle-thumb{transform:translate(72px)}.theme-toggle-icon{z-index:1;text-align:center;flex:1;font-size:36px;line-height:1;transition:opacity .3s;position:relative}.theme-toggle-label{font-family:var(--font-body);color:var(--color-text-secondary);white-space:nowrap;font-size:13px}.theme-toggle-sun{color:var(--color-accent);opacity:1}.theme-toggle-moon{color:var(--color-text-secondary);opacity:.5}[data-theme=dark] .theme-toggle-sun{opacity:.5}[data-theme=dark] .theme-toggle-moon{color:var(--color-accent);opacity:1}.auth-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding-top:0;display:flex}.auth-subtitle{font-size:var(--font-size-body);color:var(--color-text-secondary);text-align:center;margin-bottom:32px}.auth-form{flex-direction:column;gap:20px;width:100%;max-width:400px;display:flex}.auth-label{font-size:var(--font-size-caption);color:var(--color-text-secondary);flex-direction:column;gap:6px;font-weight:500;display:flex}.auth-input{font-size:16px;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-card);outline:none;padding:12px 14px;transition:border-color .2s}.auth-input:focus{border-color:var(--color-accent)}.auth-btn{width:100%;margin-top:4px}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-error{color:#b91c1c;border-radius:var(--radius-card);font-size:var(--font-size-caption);text-align:center;background:#fef2f2;border:1px solid #fecaca;padding:10px 14px}[data-theme=dark] .auth-error{color:#fca5a5;background:#3b1c1c;border-color:#5c2020}.auth-switch{font-size:var(--font-size-caption);color:var(--color-text-secondary);text-align:center}.auth-switch a{color:var(--color-accent);text-decoration:underline}.turnstile-container{justify-content:center;display:flex}.uploader{margin-bottom:32px}.drop-zone{border:2px dashed var(--color-border-dark);border-radius:var(--radius-card);text-align:center;cursor:pointer;background:var(--color-surface);padding:40px 24px;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone.dragging{border-color:var(--color-accent);background:var(--color-surface-mid)}.drop-zone-prompt{color:var(--color-text-secondary);font-size:var(--font-size-caption);flex-direction:column;align-items:center;gap:8px;display:flex}.drop-zone-selected{justify-content:center;align-items:center;gap:8px;display:flex}.drop-zone-filename{color:var(--color-text-primary);font-weight:500}.drop-zone-size{color:var(--color-text-secondary);font-size:var(--font-size-caption)}.uploader-controls{align-items:center;gap:12px;margin-top:12px;display:flex}.uploader-title{border:1px solid var(--color-border);border-radius:var(--radius-card);font-family:var(--font-body);font-size:var(--font-size-caption);background:var(--color-surface);color:var(--color-text-primary);flex:1;padding:10px 14px}.uploader-title:focus{border-color:var(--color-accent);outline:none}.progress-bar{background:var(--color-surface-mid);border-radius:2px;height:4px;margin-top:12px;overflow:hidden}.progress-fill{background:var(--color-accent);border-radius:2px;height:100%;transition:width .3s}.uploader-error{color:#c44;font-size:var(--font-size-caption);margin-top:8px}.uploader-narration{border:1px solid var(--color-border);border-radius:var(--radius-card);width:100%;font-family:var(--font-body);font-size:var(--font-size-caption);background:var(--color-surface);color:var(--color-text-primary);resize:vertical;padding:10px 14px}.uploader-narration:focus{border-color:var(--color-accent);outline:none}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;display:grid}.photo-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);transition:box-shadow .2s;overflow:hidden}.photo-card:hover{box-shadow:0 4px 16px #00000014}.photo-preview{aspect-ratio:4/3;background:var(--color-surface-mid);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.photo-preview img{object-fit:cover;width:100%;height:100%}.photo-placeholder{color:var(--color-text-secondary);opacity:.3;font-size:32px}.photo-info{padding:12px 14px}.photo-title{font-weight:500;font-size:var(--font-size-caption);color:var(--color-text-primary);margin-bottom:4px}.photo-narration{color:var(--color-text-secondary);margin-bottom:4px;font-size:13px;line-height:1.5}.photo-date{color:var(--color-text-secondary);opacity:.6;font-size:12px}.folder-card{cursor:pointer}.folder-badge{color:#fff;background:#0000008c;border-radius:10px;padding:2px 8px;font-size:12px;position:absolute;bottom:8px;right:8px}.folder-header{align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.folder-name{font-family:var(--font-display);font-size:var(--font-size-heading);color:var(--color-accent);margin:0;font-weight:400}.folder-description{font-size:var(--font-size-caption);color:var(--color-text-secondary);margin:4px 0 0;line-height:1.5}.btn-back{border:1px solid var(--color-border);border-radius:var(--radius-card);color:var(--color-text-secondary);white-space:nowrap;background:0 0;margin-top:4px;padding:6px 14px;font-size:14px;transition:color .2s,border-color .2s}.btn-back:hover{color:var(--color-accent);border-color:var(--color-accent)}.create-folder-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);flex-direction:column;gap:10px;margin-bottom:24px;padding:20px;display:flex}.create-folder-form .btn-accent{align-self:flex-end}.folder-drop-active{outline:2px solid var(--color-accent);outline-offset:-2px;background:var(--color-surface-mid)}.photo-card[draggable=true]{cursor:grab}.photo-card[draggable=true]:active{cursor:grabbing;opacity:.6}.narration-edit{margin-top:4px}.narration-edit-actions{gap:8px;margin-top:8px;display:flex}.narration-edit-actions .btn-accent{padding:6px 16px;font-size:13px}.narration-edit-actions .btn-back{padding:6px 12px;font-size:13px}.narration-add-btn{color:var(--color-accent);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;font-size:13px;transition:opacity .2s}.narration-add-btn:hover{opacity:1}.photo-narration{cursor:pointer}.photo-narration:hover{color:var(--color-accent)}
