: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: #D4A85D;--accent-subtle: rgba(212, 168, 93, .15);--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)}@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:fixed;left:50%;width:min(740px,140vw);top:30%;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:44%;opacity:.4;color:var(--accent, #D4A85D);filter:drop-shadow(0 0 6px rgba(212,168,93,.3)) drop-shadow(0 0 30px rgba(212,168,93,.14)) drop-shadow(0 0 80px rgba(212,168,93,.06));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:.35}25%{stroke-opacity:1}to{stroke-dashoffset:0;stroke-opacity:.85}}.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:.3}to{stroke-dashoffset:0;stroke-opacity:.7}}.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 .auth-section{animation:content-enter-child .8s cubic-bezier(.2,0,.2,1) .15s 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)}}.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:.4;filter:drop-shadow(0 0 6px rgba(184,134,59,.25)) drop-shadow(0 0 30px rgba(184,134,59,.1)) drop-shadow(0 0 80px rgba(184,134,59,.05))}@media(min-width:820px){.splash-maze{width:min(780px,120vw);top:32%}.splash-maze--drawing{width:min(480px,52vw);top:44%}}@media(prefers-reduced-motion:reduce){.splash-maze{transition:none}.splash-maze--drawing{opacity:.08;color:#5a6889;width:min(740px,140vw);top:30%;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{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 .auth-section,.content-layer.content-entering .content-focus-target{animation:none;opacity:1}}.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-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}.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-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}.mode-cards{margin-top:1rem;display:grid;gap:.5rem}.mode-card{display:flex;flex-direction:column;gap:.2rem;text-align:left;background:var(--interactive);border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem;color:var(--text);font:inherit;cursor:pointer;transition:background .15s;position:relative}.mode-card:hover{background:var(--interactive-hover)}.mode-card:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media(prefers-reduced-motion:reduce){.mode-card{transition:none}}.mode-card-title{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}.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:flex-start;justify-content:center;margin-bottom:.85rem}.top-bar-spacer{flex:1;min-width:0}.logo-button{margin:.05rem 0 0;padding:0;border:none;background:none;cursor:pointer}.logo{width:min(210px,44vw);object-fit:contain;opacity:.99;filter:drop-shadow(0 8px 16px var(--shadow-logo))}.logo-button:focus-visible,.menu-toggle:focus-visible,.menu-item:focus-visible,.auth-welcome: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}.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}}.auth-section{margin-bottom:.85rem;padding-bottom:.85rem;border-bottom:1px solid var(--border);min-height:2.6rem}.auth-user-row{position:relative;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.auth-welcome{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);letter-spacing:.01em;cursor:pointer;text-align:left}.auth-welcome:hover{color:var(--text)}.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)}.auth-sign-in-btn{background:none;border:1px solid var(--border-hover);border-radius:10px;color:var(--text-secondary);font:inherit;font-size:.82rem;padding:.45rem .9rem;min-height:44px;cursor:pointer;letter-spacing:.02em}.auth-sign-in-btn:hover{background:var(--interactive-hover);color:var(--text)}.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)}.top-bar-end{flex:1;display:flex;justify-content:flex-end;min-width:0}.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)}html.light .logo{filter:brightness(.45) contrast(1.1) drop-shadow(0 8px 16px var(--shadow-logo))}@media(prefers-reduced-motion:reduce){.focus-input,.notes{transition:none}}
