#root{min-height:100vh;background:#f0f6f8}body{margin:0;min-height:100vh}.page-center{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.app-shell{width:min(680px,100%);margin:0 auto;min-height:100vh;background:transparent;padding:20px 16px 28px}.top-bar{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;margin-bottom:8px}.app-icon{width:88px;height:60px;object-fit:contain;justify-self:center;grid-column:2}.icon-button{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:#e6e6e64d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;box-shadow:0 4px 16px #0000001f,0 1px 4px #0000000f,inset 0 1px #fff9}.new-task-form{margin-bottom:20px}.new-task-form input{width:100%;height:46px;border:1px solid rgba(255,255,255,.4);border-radius:24px;padding:0 16px;background:#e6e6e64d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 16px #0000001f,0 1px 4px #0000000f,inset 0 1px #fff9}.task-list{display:grid;gap:10px}.task-card{display:flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.4);border-radius:8px;background:#e6e6e64d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:8px 10px;overflow:hidden;box-shadow:0 4px 16px #0000001f,0 1px 4px #0000000f,inset 0 1px #fff9}.task-checkbox{width:18px;height:18px;flex-shrink:0;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;border:1px solid #aaa;background:#aaa;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative}.task-checkbox:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;color:#ffffffd9;font-weight:500;-webkit-text-stroke:.5px rgba(255,255,255,.85)}.task-checkbox:checked{background:#8f5bd8;border-color:#8f5bd8}.task-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;font-weight:500;-webkit-text-stroke:.5px #fff;color:#fff}.task-title{font-size:16px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1;color:#444}.task-date{font-size:14px;white-space:nowrap;margin-left:12px;flex-shrink:0;color:#444}.task-card--done .task-title,.task-card--done .task-date{color:#9f9f9f;text-decoration:line-through}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000061;display:grid;place-items:center;padding:16px}.modal{width:min(520px,100%);background:#fff;border-radius:14px;padding:20px}.modal h2{margin:0 0 14px}.modal-form{display:grid;gap:12px}.modal-form label{display:grid;gap:6px}.modal-form input,.modal-form select{height:42px;border:1px solid #ccc;border-radius:8px;padding:0 10px}.modal-actions{display:flex;justify-content:flex-end;gap:8px}@media (max-width: 768px){.app-shell{padding:16px 12px 24px}.task-title{font-size:15px}.task-date{font-size:13px}}.task-drag-handle{cursor:grab;padding:0 4px;color:#aaa;flex-shrink:0}.task-drag-handle:before{content:"⠿"}.task-drag-handle:active{cursor:grabbing}.login-container{display:flex;flex-direction:column;align-items:center;gap:24px}.login-icon{width:120px;height:120px;object-fit:contain;margin-bottom:12px}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:100}.side-menu{position:fixed;top:0;left:0;height:100%;width:260px;background:#fff9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:24px 16px;box-shadow:4px 0 24px #0000001a;animation:slideIn .2s ease}.side-menu ul{list-style:none;padding:0;margin:24px 0 0}.side-menu li{padding:12px 8px;cursor:pointer;border-radius:8px}.side-menu li:hover{background:#fff6}.menu-close{background:none;border:none;font-size:18px;cursor:pointer;padding:0}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.journal-form{margin-top:24px}.journal-input-wrapper{position:relative}.journal-input{width:100%;min-height:48px;border:1px solid rgba(255,255,255,.4);border-radius:8px;padding:12px 16px;background:#e6e6e64d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-size:15px;color:#333;box-sizing:border-box;outline:none;line-height:1.5;word-break:break-all;box-shadow:0 4px 16px #0000001f,0 1px 4px #0000000f,inset 0 1px #fff9}.journal-input:before{content:"";float:right;width:44px;height:1.5em}.journal-input::placeholder{color:#aaa}.journal-input:empty:after{content:attr(data-placeholder);color:#aaa;pointer-events:none}.journal-input:focus{outline:none;border-color:#ffffffb3}.journal-submit{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:#ffffff4d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#333;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.journal-submit:disabled{opacity:.4;cursor:default}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:10px 20px;border-radius:24px;font-size:14px;white-space:nowrap;z-index:200;animation:fadeInOut 2s ease forwards}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(8px)}15%{opacity:1;transform:translate(-50%) translateY(0)}75%{opacity:1}to{opacity:0}}.calendar{margin-bottom:24px}.calendar-nav{display:flex;align-items:center;gap:16px;margin-bottom:12px}.calendar-nav-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#444}.calendar-title{font-size:16px;font-weight:600;color:#444}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-dow{text-align:center;font-size:12px;color:#888;padding:4px 0}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:16.25px;color:#444;cursor:pointer;transition:opacity .15s;transform:scale(.8)}.calendar-day--selected{outline:2px solid #8f5bd8;outline-offset:1px}.calendar-day--today{font-weight:1000}.journal-list{display:grid;gap:12px}.journal-list-empty{color:#aaa;font-size:14px;text-align:center}.journal-list-item{display:flex;gap:12px;align-items:flex-start;padding:10px 14px;border-radius:8px;background:#e6e6e64d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.4);box-shadow:0 4px 16px #0000001f,0 1px 4px #0000000f,inset 0 1px #fff9}.journal-list-time{font-size:13px;color:#888;white-space:nowrap;flex-shrink:0}.journal-list-content{font-size:15px;color:#444;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-width:320px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f2f2f2;color:#222}button,input,select{font:inherit}
