:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:300;color:#ffffffde;background-color:#1e1e1e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text-primary: #ccc;--text-secondary: #888;--text-muted: #666;--text-strong: #bbb;--border-subtle: #444;--border-strong: #555;--border-focus: #888;--border-readonly: #333;--input-border: #444;--input-border-focus: #888;--placeholder-color: #555;--surface-hover: rgba(136, 136, 136, .1);--surface-hover-strong: rgba(136, 136, 136, .15);--surface-card: rgba(30, 30, 30, .95)}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100dvh;box-sizing:border-box}h1{font-size:3.2em;line-height:1.1}button{border-radius:12px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:400;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:background-color .25s,border-color .25s;touch-action:manipulation}button:hover{border-color:transparent}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.site-footer{margin-top:3rem;padding:1.5rem 0;text-align:center}.site-footer p{font-size:.8rem;color:var(--text-secondary);margin:0}.footer-link{color:var(--text-secondary);text-decoration:none;font-weight:300}.footer-link:hover{color:inherit}.profile-menu{position:absolute;top:max(1rem,env(safe-area-inset-top));right:max(1rem,env(safe-area-inset-right));z-index:100}.profile-btn{width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-strong);border-radius:50%;color:var(--text-secondary);cursor:pointer}.profile-btn:hover{color:inherit;border-color:var(--border-focus)}.profile-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:160px;max-width:calc(100vw - 2rem);background:#2a2a2a;border:1px solid var(--border-subtle);border-radius:12px;padding:.25rem;animation:profileFadeIn .15s ease}@keyframes profileFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.profile-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:transparent;border:none;border-radius:8px;color:var(--text-primary);font-size:.85rem;cursor:pointer;text-decoration:none}.profile-dropdown-item:hover{background:var(--surface-hover-strong);color:inherit;border-color:transparent}.profile-dropdown-item--btn{font-family:inherit;font-size:.85rem;font-weight:400;text-align:left}:root[data-theme=light]{color:#213547;background-color:#f5f2ee;--text-primary: #213547;--text-secondary: #666;--text-muted: #aaa;--text-strong: #333;--border-subtle: #ddd;--border-strong: #ccc;--border-focus: #999;--border-readonly: #e5e5e5;--input-border: #ccc;--input-border-focus: #999;--placeholder-color: #aaa;--surface-hover: rgba(0, 0, 0, .04);--surface-hover-strong: rgba(0, 0, 0, .06);--surface-card: rgba(245, 245, 245, .95)}:root[data-theme=light] a:hover{color:#747bff}:root[data-theme=light] button{background-color:#f9f9f9}:root[data-theme=light] .profile-dropdown{background:#fff;box-shadow:0 4px 16px #0000001a}.virtue-pills{display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap;margin-top:.75rem}.virtue-pill{font-size:.65rem;padding:.15rem .5rem;border-radius:9999px;border:none;text-transform:uppercase;letter-spacing:.04em;font-weight:500}.virtue-filter{display:flex;gap:.5rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center}.virtue-filter .virtue-pill{font-size:.75rem;padding:.3rem .75rem;min-height:44px;display:inline-flex;align-items:center;cursor:pointer;opacity:.5;transition:opacity .2s ease}.virtue-filter .virtue-pill.active{opacity:1}.virtue-filter .virtue-pill:hover{opacity:.8}.virtue-all{background:#aaaaaa40;color:#aaa}.virtue-courage{background:#eb969640;color:#e8a0a0}.virtue-justice{background:#96b4eb40;color:#a0b8e8}.virtue-temperance{background:#96d7aa40;color:#a0d8b0}.virtue-wisdom{background:#e6d28c40;color:#d8c880}:root[data-theme=light] .virtue-all{background:#6464641f;color:#777}:root[data-theme=light] .virtue-courage{background:#c850501f;color:#b04040}:root[data-theme=light] .virtue-justice{background:#4664b41f;color:#4060a0}:root[data-theme=light] .virtue-temperance{background:#32a05a1f;color:#2e8050}:root[data-theme=light] .virtue-wisdom{background:#b4a0321f;color:#8a7a20}.landing{display:flex;flex-direction:column;align-items:center;min-height:100dvh;padding:2rem;padding-left:max(2rem,env(safe-area-inset-left));padding-right:max(2rem,env(safe-area-inset-right));padding-bottom:max(2rem,env(safe-area-inset-bottom));box-sizing:border-box}.landing-header{margin-top:4rem;text-align:center}.landing-header h1{font-size:3.2rem;font-weight:200;margin:0}.landing-tagline{font-size:1rem;font-weight:300;color:#888;margin:.5rem 0 0}.landing-section{width:100%;max-width:600px;margin-top:2rem}.landing-section-title{font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:#666;margin:0 0 1rem;text-align:center}.landing-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;width:100%;max-width:600px}.feature-card{display:flex;flex-direction:column;padding:2rem;border-radius:12px;border:1px solid #888;text-decoration:none;color:inherit;text-align:center;transition:background .2s ease,border-color .2s ease}.feature-card:hover{background:#8888881a;border-color:#88888880;color:inherit}.feature-card-icon{font-size:2.5rem;margin-bottom:.75rem}.feature-card h3{font-size:1.2rem;font-weight:400;margin:0 0 .5rem}.feature-card p{font-size:.9rem;color:#888;margin:0;line-height:1.4;flex:1}.landing-history-link{display:block;margin-top:1.5rem;font-size:.85rem;color:var(--text-secondary);text-decoration:none;text-align:center}.landing-history-link:hover{color:var(--text-strong);text-decoration:underline;text-underline-offset:2px}@media(max-width:500px){.landing-header{margin-top:2rem}.landing-header h1{font-size:2.2rem}.landing-features{grid-template-columns:1fr;gap:1rem}.feature-card{padding:1.5rem}}.tool-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh}.tool-loading-spinner{width:28px;height:28px;border:2px solid var(--border-subtle);border-top-color:var(--text-secondary);border-radius:50%;animation:tool-spin .7s linear infinite}@keyframes tool-spin{to{transform:rotate(360deg)}}.tool-page{margin:0 auto;padding:4rem 2rem;min-height:100dvh;box-sizing:border-box}.tool-page--standard{max-width:600px}.tool-nav{position:absolute;top:max(1rem,env(safe-area-inset-top));left:max(1rem,env(safe-area-inset-left));right:calc(max(1rem,env(safe-area-inset-right)) + 3rem);display:flex;justify-content:space-between;align-items:center;z-index:50}.home-link{font-size:.9rem;color:var(--text-secondary);text-decoration:none}.home-link:hover{color:inherit}.tool-title{font-size:1.8rem;font-weight:200;margin:0 0 .5rem;text-align:center}.tool-subtitle{font-size:.95rem;font-weight:300;font-style:italic;color:var(--text-secondary);margin:0 0 1rem;text-align:center}.tool-input{font-family:inherit;font-size:.95rem;font-weight:300;padding:.75rem 1rem;border-radius:12px;border:1px solid var(--input-border);background:transparent;color:inherit}.tool-input::placeholder{color:var(--placeholder-color)}.tool-input:focus{outline:none;border-color:var(--input-border-focus)}.tool-textarea{font-family:inherit;font-size:.95rem;font-weight:300;padding:.75rem 1rem;border-radius:12px;border:1px solid var(--input-border);background:transparent;color:inherit;resize:vertical;line-height:1.5}.tool-textarea::placeholder{color:var(--placeholder-color)}.tool-textarea:focus{outline:none;border-color:var(--input-border-focus)}.tool-textarea[readonly]{border-color:var(--border-readonly);cursor:default}.tool-textarea[readonly]:focus{border-color:var(--border-readonly)}.tool-btn{padding:.5rem 1.2rem;font-size:.85rem;border:1px solid var(--border-strong);background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:12px}.tool-btn:hover{background:var(--surface-hover);border-color:var(--border-focus)}.tool-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.tool-btn:disabled{opacity:.5;cursor:default}.tool-btn--green{color:#a8d5a2;border-color:#a8d5a24d}.tool-btn--green:hover{background:#a8d5a214;border-color:#a8d5a2}.tool-btn--amber{color:#d4c87a;border-color:#d4c87a4d}.tool-btn--amber:hover{background:#d4c87a14;border-color:#d4c87a}.tool-btn--danger{color:#f4a7a7;border-color:#f4a7a74d}.tool-btn--danger:hover:not(:disabled){background:#f4a7a714;border-color:#f4a7a7}.tool-section-label{font-size:.85rem;font-weight:400}.tool-input-row{display:flex;gap:.5rem;margin-bottom:2rem}.tool-input-row .tool-input{flex:1}.tool-add-btn{padding:.5rem 1.2rem;border:1px solid var(--input-border);background:transparent;color:inherit;cursor:pointer;font-size:.85rem;border-radius:12px}.tool-add-btn:hover:not(:disabled){background:var(--surface-hover-strong);border-color:var(--border-focus)}.tool-add-btn:disabled{opacity:.5;cursor:default}.tool-items{display:flex;flex-direction:column;gap:.75rem}.tool-card{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;border-radius:12px;border:1px solid rgba(168,184,213,.15)}.tool-card--enter{animation:toolCardEnter .3s ease}@keyframes toolCardEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tool-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.tool-card-title{font-size:.95rem;font-weight:400;color:#a8b8d5;word-break:break-word}.tool-textarea--inline{font-family:inherit;font-size:.8rem;font-weight:300;font-style:italic;padding:.4rem .6rem;border-radius:8px;border:1px solid transparent;background:transparent;color:#a8b8d5;resize:none;overflow:hidden;width:100%;box-sizing:border-box}.tool-textarea--inline::placeholder{color:#a8b8d566;font-style:italic}.tool-textarea--inline:focus{outline:none;border-color:#a8b8d54d}.tool-remove-btn{background:none;border:none;color:#666;font-size:1.2rem;cursor:pointer;padding:0 .25rem;line-height:1;flex-shrink:0;margin-left:auto}.tool-remove-btn:hover{color:#aaa}.tool-textarea--autoresize{resize:none;overflow:hidden}:root[data-theme=light] .tool-btn--green{color:#4a9;border-color:#44aa994d}:root[data-theme=light] .tool-btn--green:hover{border-color:#4a9;background:#44aa990f}:root[data-theme=light] .tool-btn--amber{color:#b59a2e;border-color:#b59a2e4d}:root[data-theme=light] .tool-btn--amber:hover{border-color:#b59a2e;background:#b59a2e0f}:root[data-theme=light] .tool-btn--danger{color:#c66;border-color:#cc66664d}:root[data-theme=light] .tool-btn--danger:hover:not(:disabled){border-color:#c66;background:#cc66660f}.tool-date-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:2rem}.tool-date-nav-center{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:160px}.tool-date-nav-btn{background:transparent;border:1px solid var(--border-strong);border-radius:12px;color:var(--text-secondary);font-size:1rem;cursor:pointer;padding:.4rem .8rem;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;line-height:1}.tool-date-nav-btn:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-focus)}.tool-date-nav-btn:disabled{opacity:.3;cursor:default}.tool-date-nav-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.tool-date-nav-date{font-size:1rem;font-weight:300;color:var(--text-secondary);margin:0;text-align:center}.tool-date-nav-actual{font-size:.75rem;font-weight:300;color:var(--text-muted)}.tool-today-link{background:none;border:none;color:var(--text-secondary);font-size:.75rem;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.tool-today-link:hover{color:var(--text-strong)}.tool-intro{text-align:center;font-size:.85rem;font-weight:300;color:var(--text-secondary);margin:0 auto 2rem;max-width:500px;line-height:1.5}.tool-empty-hint{text-align:center;font-size:.85rem;font-weight:300;font-style:italic;color:var(--text-muted);margin:0 auto;max-width:400px;line-height:1.5}.tool-undo-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-radius:10px;background:var(--surface-card);border:1px solid var(--border-subtle);color:var(--text-primary);font-size:.85rem;font-weight:300;z-index:100;animation:toastIn .25s ease;max-width:90vw}.tool-undo-btn{background:none;border:1px solid rgba(168,184,213,.3);color:#a8b8d5;padding:.25rem .6rem;border-radius:6px;font-size:.8rem;cursor:pointer;white-space:nowrap}.tool-undo-btn:hover{background:#a8b8d514;border-color:#a8b8d5}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tool-history-link{margin-top:2rem;text-align:center}.tool-history-link a{color:var(--text-secondary);font-size:.85rem;text-decoration:none}.tool-history-link a:hover{color:var(--text-strong);text-decoration:underline;text-underline-offset:2px}:root[data-theme=light] .tool-card{border-color:#5a7ab033}:root[data-theme=light] .tool-card-title{color:#5a7ab0}:root[data-theme=light] .tool-textarea--inline{color:#5a7ab0}:root[data-theme=light] .tool-textarea--inline::placeholder{color:#5a7ab066}:root[data-theme=light] .tool-textarea--inline:focus{border-color:#5a7ab04d}:root[data-theme=light] .tool-remove-btn{color:#bbb}:root[data-theme=light] .tool-remove-btn:hover{color:#888}:root[data-theme=light] .tool-undo-btn{color:#5a7ab0;border-color:#5a7ab04d}:root[data-theme=light] .tool-undo-btn:hover{background:#5a7ab00f;border-color:#5a7ab0}@media(max-width:600px){.tool-page{padding:3.5rem 1.5rem 3rem}.tool-input,.tool-textarea{font-size:1rem}.tool-btn{min-height:44px}.tool-title{font-size:1.5rem}}.tool-save-status{position:fixed;top:max(1rem,env(safe-area-inset-top));left:50%;transform:translate(-50%);font-size:.75rem;padding:.25rem .75rem;border-radius:8px;border:1px solid;pointer-events:none;z-index:200;animation:toastIn .2s ease}.tool-save-status--saved{color:#7eb87e;border-color:#7eb87e4d;background:#7eb87e14}.tool-save-status--error{color:#e07070;border-color:#e070704d;background:#e0707014}.tool-error-banner{margin:1rem 0;padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(224,112,112,.3);background:#e0707014;color:#e07070;font-size:.85rem;text-align:center}@media(max-width:600px)and (orientation:landscape){.tool-page{padding-top:3rem;padding-bottom:2rem}.tool-title{font-size:1.3rem;margin-bottom:.25rem}.tool-subtitle{font-size:.85rem;margin-bottom:1rem}}
