:root{font-family:Outfit,ui-sans-serif,system-ui,-apple-system,sans-serif;--font-heading: "Literata", Georgia, "Times New Roman", serif;line-height:1.4;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;--bg: #141A26;--surface: #1D2533;--surface-elevated: #273247;--text: #F4F1EA;--text-secondary: #CFC8BB;--text-muted: #A8A194;--accent: #C9A46A;--accent-subtle: rgba(201, 164, 106, .12);--accent-secondary: #9A9DD4;--accent-secondary-subtle: rgba(154, 157, 212, .15);--border: rgba(207, 200, 187, .1);--border-hover: rgba(207, 200, 187, .2);--border-active: rgba(207, 200, 187, .3);--interactive: rgba(207, 200, 187, .06);--interactive-hover: rgba(207, 200, 187, .1);--interactive-active: rgba(207, 200, 187, .14);--focus-ring: rgba(154, 157, 212, .8);--error: #E8937A;--error-subtle: rgba(232, 147, 122, .15);--success: #7DB88E;--text-on-accent: #FFF9F0;--backdrop: rgba(0, 0, 0, .45);--thread: #C45B4A;--thread-subtle: rgba(196, 91, 74, .15);--thread-line: rgba(196, 91, 74, .18);--glass-bg: rgba(207, 200, 187, .03);--glass-border: rgba(207, 200, 187, .08);--glass-glow: rgba(212, 168, 93, .03);--bg-glow: rgba(212, 168, 93, .05);--shadow-logo: rgba(10, 13, 20, .3);--shadow-dropdown: rgba(7, 10, 16, .5);--accent-fill: rgba(212, 168, 93, .55);--accent-secondary-fill: rgba(154, 157, 212, .5);--accent-secondary-line: rgba(154, 157, 212, .2);--accent-secondary-dot: rgba(154, 157, 212, .4);--accent-border: rgba(212, 168, 93, .35);--accent-hover: rgba(212, 168, 93, .22);--accent-secondary-border: rgba(154, 157, 212, .18);--accent-secondary-tag-border: rgba(154, 157, 212, .2);--success-fill: rgba(125, 184, 142, .55);--success-subtle: rgba(125, 184, 142, .1);--success-border: rgba(125, 184, 142, .18);--fading-border: rgba(212, 168, 93, .15)}html.light{--bg: #E4DACE;--surface: #EBE2D4;--surface-elevated: #DDD2C2;--text: #2E2A24;--text-secondary: #5B5348;--text-muted: #6B5F50;--accent: #8B6326;--accent-subtle: rgba(139, 99, 38, .12);--accent-secondary: #5E6396;--accent-secondary-subtle: rgba(94, 99, 150, .12);--border: rgba(46, 42, 36, .1);--border-hover: rgba(46, 42, 36, .2);--border-active: rgba(46, 42, 36, .3);--interactive: rgba(46, 42, 36, .05);--interactive-hover: rgba(46, 42, 36, .09);--interactive-active: rgba(46, 42, 36, .13);--focus-ring: rgba(94, 99, 150, .7);--error: #C4533E;--error-subtle: rgba(196, 83, 62, .12);--success: #3A7549;--thread: #9E3E30;--thread-subtle: rgba(158, 62, 48, .12);--thread-line: rgba(158, 62, 48, .15);--glass-bg: var(--interactive);--glass-border: var(--border-hover);--glass-glow: rgba(184, 134, 59, .06);--bg-glow: rgba(184, 134, 59, .06);--shadow-logo: rgba(0, 0, 0, .08);--shadow-dropdown: rgba(0, 0, 0, .12);--accent-fill: rgba(184, 134, 59, .5);--accent-secondary-fill: rgba(94, 99, 150, .45);--accent-secondary-line: rgba(94, 99, 150, .18);--accent-secondary-dot: rgba(94, 99, 150, .35);--accent-border: rgba(184, 134, 59, .3);--accent-hover: rgba(184, 134, 59, .18);--accent-secondary-border: rgba(94, 99, 150, .15);--accent-secondary-tag-border: rgba(94, 99, 150, .18);--success-fill: rgba(74, 138, 92, .45);--success-subtle: rgba(74, 138, 92, .08);--success-border: rgba(74, 138, 92, .15);--fading-border: rgba(184, 134, 59, .15);--text-on-accent: #FFF9F0;--backdrop: rgba(0, 0, 0, .3)}html.font-small{font-size:15px}html.font-medium{font-size:16px}html.font-large{font-size:19px}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;background:var(--bg)}body{overflow:hidden;overscroll-behavior:none}:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}::-moz-focus-inner{border:0}:focus:not(:focus-visible){outline:none}.content-focus-target:focus{outline:none}.save-indicator{margin:0;font-size:.82rem;letter-spacing:.01em;display:flex;align-items:center;gap:.4rem}.save-dot{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}.save-indicator--saving{color:var(--text-muted)}.save-indicator--saving .save-dot{background:var(--accent);animation:save-pulse 1.4s ease-in-out infinite}.save-indicator--saved{color:var(--success)}.save-indicator--saved .save-dot{background:var(--success)}.save-indicator--error{color:var(--error)}.save-retry-btn{background:none;border:none;padding:0;color:inherit;text-decoration:underline;cursor:pointer;font:inherit}.save-retry-btn:hover{opacity:.8}@keyframes save-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.75)}}@media(prefers-reduced-motion:reduce){.save-indicator--saving .save-dot{animation:none}}.skip-link{position:absolute;top:-100%;left:0;z-index:100;padding:.55rem 1rem;background:var(--surface-elevated);color:var(--text);font-size:.85rem;text-decoration:none;border-radius:0 0 10px}.skip-link:focus{top:0}.splash-maze{position:absolute;left:50%;width:min(740px,140vw);top:50%;transform:translate(-50%,-50%) rotate(var(--maze-rotation, 0deg));opacity:.08;color:#5a6889;pointer-events:none;filter:none;transition:opacity 1.5s cubic-bezier(.4,0,.2,1),width 1.5s cubic-bezier(.4,0,.2,1),top 1.5s cubic-bezier(.4,0,.2,1),color 1.5s ease,filter 1.5s ease,transform .8s cubic-bezier(.4,0,.2,1)}.splash-maze--drawing{width:min(440px,75vw);top:50%;opacity:.5;color:var(--accent, #D4A85D);filter:drop-shadow(0 0 6px rgba(212,168,93,.25)) drop-shadow(0 0 30px rgba(212,168,93,.12));transition:none}.splash-maze__path{stroke-dasharray:1;stroke-dashoffset:0}.splash-maze--drawing .splash-maze__arc{stroke-dashoffset:1;animation:maze-stroke-arc 1s ease-in-out forwards}@keyframes maze-stroke-arc{0%{stroke-dashoffset:1;stroke-opacity:.5}25%{stroke-opacity:1}to{stroke-dashoffset:0;stroke-opacity:1}}.splash-maze--drawing .splash-maze__radial{stroke-dashoffset:1;animation:maze-stroke-radial .25s ease-out forwards}@keyframes maze-stroke-radial{0%{stroke-dashoffset:1;stroke-opacity:.4}to{stroke-dashoffset:0;stroke-opacity:1}}.splash-maze__pulse{opacity:0;transform-origin:512px 512px}.splash-maze--drawing .splash-maze__pulse{animation:maze-pulse 1.1s ease-out forwards}@keyframes maze-pulse{0%{opacity:0;transform:scale(1);stroke-width:3}12%{opacity:.3}to{opacity:0;transform:scale(12);stroke-width:.15}}.content-layer.content-hidden{opacity:0;pointer-events:none}.content-layer.content-entering{animation:content-enter 1.2s cubic-bezier(.2,0,.2,1) forwards}.content-layer.content-entering .top-bar{animation:content-enter-child .8s cubic-bezier(.2,0,.2,1) .05s both}.content-layer.content-entering .content-focus-target{animation:content-enter-child .8s cubic-bezier(.2,0,.2,1) .3s both}@keyframes content-enter{0%{opacity:0}to{opacity:1}}@keyframes content-enter-child{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.splash-maze__content--celebrating{animation:maze-save-ripple 3s cubic-bezier(.4,0,.2,1)}@keyframes maze-save-ripple{0%{rotate:0deg}to{rotate:1080deg}}.splash-maze__ring--celebrating{transform-origin:512px 512px;animation:maze-ring-breathe 2.4s ease-in-out both}@keyframes maze-ring-breathe{0%{scale:1}28%{scale:var(--breathe-expand, 1.1)}54%{scale:var(--breathe-contract, .95)}74%{scale:var(--breathe-settle, 1.03)}to{scale:1}}.focus-shell:has(.focus-input:focus,.notes:focus) .splash-maze{opacity:.04}html.light .splash-maze{color:#2e2a24;opacity:.06}html.light .splash-maze--drawing{color:var(--accent, #B8863B);opacity:.45;filter:drop-shadow(0 0 6px rgba(184,134,59,.2)) drop-shadow(0 0 30px rgba(184,134,59,.1))}@media(min-width:820px){.splash-maze{width:min(780px,120vw)}.splash-maze--drawing{width:min(480px,52vw)}}@media(prefers-reduced-motion:reduce){.splash-maze{transition:none}.splash-maze--drawing{opacity:.08;color:#5a6889;width:min(740px,140vw);filter:none}.splash-maze--drawing .splash-maze__arc,.splash-maze--drawing .splash-maze__radial{animation:none;stroke-dashoffset:0}.splash-maze--drawing .splash-maze__pulse,.splash-maze__content--celebrating,.splash-maze__ring--celebrating{animation:none}.content-layer.content-hidden{opacity:1;pointer-events:auto}.content-layer.content-entering,.content-layer.content-entering .top-bar,.content-layer.content-entering .content-focus-target{animation:none;opacity:1}}.mitos-wordmark{margin:0;display:inline-flex;align-items:baseline;font-family:var(--font-heading);font-size:clamp(2.2rem,6.5vw,3.5rem);font-weight:600;line-height:1;letter-spacing:-.03em;color:var(--text);white-space:nowrap;transition:color .3s ease}.mitos-o{display:inline-block;width:.68em;height:.68em;vertical-align:baseline;position:relative;top:.05em;margin-inline:.01em .005em}.mitos-o svg{display:block;width:100%;height:100%;overflow:visible}.mitos-o .mitos-o-outline{fill:none;stroke:currentColor;stroke-width:5;stroke-linecap:round}.mitos-o circle{fill:none;stroke:currentColor;stroke-width:3.2;stroke-linecap:round}.mitos-o .mitos-o-thread{stroke:var(--thread);transition:stroke .3s ease}.profile-page{display:flex;flex-direction:column;gap:0}.profile-back{align-self:flex-start;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;color:var(--text-secondary);font:inherit;font-size:.82rem;cursor:pointer;padding:0;margin-bottom:1rem;letter-spacing:.01em}.profile-back:hover{color:var(--text)}.profile-title{margin:0 0 .25rem;font-family:var(--font-heading);font-size:clamp(1.4rem,3.5vw,1.9rem);font-weight:560;letter-spacing:-.02em}.profile-email{margin:0 0 1.75rem;font-size:.82rem;color:var(--text-muted);letter-spacing:.01em}.profile-form{display:flex;flex-direction:column;gap:.35rem}.profile-label{font-size:.78rem;color:var(--text-secondary);letter-spacing:.03em;margin-top:.6rem}.profile-label:first-child{margin-top:0}.profile-input{width:100%;border:none;border-bottom:1px solid var(--border-hover);background:transparent;color:var(--text);font:inherit;font-size:clamp(1rem,2.5vw,1.15rem);padding:.4rem 0;outline:none}.profile-input::placeholder{color:var(--text-muted)}.profile-input:focus{border-bottom-color:var(--border-active)}.profile-input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.profile-hint{margin:.2rem 0 0;font-size:.72rem;color:var(--text-muted);line-height:1.3}.profile-error{margin:.5rem 0 0;font-size:.82rem;color:var(--error)}.profile-save{margin-top:1.5rem;align-self:flex-start}.profile-save+.save-indicator{margin-top:.6rem}.delete-entry-btn{color:var(--text-secondary)}.delete-entry-btn:hover{color:var(--error)}.delete-entry-dialog{position:fixed;inset:0;width:100%;height:100%;max-width:none;max-height:none;margin:0;border:none;background:transparent;color:inherit;padding:1.5rem;overflow-y:auto}.delete-entry-dialog[open]{display:flex;align-items:center;justify-content:center;animation:delete-fade-in .2s ease-out}.delete-entry-dialog::backdrop{background:#00000073}html.light .delete-entry-dialog::backdrop{background:#0000004d}.delete-entry-dialog[open]::backdrop{animation:delete-fade-in .2s ease-out}@keyframes delete-fade-in{0%{opacity:0}to{opacity:1}}.delete-entry-modal{position:relative;width:min(360px,100%);background:var(--surface);border:1px solid var(--border-hover);border-radius:16px;padding:1.75rem 1.5rem 1.5rem;animation:delete-slide-up .25s ease-out}@keyframes delete-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.delete-entry-title{margin:0;font-family:var(--font-heading);font-size:1.1rem;font-weight:560}.delete-entry-body{margin:.5rem 0 0;color:var(--text-secondary);font-size:.88rem;line-height:1.45}.delete-entry-actions{margin-top:1.25rem;display:flex;gap:.5rem;justify-content:flex-end}.delete-entry-confirm{background:var(--error-subtle);color:var(--error);border-color:transparent}.delete-entry-confirm:hover{background:var(--error);color:var(--bg)}.delete-entry-confirm:disabled{opacity:.6;cursor:not-allowed}@media(prefers-reduced-motion:reduce){.delete-entry-dialog[open],.delete-entry-dialog[open]::backdrop{animation:none}.delete-entry-modal{animation:none}}.social-activity{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border);display:grid;gap:.75rem}.social-reactions-list{display:flex;flex-wrap:wrap;gap:.4rem}.social-reaction-badge{display:inline-flex;align-items:center;gap:.25rem;background:var(--interactive);border:1px solid var(--border);border-radius:20px;padding:.2rem .5rem .2rem .2rem;font-size:.82rem}.social-reaction-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600}.social-reaction-name{font-size:.75rem;color:var(--text-secondary)}.social-comment{background:var(--interactive);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem}.social-comment+.social-comment{margin-top:.4rem}.social-comment-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem}.social-comment-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600;flex-shrink:0}.social-comment-name{font-size:.82rem;font-weight:500}.social-comment-time{font-size:.7rem;color:var(--text-muted);margin-left:auto}.social-comment-body{margin:0;font-size:.88rem;line-height:1.4;white-space:pre-wrap}.history-page{padding-top:.25rem}.history-back{margin:0;padding:0;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;font:inherit;font-size:.82rem;color:var(--text-secondary);cursor:pointer}.history-back:hover{color:var(--text)}.history-title{margin:.8rem 0 0;font-family:var(--font-heading);font-size:clamp(1.3rem,3.5vw,1.7rem);font-weight:560;letter-spacing:-.02em}.history-loading,.history-empty-state{margin:1.5rem 0 0;color:var(--text-secondary);font-size:.88rem}.history-list{margin-top:1rem;display:grid;gap:.5rem;padding-left:.85rem;border-left:1.5px solid var(--thread-line)}.history-card-header{display:flex;align-items:center;gap:.5rem}.history-card-emoji{margin-left:auto;font-size:.82rem;letter-spacing:.05em}.history-card-comments{font-size:.72rem;color:var(--text-muted);margin-top:.1rem}.history-card-type{font-size:.72rem;letter-spacing:.03em;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--accent-border);border-radius:6px;padding:.1rem .35rem}.history-card{position:relative;display:flex;flex-direction:column;gap:.25rem;text-align:left;background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.7rem .8rem;color:var(--text);font:inherit;cursor:pointer;transition:background .15s}.history-card:before{content:"";position:absolute;left:calc(-.85rem - 2px);top:1rem;width:5px;height:5px;background:var(--thread);border-radius:50%;opacity:.25}.history-card:hover{background:var(--interactive-hover)}@media(prefers-reduced-motion:reduce){.history-card{transition:none}}.history-card-date{font-size:.78rem;color:var(--text-secondary);letter-spacing:.02em}.history-card-preview{font-size:.9rem;line-height:1.4;color:var(--text-secondary)}.history-load-more{margin-top:.75rem;width:100%;text-align:center;font-size:.82rem}.history-detail-date{margin:.8rem 0 0;color:var(--text-secondary);font-size:.88rem;letter-spacing:.02em}.history-detail-list{margin-top:.8rem;display:grid;gap:.6rem}.history-detail-item{background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.7rem .8rem}.history-detail-item p{margin:0;color:var(--text-secondary);font-size:.82rem}.history-detail-item div{margin-top:.3rem;white-space:pre-wrap}.history-empty{color:var(--text-muted)}.history-detail-type{display:inline-block;margin-top:.3rem;font-size:.75rem;letter-spacing:.03em;color:var(--accent)}.history-detail-item--inline{display:flex;gap:.5rem;align-items:baseline}.history-item-number{color:var(--accent);font-weight:560;min-width:1.5rem;text-align:right;flex-shrink:0;font-size:.85rem}.history-detail-actions{margin-top:1rem;display:flex;gap:.5rem;flex-wrap:wrap}.history-unshare-confirm{display:flex;flex-direction:column;gap:.4rem;background:var(--interactive);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem;width:100%}.history-unshare-text{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.history-unshare-yes{color:var(--error)}.history-social{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border);display:grid;gap:1rem}.history-social-title{margin:0 0 .4rem;font-size:.82rem;font-weight:560;color:var(--text-secondary)}.history-reactions-list{display:flex;flex-wrap:wrap;gap:.4rem}.history-reaction-badge{display:inline-flex;align-items:center;gap:.25rem;background:var(--interactive);border:1px solid var(--border);border-radius:20px;padding:.2rem .5rem .2rem .2rem;font-size:.82rem}.history-reaction-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600}.history-reaction-name{font-size:.75rem;color:var(--text-secondary)}.history-comment{background:var(--interactive);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem;margin-top:.4rem}.history-comment-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem}.history-comment-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600;flex-shrink:0}.history-comment-name{font-size:.82rem;font-weight:500}.history-comment-time{font-size:.7rem;color:var(--text-muted);margin-left:auto}.history-comment-body{margin:0;font-size:.88rem;line-height:1.4;white-space:pre-wrap}.milestones-page{display:flex;flex-direction:column;gap:0}.milestones-back{align-self:flex-start;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;color:var(--text-secondary);font:inherit;font-size:.82rem;cursor:pointer;padding:0;margin-bottom:1rem;letter-spacing:.01em}.milestones-back:hover{color:var(--text)}.milestones-title{margin:0 0 1.25rem;font-family:var(--font-heading);font-size:clamp(1.4rem,3.5vw,1.9rem);font-weight:560;letter-spacing:-.02em}.milestones-add{align-self:flex-start}.milestones-form{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.5rem;padding:1rem;background:var(--interactive);border:1px solid var(--border);border-radius:12px}.milestones-label{font-size:.78rem;color:var(--text-secondary);letter-spacing:.03em;margin-top:.6rem}.milestones-label:first-child{margin-top:0}.milestones-optional{color:var(--text-muted)}.milestones-input{width:100%;border:none;border-bottom:1px solid var(--border-hover);background:transparent;color:var(--text);font:inherit;font-size:clamp(1rem,2.5vw,1.15rem);padding:.4rem 0;outline:none}.milestones-input::placeholder{color:var(--text-muted)}.milestones-input:focus{border-bottom-color:var(--border-active)}.milestones-input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.milestones-date{max-width:12rem}.milestones-date::-webkit-calendar-picker-indicator{filter:var(--date-picker-filter, none);cursor:pointer}html.dark .milestones-date::-webkit-calendar-picker-indicator{filter:invert(.85)}.milestones-pin-label{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.milestones-pin-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.milestones-error{margin:.5rem 0 0;font-size:.82rem;color:var(--error)}.milestones-form-actions{display:flex;gap:.5rem;margin-top:1rem}.milestones-loading{margin:1.5rem 0 0;color:var(--text-secondary);font-size:.88rem}.milestones-empty{margin:1.5rem 0 0}.milestones-empty p{margin:0;color:var(--text-secondary);font-size:.92rem;line-height:1.5}.milestones-section{margin-top:1.5rem}.milestones-section-title{margin:0 0 .5rem;font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.milestones-list{display:grid;gap:.5rem}.milestones-card{position:relative;display:flex;flex-direction:column;gap:.15rem;text-align:left;background:var(--interactive);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:12px;padding:.7rem .8rem;color:var(--text);font:inherit;cursor:pointer;transition:background .15s}.milestones-card:hover{background:var(--interactive-hover)}.milestones-card--editing{border-color:var(--accent);background:var(--interactive-hover)}.milestones-card--completed{border-left-color:var(--text-muted);opacity:.8}.milestones-card-day{font-size:1.1rem;font-weight:560;color:var(--accent);letter-spacing:-.01em}.milestones-card-span{font-size:1rem;font-weight:500;color:var(--text-secondary);letter-spacing:-.01em}.milestones-card-name{font-size:.92rem;color:var(--text)}.milestones-card-meta{font-size:.75rem;color:var(--text-muted);letter-spacing:.01em}.milestones-card-unpinned{font-size:.72rem;color:var(--text-muted);font-style:italic}@media(prefers-reduced-motion:reduce){.milestones-card{transition:none}}.milestones-delete-btn{align-self:flex-start;margin-top:.75rem;color:var(--text-secondary)}.milestones-delete-btn:hover{color:var(--error)}.milestones-dialog{position:fixed;inset:0;width:100%;height:100%;max-width:none;max-height:none;margin:0;border:none;background:transparent;color:inherit;padding:1.5rem;overflow-y:auto}.milestones-dialog[open]{display:flex;align-items:center;justify-content:center;animation:ms-fade-in .2s ease-out}.milestones-dialog::backdrop{background:#00000073}html.light .milestones-dialog::backdrop{background:#0000004d}.milestones-dialog[open]::backdrop{animation:ms-fade-in .2s ease-out}@keyframes ms-fade-in{0%{opacity:0}to{opacity:1}}.milestones-dialog-modal{position:relative;width:min(360px,100%);background:var(--surface);border:1px solid var(--border-hover);border-radius:16px;padding:1.75rem 1.5rem 1.5rem;animation:ms-slide-up .25s ease-out}@keyframes ms-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.milestones-dialog-title{margin:0;font-family:var(--font-heading);font-size:1.1rem;font-weight:560}.milestones-dialog-body{margin:.5rem 0 0;color:var(--text-secondary);font-size:.88rem;line-height:1.45}.milestones-dialog-actions{margin-top:1.25rem;display:flex;gap:.5rem;justify-content:flex-end}.milestones-dialog-confirm{background:var(--error-subtle);color:var(--error);border-color:transparent}.milestones-dialog-confirm:hover{background:var(--error);color:var(--bg)}.milestones-dialog-confirm:disabled{opacity:.6;cursor:not-allowed}@media(prefers-reduced-motion:reduce){.milestones-dialog[open],.milestones-dialog[open]::backdrop{animation:none}.milestones-dialog-modal{animation:none}}.friends-page{padding-top:.25rem}.friends-back{margin:0;padding:0;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;font:inherit;font-size:.82rem;color:var(--text-secondary);cursor:pointer}.friends-back:hover{color:var(--text)}.friends-title{margin:.8rem 0 0;font-family:var(--font-heading);font-size:clamp(1.3rem,3.5vw,1.7rem);font-weight:560;letter-spacing:-.02em}.friends-section{margin-top:1.5rem}.friends-section-title{margin:0 0 .25rem;font-size:.88rem;font-weight:560;color:var(--text-secondary);letter-spacing:.01em}.friends-section-desc{margin:0 0 .75rem;font-size:.82rem;color:var(--text-muted);line-height:1.4}.friends-empty{color:var(--text-muted);font-size:.82rem}.friends-invite-result{margin-top:.75rem;display:flex;gap:.5rem;align-items:center}.friends-invite-input{flex:1;min-width:0;background:var(--interactive);border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem;font:inherit;font-size:.82rem;color:var(--text)}.friends-invite-input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.friends-invite-list{display:grid;gap:.4rem;margin-top:.5rem}.friends-invite-item{display:flex;align-items:center;justify-content:space-between;background:var(--interactive);border:1px solid var(--border);border-radius:10px;padding:.5rem .7rem}.friends-invite-date{font-size:.78rem;color:var(--text-secondary)}.friends-revoke-btn{background:none;border:none;font:inherit;font-size:.78rem;color:var(--text-secondary);cursor:pointer;padding:.2rem .4rem;min-height:44px;display:inline-flex;align-items:center}.friends-revoke-btn:hover{color:var(--error)}.friends-list{display:grid;gap:.4rem;margin-top:.5rem}.friends-list-item{display:flex;align-items:center;gap:.6rem;background:var(--interactive);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem}.friends-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;font-weight:600;flex-shrink:0}.friends-list-info{flex:1;min-width:0;display:flex;flex-direction:column}.friends-list-name{font-size:.9rem;font-weight:500}.friends-list-since{font-size:.72rem;color:var(--text-muted)}.friends-remove-btn{background:none;border:none;font:inherit;font-size:.78rem;color:var(--text-secondary);cursor:pointer;padding:.2rem .4rem;min-height:44px;display:inline-flex;align-items:center}.friends-remove-btn:hover{color:var(--error)}.friends-confirm-remove{display:flex;align-items:center;gap:.4rem;font-size:.78rem}.friends-confirm-text{color:var(--text-secondary)}.friends-confirm-yes,.friends-confirm-no{background:none;border:none;font:inherit;font-size:.78rem;cursor:pointer;padding:.2rem .4rem;min-height:44px;display:inline-flex;align-items:center}.friends-confirm-yes{color:var(--error);font-weight:600}.friends-confirm-no{color:var(--text-secondary)}.shared-page{padding-top:.25rem}.shared-back{margin:0;padding:0;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;font:inherit;font-size:.82rem;color:var(--text-secondary);cursor:pointer}.shared-back:hover{color:var(--text)}.shared-title{margin:.8rem 0 0;font-family:var(--font-heading);font-size:clamp(1.3rem,3.5vw,1.7rem);font-weight:560;letter-spacing:-.02em}.shared-loading,.shared-empty-state{margin:1.5rem 0 0;color:var(--text-secondary);font-size:.88rem;line-height:1.5}.shared-list{margin-top:1rem;display:grid;gap:.5rem}.shared-card{display:flex;flex-direction:column;gap:.3rem;text-align:left;background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.7rem .8rem;color:var(--text);font:inherit;cursor:pointer;transition:background .15s}.shared-card:hover{background:var(--interactive-hover)}@media(prefers-reduced-motion:reduce){.shared-card{transition:none}}.shared-card-author{display:flex;align-items:center;gap:.4rem}.shared-card-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.65rem;font-weight:600;flex-shrink:0}.shared-card-name{font-size:.82rem;font-weight:500}.shared-card-date{font-size:.75rem;color:var(--text-muted);letter-spacing:.02em}.shared-card-preview{font-size:.88rem;line-height:1.4;color:var(--text-secondary)}.shared-card-meta{display:flex;align-items:center;gap:.6rem;margin-top:.15rem}.shared-card-reactions{font-size:.82rem}.shared-card-comments{font-size:.72rem;color:var(--text-muted)}.shared-load-more{margin-top:.75rem;width:100%;text-align:center;font-size:.82rem}.shared-detail-author{margin-top:.8rem;display:flex;align-items:center;gap:.6rem}.shared-author-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:600;flex-shrink:0}.shared-author-name{display:block;font-weight:500;font-size:.95rem}.shared-detail-date{display:block;font-size:.78rem;color:var(--text-secondary);letter-spacing:.02em}.shared-detail-list{margin-top:.8rem;display:grid;gap:.6rem}.shared-detail-item{background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.7rem .8rem}.shared-detail-item p{margin:0;color:var(--text-secondary);font-size:.82rem}.shared-detail-item div{margin-top:.3rem;white-space:pre-wrap}.shared-empty{color:var(--text-muted)}.shared-detail-item--inline{display:flex;gap:.5rem;align-items:baseline}.shared-item-number{color:var(--accent);font-weight:560;min-width:1.5rem;text-align:right;flex-shrink:0;font-size:.85rem}.shared-reactions{margin-top:1rem;display:flex;flex-direction:column;gap:.6rem}.shared-reactions-display{display:flex;flex-wrap:wrap;gap:.4rem}.shared-reaction-badge{display:inline-flex;align-items:center;gap:.2rem;background:var(--interactive);border:1px solid var(--border);border-radius:20px;padding:.2rem .5rem .2rem .2rem}.shared-reaction-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600}.shared-reaction-emoji{font-size:.88rem}.shared-reactions-picker{display:flex;gap:.25rem;flex-wrap:wrap}.shared-reaction-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--interactive);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s}.shared-reaction-btn:hover{background:var(--interactive-hover)}.shared-reaction-btn.active{background:var(--accent-subtle);border-color:var(--accent-border)}.shared-reaction-btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){.shared-reaction-btn{transition:none}}.shared-comments{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.shared-comments-title{margin:0 0 .6rem;font-size:.88rem;font-weight:560;color:var(--text-secondary)}.shared-comments-list{display:grid;gap:.6rem;margin-bottom:.8rem}.shared-comment{background:var(--interactive);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem}.shared-comment-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem}.shared-comment-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600;flex-shrink:0}.shared-comment-name{font-size:.82rem;font-weight:500}.shared-comment-time{font-size:.7rem;color:var(--text-muted);margin-left:auto}.shared-comment-body{margin:0;font-size:.88rem;line-height:1.4;white-space:pre-wrap}.shared-comment-actions{display:flex;gap:.5rem;margin-top:.3rem}.shared-comment-action-btn{background:none;border:none;font:inherit;font-size:.72rem;color:var(--text-muted);cursor:pointer;padding:.15rem 0;min-height:28px}.shared-comment-action-btn:hover{color:var(--text-secondary)}.shared-comment-edit{margin-top:.3rem;display:flex;flex-direction:column;gap:.4rem}.shared-comment-edit-actions{display:flex;gap:.5rem}.shared-comment-form{display:flex;flex-direction:column;gap:.4rem}.shared-comment-textarea{width:100%;background:var(--interactive);border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem;font:inherit;font-size:.88rem;color:var(--text);resize:vertical;min-height:60px}.shared-comment-textarea:focus{border-color:var(--border-active)}.shared-comment-textarea:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.shared-comment-submit{align-self:flex-end;font-size:.82rem}.invite-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:1rem}.invite-card{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:360px;gap:.75rem}.invite-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:600;letter-spacing:-.02em}.invite-heading{margin:0;font-family:var(--font-heading);font-size:clamp(1.2rem,3vw,1.5rem);font-weight:560;letter-spacing:-.02em}.invite-subtext{margin:0;color:var(--text-secondary);font-size:.88rem;line-height:1.4}.invite-accept{margin-top:.5rem;min-width:160px}.invite-loading{color:var(--text-secondary);font-size:.88rem}.invite-error{margin:0;color:var(--text);font-size:1rem}.invite-hint{margin:0;color:var(--text-secondary);font-size:.82rem}.invite-accepted{margin:0;font-size:1rem;color:var(--text)}.notification-bell{position:relative;border:1px solid var(--border-hover);background:var(--interactive);color:var(--text-secondary);width:44px;height:44px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}.notification-bell:hover{background:var(--interactive-hover);color:var(--text)}.notification-bell:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){.notification-bell{transition:none}}.notification-dot{position:absolute;top:7px;right:7px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px var(--surface)}.notif-page{padding-top:.25rem}.notif-back{margin:0;padding:0;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;font:inherit;font-size:.82rem;color:var(--text-secondary);cursor:pointer}.notif-back:hover{color:var(--text)}.notif-title{margin:.8rem 0 0;font-family:var(--font-heading);font-size:clamp(1.3rem,3.5vw,1.7rem);font-weight:560;letter-spacing:-.02em}.notif-loading,.notif-empty{margin:1.5rem 0 0;color:var(--text-secondary);font-size:.88rem}.notif-list{margin-top:1rem;display:grid;gap:.4rem}.notif-item{display:flex;align-items:center;gap:.6rem;text-align:left;background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.65rem .8rem;color:var(--text);font:inherit;cursor:pointer;transition:background .15s;width:100%}.notif-item--read{opacity:.6}.notif-item:hover{background:var(--interactive-hover)}.notif-item--read:hover{opacity:1}@media(prefers-reduced-motion:reduce){.notif-item{transition:none}}.notif-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;font-weight:600;flex-shrink:0}.notif-avatar--generic{background:var(--accent-subtle);color:var(--accent)}.notif-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.notif-message{margin:0;font-size:.88rem;line-height:1.35}.notif-message strong{font-weight:560}.notif-time{font-size:.72rem;color:var(--text-muted)}.milestone-counter{text-align:center;margin-bottom:.5rem;padding:.35rem 0;display:flex;flex-direction:column;gap:.25rem;align-items:center}.milestone-counter-line{display:inline-flex;align-items:center;gap:0;font-size:.82rem;letter-spacing:.02em;color:var(--text-secondary)}.milestone-counter-day{color:var(--accent);font-weight:500}.milestone-counter-dash{color:var(--text-muted)}.milestone-counter-name{color:var(--text-secondary)}.milestone-counter-add{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin-left:.35rem;padding:0;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.milestone-counter-add:hover,.milestone-counter-add.added{color:var(--accent);border-color:var(--accent)}@media(prefers-reduced-motion:reduce){.milestone-counter-add{transition:none}}.milestone-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem;padding:.35rem 0}.milestone-hint-link{background:none;border:none;color:var(--text-muted);font:inherit;font-size:.78rem;letter-spacing:.02em;cursor:pointer;padding:0}.milestone-hint-link:hover{color:var(--accent)}.milestone-hint-dismiss{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:.7rem;cursor:pointer;opacity:.6}.milestone-hint-dismiss:hover{opacity:1;color:var(--text-secondary)}.mode-cards{margin-top:1rem;display:grid;gap:.5rem}.mode-card{display:flex;align-items:center;gap:.75rem;text-align:left;background:var(--interactive);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:12px;padding:.85rem 1rem;color:var(--text);font:inherit;cursor:pointer;transition:background .15s,border-color .15s;position:relative}.mode-card:hover{background:var(--interactive-hover)}.mode-card:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.mode-card--gold{border-left-color:var(--accent)}.mode-card--gold .mode-card-glyph{color:var(--accent)}.mode-card--periwinkle{border-left-color:var(--accent-secondary)}.mode-card--periwinkle .mode-card-glyph{color:var(--accent-secondary)}.mode-card--thread{border-left-color:var(--thread)}.mode-card--thread .mode-card-glyph{color:var(--thread)}.mode-card-glyph{font-size:1.3rem;line-height:1;flex-shrink:0;width:1.6rem;text-align:center;opacity:.7;transition:opacity .15s}.mode-card:hover .mode-card-glyph{opacity:1}.mode-card-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}.mode-card-title{font-family:var(--font-heading);font-weight:560;font-size:1rem;letter-spacing:-.01em}.mode-card-desc{font-size:.82rem;color:var(--text-secondary)}.mode-card-badge{position:absolute;top:.6rem;right:.75rem;font-size:.72rem;letter-spacing:.03em;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--accent-border);border-radius:6px;padding:.15rem .45rem}@media(prefers-reduced-motion:reduce){.mode-card,.mode-card-glyph{transition:none}}.entry-overflow{position:relative}.entry-overflow-trigger{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--interactive);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);font-size:1.1rem;font-weight:700;letter-spacing:.15em;cursor:pointer;padding:0;line-height:1;transition:background .15s}.entry-overflow-trigger:hover{background:var(--interactive-hover);color:var(--text)}.entry-overflow-trigger:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){.entry-overflow-trigger{transition:none}}.entry-overflow-menu{position:absolute;bottom:calc(100% + .35rem);right:0;min-width:140px;border-radius:10px;border:1px solid var(--border-hover);background:var(--surface-elevated);box-shadow:0 8px 20px var(--shadow-dropdown);overflow:hidden;z-index:20}.entry-overflow-item{display:block;width:100%;text-align:left;background:none;border:none;font:inherit;font-size:.84rem;color:var(--text);padding:.55rem .75rem;cursor:pointer;min-height:44px;display:flex;align-items:center}.entry-overflow-item:hover{background:var(--interactive-hover)}.entry-overflow-item--danger{color:var(--error)}.entry-overflow-item--danger:hover{background:var(--interactive-hover)}.gratitude-list{margin-top:1rem;display:grid;gap:.35rem}.gratitude-row{display:flex;align-items:center;gap:.5rem}.gratitude-number{color:var(--text-muted);font-size:.85rem;min-width:1.5rem;text-align:right;flex-shrink:0}.gratitude-input{flex:1;border:none;border-bottom:1px solid var(--border);outline:none;background:transparent;color:var(--text);font:inherit;font-size:clamp(1rem,2.5vw,1.15rem);padding:.45rem .5rem;line-height:1.5;min-height:44px;border-radius:0;transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,border-radius .3s ease}.gratitude-input::placeholder{color:var(--text-muted)}.gratitude-input:focus,.gratitude-input:focus-visible{background:var(--glass-bg);border-radius:10px;border-bottom:1px solid var(--glass-border);box-shadow:0 0 0 1px var(--glass-border),0 4px 16px var(--glass-glow);outline:none}.gratitude-hint{margin:.5rem 0 0;color:var(--error);font-size:.82rem}.gratitude-helper{margin-top:.6rem}.gratitude-review-list{margin-top:1rem;display:grid;gap:.35rem;padding-left:.85rem;border-left:1.5px solid var(--thread-line)}.gratitude-review-item{display:flex;gap:.5rem;padding:.5rem .8rem;background:var(--interactive);border:1px solid var(--border);border-radius:10px;line-height:1.5}.gratitude-review-number{color:var(--accent);font-weight:560;min-width:1.5rem;text-align:right;flex-shrink:0}.gratitude-highlight-section{margin-top:1rem}.gratitude-highlight-label{display:block;margin-bottom:.4rem;color:var(--text-secondary);font-size:.85rem}.gratitude-highlight-input{width:100%;border:none;border-bottom:1px solid var(--border);outline:none;background:transparent;color:var(--text);font:inherit;padding:.4rem .5rem;min-height:44px;border-radius:0;transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,border-radius .3s ease}.gratitude-highlight-input::placeholder{color:var(--text-muted)}.gratitude-highlight-input:focus,.gratitude-highlight-input:focus-visible{background:var(--glass-bg);border-radius:10px;border-bottom:1px solid var(--glass-border);box-shadow:0 0 0 1px var(--glass-border),0 4px 16px var(--glass-glow);outline:none}.freeform-input{margin-top:1rem;width:100%;min-height:300px;resize:none;border:none;border-bottom:1px solid var(--border);outline:none;background:transparent;color:var(--text);font:inherit;font-size:clamp(1.08rem,2.7vw,1.28rem);line-height:1.58;padding:.5rem .6rem;border-radius:0;transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,border-radius .3s ease}.freeform-input::placeholder{color:var(--text-muted)}.freeform-input:focus,.freeform-input:focus-visible{background:var(--glass-bg);border-radius:12px;border-bottom:1px solid var(--glass-border);box-shadow:0 0 0 1px var(--glass-border),0 4px 16px var(--glass-glow);outline:none}.freeform-review{margin-top:1rem;padding:.7rem .8rem;background:var(--interactive);border:1px solid var(--border);border-radius:12px;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;line-height:1.58}.page{position:fixed;inset:0;overflow:hidden;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);background:radial-gradient(ellipse 600px 400px at 25% 0%,var(--bg-glow),transparent 60%),var(--surface);color:var(--text)}.focus-shell{position:relative;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;width:100%;height:100%;margin:0 auto;padding:1.05rem;scrollbar-width:thin;scrollbar-color:var(--border-active) transparent}.focus-shell::-webkit-scrollbar{width:6px}.focus-shell::-webkit-scrollbar-track{background:transparent}.focus-shell::-webkit-scrollbar-thumb{background:var(--border-active);border-radius:3px}.focus-shell::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.content-layer{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100%}.top-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:.85rem;padding-bottom:.85rem;border-bottom:1px solid var(--border-hover)}.logo-button{margin:0;padding:0;border:none;background:none;cursor:pointer}.logo-button:focus-visible,.menu-toggle:focus-visible,.menu-item:focus-visible,.menu-control-btn:focus-visible,.review-edit-btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.focus-input,.notes{border-radius:0;padding:.5rem .6rem;border-bottom:1px solid var(--border);transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,border-radius .3s ease}.focus-input:focus,.focus-input:focus-visible,.notes:focus,.notes:focus-visible{background:var(--glass-bg);border-radius:12px;border-color:var(--glass-border);box-shadow:0 0 0 1px var(--glass-border),0 4px 16px var(--glass-glow);outline:none}.date{margin:.5rem 0 0;color:var(--text-secondary);font-size:.88rem;letter-spacing:.02em}.step-indicator{display:flex;align-items:flex-start;justify-content:center;margin:.75rem 0 .1rem;padding:0 .5rem}.step-item{display:flex;flex-direction:column;align-items:center;flex:1;max-width:140px;position:relative;background:none;border:none;padding:.25rem 0;margin:0;font:inherit;cursor:default;-webkit-tap-highlight-color:transparent}.step-item.clickable{cursor:pointer}.step-item.clickable:hover .step-dot,.step-item.clickable:focus-visible .step-dot{opacity:.7;box-shadow:0 0 0 2.5px var(--thread-subtle)}.step-item.clickable:hover .step-label,.step-item.clickable:focus-visible .step-label{color:var(--thread)}.step-item:focus-visible{outline:2px solid var(--thread);outline-offset:4px;border-radius:4px}.step-item:not(:last-child):after{content:"";position:absolute;top:1px;left:50%;width:100%;height:1.5px;background:var(--thread);opacity:.15;transition:opacity .3s ease}.step-item.completed:not(:last-child):after{opacity:.4}.step-dot{width:4px;height:4px;border-radius:50%;border:none;background:var(--thread);opacity:.15;flex-shrink:0;transition:opacity .3s ease,box-shadow .3s ease}.step-item.completed .step-dot{opacity:.45}.step-item.current .step-dot{opacity:.6;box-shadow:0 0 0 2.5px var(--thread-subtle);animation:step-glow 2.8s ease-in-out infinite}@keyframes step-glow{0%,to{box-shadow:0 0 0 2.5px var(--thread-subtle)}50%{box-shadow:0 0 0 5px var(--thread-subtle)}}.step-label{margin-top:.4rem;font-size:.74rem;letter-spacing:.05em;color:var(--text-muted)}.step-item.current .step-label{color:var(--thread);font-weight:500}.step-item.completed .step-label{color:var(--text-secondary)}@media(prefers-reduced-motion:reduce){.step-dot,.step-item:not(:last-child):after{transition:none}.step-item.current .step-dot{animation:none}}h1,h2,h3{font-family:var(--font-heading)}h1{margin:.45rem 0 0;font-size:clamp(1.6rem,4.2vw,2.25rem);font-weight:560;line-height:1.16;letter-spacing:-.02em}.focus-input{margin-top:1rem;width:100%;min-height:180px;resize:none;border:1px solid transparent;outline:none;background:transparent;color:var(--text);font:inherit;font-size:clamp(1.08rem,2.7vw,1.28rem);line-height:1.58}.focus-input::placeholder,.notes::placeholder{color:var(--text-muted)}.focus-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding-top:.8rem}.hint{color:var(--text-muted);font-size:.82rem}.arrow{border:1px solid var(--border-active);background:var(--interactive);color:var(--text);width:44px;height:44px;border-radius:999px;font-size:1.18rem;cursor:pointer}.arrow:hover{background:var(--interactive-hover)}.review-list{margin-top:1rem;display:grid;gap:.6rem;padding-left:.85rem;border-left:1.5px solid var(--thread-line)}.review-item{position:relative;background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.7rem .8rem}.review-item:before{content:"";position:absolute;left:calc(-.85rem - 2px);top:50%;transform:translateY(-50%);width:5px;height:5px;background:var(--thread);border-radius:50%;opacity:.35}.review-edit-btn{position:absolute;top:.25rem;right:.25rem;display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:none;background:none;color:var(--text-secondary);opacity:.6;cursor:pointer;border-radius:10px;transition:opacity .15s ease}.review-edit-btn:hover,.review-edit-btn:focus-visible{opacity:.9}@media(prefers-reduced-motion:reduce){.review-edit-btn{transition:none}}.review-item p{margin:0;color:var(--text-secondary);font-size:.82rem}.review-item div{margin-top:.3rem;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word}.empty{color:var(--text-muted)}.notes{margin-top:.75rem;width:100%;min-height:80px;resize:none;border:1px solid transparent;outline:none;background:transparent;color:var(--text);font:inherit}.review-actions{margin-top:auto;display:flex;flex-wrap:wrap;gap:.55rem;padding-top:.9rem}.action{border:1px solid var(--border-active);background:var(--interactive);color:var(--text);border-radius:10px;padding:.56rem .84rem;font:inherit;cursor:pointer}.action.primary{background:var(--accent-subtle);border-color:var(--accent-border);color:var(--accent)}.action:hover{background:var(--interactive-hover)}.action.primary:hover{background:var(--accent-hover)}@media(min-width:820px){.page{padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}.focus-shell{width:min(760px,100%);padding:1.4rem}.focus-input{min-height:220px}}.top-bar-spacer{flex:1}.menu-wrap{position:relative}.menu-toggle{border:1px solid var(--border-hover);background:var(--interactive);color:var(--text-secondary);width:44px;height:44px;border-radius:10px;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.menu-toggle:hover{background:var(--interactive-hover)}.menu-dropdown{position:absolute;right:0;top:calc(100% + .35rem);min-width:160px;border-radius:12px;border:1px solid var(--border-hover);background:var(--surface-elevated);box-shadow:0 12px 24px var(--shadow-dropdown);overflow:hidden;z-index:30}.menu-item{width:100%;text-align:left;border:none;background:transparent;color:var(--text);font:inherit;font-size:.84rem;padding:.6rem .75rem;cursor:pointer}.menu-item+.menu-item{border-top:1px solid var(--border)}.menu-item:hover{background:var(--interactive-hover)}.menu-profile-item{display:flex;align-items:center;gap:.55rem;padding:.65rem .75rem}.menu-avatar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);font-size:.78rem;font-weight:600;flex-shrink:0}.menu-greeting{font-size:.82rem;color:var(--text-secondary)}.auth-dialog{position:fixed;inset:0;width:100%;height:100%;max-width:none;max-height:none;margin:0;border:none;background:transparent;color:inherit;padding:1.5rem;overflow-y:auto}.auth-dialog[open]{display:flex;align-items:center;justify-content:center;animation:auth-fade-in .2s ease-out}.auth-dialog::backdrop{background:#00000073}html.light .auth-dialog::backdrop{background:#0000004d}.auth-dialog[open]::backdrop{animation:auth-fade-in .2s ease-out}@keyframes auth-fade-in{0%{opacity:0}to{opacity:1}}.auth-modal{position:relative;width:min(400px,100%);background:var(--surface);border:1px solid var(--border-hover);border-radius:16px;padding:2.5rem 2rem 2rem;text-align:center;animation:auth-slide-up .25s ease-out}@keyframes auth-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.auth-modal-close{position:absolute;top:.75rem;right:.75rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;border-radius:8px}.auth-modal-close:hover{background:var(--interactive-hover);color:var(--text)}.auth-modal-brand{margin:0 0 .25rem;font-family:var(--font-heading);font-size:1.4rem;letter-spacing:.04em;color:var(--text)}.auth-modal-tagline{margin:0 0 1.75rem;font-size:.85rem;font-style:italic;color:var(--accent);letter-spacing:.02em}.auth-modal-label{display:block;margin:0 0 .6rem;font-size:.85rem;color:var(--text-secondary);text-align:left}.auth-modal-input{width:100%;border:1px solid var(--border-hover);border-radius:10px;background:var(--interactive);color:var(--text);font:inherit;font-size:.95rem;padding:.65rem .8rem;outline:none}.auth-modal-input::placeholder{color:var(--text-muted)}.auth-modal-input:focus{border-color:var(--border-active);background:var(--interactive-hover)}.auth-modal-input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-1px}.auth-modal-submit{width:100%;margin-top:.75rem;padding:.7rem;min-height:44px;border:none;border-radius:10px;background:var(--accent);color:var(--text-on-accent);font:inherit;font-size:.9rem;letter-spacing:.02em;cursor:pointer}.auth-modal-submit:hover{filter:brightness(1.08)}.auth-modal-submit:disabled{opacity:.45;cursor:default;filter:none}.auth-modal .auth-error{margin:.6rem 0 0;font-size:.8rem;color:var(--error);text-align:left}.auth-modal-back{margin-top:.75rem;padding:0;min-height:44px;display:inline-flex;align-items:center;background:none;border:none;font:inherit;font-size:.78rem;color:var(--accent-secondary);cursor:pointer}.auth-modal-back:hover{color:var(--text)}.auth-otp-digits{display:flex;justify-content:center;gap:.45rem;margin:.25rem 0 0}.auth-otp-digit{width:2.8rem;height:3.2rem;border:1px solid var(--border-hover);border-radius:10px;background:var(--interactive);color:var(--text);font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:1.35rem;text-align:center;outline:none;caret-color:transparent}.auth-otp-digit:focus{border-color:var(--accent);background:var(--interactive-hover)}.auth-otp-digit:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-1px}.auth-otp-digit::selection{background:transparent}@media(prefers-reduced-motion:reduce){.auth-dialog[open],.auth-dialog[open]::backdrop{animation:none}.auth-modal{animation:none}}.save-section{margin-top:1.1rem;padding-top:.85rem;border-top:1px solid var(--border)}.menu-controls{display:flex;justify-content:center;gap:.35rem;padding:.5rem .75rem;border-bottom:1px solid var(--border)}.menu-control-btn{width:44px;height:44px;border:1px solid var(--border-hover);border-radius:10px;background:var(--interactive);color:var(--text-secondary);font:inherit;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.menu-control-btn:hover{background:var(--interactive-hover)}.menu-control-btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.mode-switcher{display:flex;justify-content:center;gap:1.2rem;margin-bottom:.75rem;border-bottom:1px solid var(--border)}.mode-tab{position:relative;padding:.5rem 0;border:none;background:none;color:var(--text-muted);font:inherit;font-size:.82rem;letter-spacing:.02em;cursor:pointer;min-height:44px;transition:color .2s ease}.mode-tab:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent);border-radius:1px;opacity:0;transition:opacity .2s ease}.mode-tab.active{color:var(--text);font-weight:500}.mode-tab.active:after{opacity:1}.mode-tab:hover:not(.active){color:var(--text-secondary)}.mode-tab:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){.mode-tab,.mode-tab:after{transition:none}}.mode-confirm-btn--primary:hover{background:var(--accent-hover)}@media(prefers-reduced-motion:reduce){.focus-input,.notes{transition:none}}
