:root{--bg: #0F1117;--bg-elevated: #13151F;--amber: #C8A96E;--amber-dim: rgba(200, 169, 110, .4);--indigo: #3D3580;--purple: #9370DB;--teal: #38B2AC;--text: #E8E0D0;--text-dim: rgba(232, 224, 208, .7);--text-muted: rgba(232, 224, 208, .4);--border: rgba(200, 169, 110, .18);--font: "Courier Prime", "Courier New", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;background:var(--bg)}body{color:var(--text);font-family:var(--font);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(ellipse at 50% 20%,#16192a 0%,var(--bg) 68%)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}#root{height:100%;display:flex;flex-direction:column}button,input,select,textarea{font-family:var(--font)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--amber-dim);border-radius:2px}@keyframes cursor-blink{0%,49%{opacity:1}50%,to{opacity:0}}.cursor{display:inline-block;width:2px;height:1em;background:var(--amber);margin-left:1px;vertical-align:text-bottom;animation:cursor-blink 1s step-end infinite}.app-loading{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem;letter-spacing:.1em}.logo{display:inline-flex;align-items:baseline;line-height:1}.logo-life{font-size:2.6rem;font-weight:400;color:var(--text);letter-spacing:-.02em}.logo-glance{font-size:2.8rem;font-weight:700;font-style:italic;color:var(--indigo);letter-spacing:-.02em}.logo-sm .logo-life{font-size:1.2rem}.logo-sm .logo-glance{font-size:1.3rem}.logo-tagline{font-size:.9rem;color:var(--text-muted);margin-top:.4rem;font-style:italic}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.4rem;border:1px solid var(--amber);background:transparent;color:var(--amber);font-family:var(--font);font-size:.95rem;cursor:pointer;transition:background .15s,color .15s;letter-spacing:.02em;line-height:1}.btn:hover{background:#c8a96e1f}.btn:disabled{opacity:.35;cursor:not-allowed}.btn:disabled:hover{background:transparent}.btn-filled{background:var(--amber);color:var(--bg)}.btn-filled:hover{background:#d4b880}.btn-filled:disabled{background:var(--amber)}.input{background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:1rem;padding:.45rem 0;width:100%;outline:none;transition:border-color .15s;caret-color:var(--amber)}.input:focus{border-bottom-color:var(--amber)}.input::placeholder{color:var(--text-muted)}.input-sm{font-size:.9rem}.field-label{font-size:.68rem;color:var(--text-muted);letter-spacing:.08em;text-transform:lowercase;display:block;margin-bottom:.25rem}.field-row{display:flex;gap:.75rem}.onboarding{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem 6rem;position:relative}.onboarding-step{width:100%;max-width:580px;display:flex;flex-direction:column;gap:2rem;animation:step-in .3s ease}@keyframes step-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.onboarding-eyebrow{font-size:.7rem;color:var(--amber);letter-spacing:.12em;text-transform:lowercase}.progress-dots{display:flex;gap:.45rem;align-items:center}.progress-dot{width:5px;height:5px;border-radius:50%;background:var(--border);transition:background .3s}.progress-dot.active{background:var(--amber)}.progress-dot.done{background:#c8a96e66}.onboarding-prompt{font-size:1.3rem;line-height:1.55;color:var(--text);min-height:5rem}.onboarding-inputs{display:flex;flex-direction:column;gap:1.2rem}.onboarding-helper{font-size:.78rem;color:var(--text-muted);font-style:italic}.onboarding-actions{display:flex;align-items:center;gap:1rem}.skip-link{position:fixed;bottom:1.25rem;right:1.5rem;background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:.72rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px;letter-spacing:.04em}.skip-link:hover{color:var(--text-dim)}.timeline-preview{position:fixed;bottom:0;left:0;right:0;height:72px;border-top:1px solid var(--border);background:#0f1117f7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden}.stat-reveal-rows{display:flex;flex-direction:column;gap:1.2rem}.stat-reveal-row{display:flex;flex-direction:column;gap:.2rem;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}.stat-reveal-row.visible{opacity:1;transform:translateY(0)}.stat-reveal-label{font-size:.68rem;color:var(--text-muted);letter-spacing:.08em}.stat-reveal-value{font-size:1.15rem;color:var(--text);line-height:1.4}.stat-reveal-value em{font-style:normal;color:var(--amber)}.timeline-view{height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative}.timeline-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:.6rem 1.1rem;border-bottom:1px solid var(--border);flex-shrink:0;z-index:10;background:var(--bg)}.header-center{display:flex;flex-direction:column;align-items:center;gap:1px}.header-right{display:flex;justify-content:flex-end;align-items:center}.zoom-tabs{display:flex;border:1px solid var(--border)}.zoom-tab{padding:.3rem .7rem;background:transparent;border:none;border-left:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.7rem;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.04em}.zoom-tab:first-child{border-left:none}.zoom-tab:hover{color:var(--text-dim);background:#c8a96e0f}.zoom-tab.active{color:var(--amber);background:#c8a96e1a}.view-tabs{display:flex;border:1px solid var(--border);border-radius:2px}.view-tab{padding:.18rem .65rem;background:transparent;border:none;border-left:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.62rem;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.03em;white-space:nowrap}.view-tab:first-child{border-left:none}.view-tab:hover{color:var(--text-dim);background:#c8a96e0f}.view-tab.active{color:var(--amber);background:#c8a96e1a}.timeline-body{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column}.timeline-svg-wrap{flex:1;width:100%;cursor:grab;touch-action:pan-y;-webkit-user-select:none;user-select:none}.timeline-svg-wrap:active{cursor:grabbing}.timeline-zoom-wrap{flex:1;display:flex;flex-direction:column;transition:transform .42s cubic-bezier(.25,.46,.45,.94);transform-origin:center center}.timeline-zoom-wrap.zooming-out{transform:perspective(800px) rotateX(-2deg) scale(.97)}.timeline-zoom-wrap.zooming-in{transform:perspective(800px) rotateX(2deg) scale(1.03)}.timeline-bottom{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.1rem;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg)}.add-milestone-btn{display:flex;align-items:center;gap:.45rem;padding:.45rem .9rem;background:transparent;border:1px solid var(--amber);color:var(--amber);font-family:var(--font);font-size:.8rem;cursor:pointer;transition:background .15s;letter-spacing:.03em}.add-milestone-btn:hover{background:#c8a96e1a}.today-btn{padding:.45rem .9rem;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.7rem;cursor:pointer;transition:color .15s,border-color .15s;letter-spacing:.04em}.today-btn:hover{color:var(--amber);border-color:var(--amber-dim)}.zoom-row{position:relative;display:flex;justify-content:center;align-items:center}.zoom-indicator{position:absolute;left:calc(100% + .55rem);top:50%;transform:translateY(-50%);font-size:.6rem;color:var(--text-muted);letter-spacing:.07em;white-space:nowrap}.custom-zoom-row{display:flex;align-items:center;gap:.25rem;color:var(--amber)}.custom-zoom-input{width:3.2rem;background:transparent;border:none;border-bottom:1px solid var(--amber-dim);color:var(--amber);font-family:var(--font);font-size:.6rem;text-align:center;outline:none;padding:0 .1rem;-moz-appearance:textfield}.custom-zoom-input::-webkit-outer-spin-button,.custom-zoom-input::-webkit-inner-spin-button{-webkit-appearance:none}.filter-chips-inline{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center;flex:1;justify-content:center}.filter-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.68rem;cursor:pointer;transition:color .15s,border-color .15s;letter-spacing:.03em}.filter-chip:hover{color:var(--text-dim);border-color:var(--amber-dim)}.filter-chip.active{color:var(--amber);border-color:var(--amber)}.filter-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.stat-panels{pointer-events:none;position:absolute;left:0;right:0;top:.75rem;display:flex;justify-content:space-between;padding:0 1rem;z-index:5}.stat-panel{pointer-events:all;font-size:.7rem;max-width:155px;line-height:1.5}.stat-panel-label{color:var(--amber);letter-spacing:.06em;margin-bottom:.3rem;font-size:.65rem;text-transform:lowercase}.stat-panel-count{color:var(--text-dim)}.stat-panel-right{text-align:right}.stat-milestone{margin-top:.5rem;line-height:1.45}.stat-milestone-right{text-align:right}.stat-milestone-title{font-size:.72rem;color:var(--text-dim)}.stat-milestone-date{font-size:.63rem;color:var(--text-muted);margin-top:.1rem}.stat-milestone-rel{font-size:.63rem;color:var(--amber);margin-top:.08rem}.stat-nav-row{display:flex;align-items:center;gap:.3rem;margin-top:.25rem}.stat-nav-row-right{justify-content:flex-end}.stat-nav-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.58rem;padding:.08rem .32rem;cursor:pointer;line-height:1.4;transition:color .15s,border-color .15s}.stat-nav-btn:hover{color:var(--amber);border-color:var(--amber-dim)}.stat-nav-pos{font-size:.56rem;color:var(--text-muted);letter-spacing:.04em}.header-actions{display:flex;align-items:center;gap:.35rem;justify-content:flex-end}.action-link{background:transparent;border:none;color:var(--text-muted);font-family:var(--font);font-size:.56rem;cursor:pointer;padding:0;letter-spacing:.05em;transition:color .15s}.action-link:hover{color:var(--amber)}.action-sep{color:#c8a96e59;font-size:.75rem;line-height:1}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:100;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center}@media (min-width: 640px){.sheet-overlay{align-items:center}}.sheet{background:var(--bg-elevated);border:1px solid var(--border);border-bottom:none;width:100%;max-width:520px;padding:1.5rem;display:flex;flex-direction:column;gap:1.2rem;max-height:88vh;overflow-y:auto;animation:sheet-up .22s ease}@media (min-width: 640px){.sheet{border-bottom:1px solid var(--border)}}@keyframes sheet-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.sheet-header{display:flex;justify-content:space-between;align-items:center}.sheet-title{font-size:.85rem;color:var(--amber);letter-spacing:.07em;text-transform:lowercase}.sheet-close{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;line-height:1;padding:.2rem}.sheet-close:hover{color:var(--text)}.sheet-field{display:flex;flex-direction:column;gap:.3rem}.date-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.75rem;align-items:end}.precision-tabs{display:flex;border:1px solid var(--border);align-self:flex-start;margin-top:.4rem}.precision-tab{padding:.22rem .65rem;background:transparent;border:none;border-left:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.68rem;cursor:pointer;transition:color .15s,background .15s;letter-spacing:.04em}.precision-tab:first-child{border-left:none}.precision-tab.active{color:var(--amber);background:#c8a96e1a}.category-grid{display:flex;gap:.5rem;flex-wrap:wrap}.category-chip{display:flex;align-items:center;gap:.4rem;padding:.3rem .65rem;border:1px solid transparent;cursor:pointer;transition:border-color .15s;font-size:.72rem;color:var(--text-muted);letter-spacing:.03em}.category-chip.selected{border-color:var(--amber);color:var(--text)}.category-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sheet-actions{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid var(--border);gap:.75rem}.sheet-actions-right{display:flex;gap:.5rem}.btn-ghost{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:.8rem;cursor:pointer;padding:.45rem;transition:color .15s;letter-spacing:.03em}.btn-ghost:hover{color:#e85d75}.detail-photo-wrap{margin:-1.2rem -1.5rem 0;overflow:hidden;border-bottom:1px solid var(--border)}.detail-photo{width:100%;max-height:260px;object-fit:cover;display:block}.photo-preview-wrap{position:relative;align-self:stretch}.photo-preview{width:100%;max-height:180px;object-fit:cover;display:block;border-radius:3px;border:1px solid var(--border)}.photo-remove{position:absolute;top:.4rem;right:.4rem;background:#0d0f16d1;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font);font-size:.65rem;padding:.18rem .45rem;border-radius:2px;cursor:pointer;letter-spacing:.03em;transition:color .15s}.photo-remove:hover{color:var(--text)}.detail-title{font-size:1.4rem;font-weight:700;line-height:1.3}.detail-meta{display:flex;flex-direction:column;gap:.2rem}.detail-date-raw{font-size:.85rem;color:var(--text-dim)}.detail-relative{font-size:.8rem;color:var(--amber)}.detail-age{font-size:.75rem;color:#c8a96e8c;font-family:Courier Prime,monospace}.detail-category{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--text-muted)}.detail-cat-dot{width:8px;height:8px;border-radius:50%}.detail-note{font-size:.88rem;color:var(--text-dim);line-height:1.65;white-space:pre-wrap;border-left:2px solid var(--border);padding-left:.75rem}.empty-state{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:.5rem}.empty-state-label{font-size:.78rem;color:var(--text-muted);line-height:1.7;letter-spacing:.03em}@keyframes milestone-appear{0%{opacity:0;transform:scale(.25)}to{opacity:1;transform:scale(1)}}@keyframes milestone-fly{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.minimap-bar{height:40px;flex-shrink:0;background:#0d0f16b3;border-top:1px solid var(--border);cursor:crosshair;user-select:none;-webkit-user-select:none}.settings-sheet{max-width:540px;width:100%}.settings-sheet .zoom-tabs{width:100%}.settings-sheet .zoom-tab{flex:1;text-align:center;padding:.55rem .5rem}.settings-section{display:flex;flex-direction:column;gap:.55rem;padding-top:.8rem;border-top:1px solid var(--border)}.settings-label{font-size:.65rem;color:var(--amber);letter-spacing:.07em}.settings-cat-list{display:flex;flex-direction:column;gap:.3rem}.settings-cat-row{display:flex;align-items:center;gap:.5rem;min-height:1.4rem}.settings-cat-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.settings-cat-name{flex:1;font-size:.7rem;color:var(--text-dim);letter-spacing:.03em}.settings-cat-inuse{font-size:.55rem;color:var(--text-muted);letter-spacing:.05em}.settings-cat-del{background:none;border:none;color:var(--text-muted);font-size:.6rem;cursor:pointer;padding:.15rem .3rem;line-height:1;transition:color .15s}.settings-cat-del:hover:not(:disabled){color:var(--amber)}.settings-cat-del:disabled{opacity:.2;cursor:default}.settings-cat-add{display:flex;flex-direction:column;gap:.4rem}.settings-cat-add-row{display:flex;gap:.4rem;align-items:center}.settings-palette{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:center}.settings-swatch{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .1s}.settings-swatch:hover{transform:scale(1.18)}.settings-swatch.selected{border-color:var(--text);transform:scale(1.18)}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer}.settings-toggle-label{font-size:.75rem;color:var(--text-dim)}.settings-toggle{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:2.2rem;height:1.2rem;border-radius:1rem;background:#e8e0d01f;border:1px solid var(--border);position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.settings-toggle:after{content:"";position:absolute;width:.85rem;height:.85rem;border-radius:50%;background:var(--text-muted);top:50%;left:.15rem;transform:translateY(-50%);transition:left .2s,background .2s}.settings-toggle:checked{background:#c8a96e40;border-color:var(--amber)}.settings-toggle:checked:after{left:calc(100% - 1rem);background:var(--amber)}.settings-you-row{display:flex;align-items:center;gap:.75rem}.settings-you-label{font-size:.72rem;color:var(--text-muted);flex-shrink:0}.settings-birthday-input{background:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-family:Courier Prime,monospace;font-size:.72rem;padding:.3rem .5rem;color-scheme:dark}.settings-backup-row{display:flex;gap:.5rem;flex-wrap:wrap}.help-sheet{max-width:420px}.help-shortcuts-table{width:100%;border-collapse:collapse}.help-shortcuts-table tr+tr td{padding-top:.45rem}.help-keys{white-space:nowrap;padding-right:1rem;vertical-align:middle}.help-kbd{display:inline-block;font-family:var(--font);font-size:.65rem;color:var(--text);background:#e8e0d012;border:1px solid rgba(232,224,208,.22);border-bottom-width:2px;border-radius:4px;padding:.15em .45em;margin-right:.25rem;line-height:1.5}.help-desc{font-size:.72rem;color:var(--text-dim);vertical-align:middle}.help-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;margin-top:.5rem;border-top:1px solid var(--border)}.help-footer-meta{font-size:.62rem;color:var(--text-muted)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh}.search-palette{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;width:480px;max-width:92vw;box-shadow:0 8px 40px #000000b3;overflow:hidden}.search-input-row{display:flex;align-items:center;gap:.55rem;padding:.8rem 1rem;border-bottom:1px solid var(--border)}.search-prompt{color:var(--amber);font-family:Courier Prime,monospace;font-size:1.15rem;line-height:1;flex-shrink:0}.search-input{background:transparent;border:none;color:var(--text);font-family:Courier Prime,monospace;font-size:.88rem;outline:none;flex:1;min-width:0}.search-input::placeholder{color:var(--text-muted)}.search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.7rem;padding:0;line-height:1;flex-shrink:0}.search-clear:hover{color:var(--text-dim)}.search-results{max-height:340px;overflow-y:auto}.search-result{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;cursor:pointer;border-left:2px solid transparent;transition:background .1s}.search-result.active{background:#c8a96e12;border-left-color:var(--amber)}.search-result-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.search-result-body{display:flex;flex-direction:column;gap:.12rem;min-width:0}.search-result-title{font-size:.82rem;color:var(--text);font-family:Courier Prime,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-meta{font-size:.66rem;color:var(--text-muted);font-family:Courier Prime,monospace}.search-result-sep{margin:0 .3rem;opacity:.5}.search-empty{padding:1.1rem 1rem;text-align:center;color:var(--text-muted);font-size:.75rem;font-family:Courier Prime,monospace}@media (max-width: 480px){.onboarding-prompt{font-size:1.1rem}.logo-life,.logo-glance{font-size:2rem}.stat-panels{display:none}}
