:root{--bg-page:#f5f4f0;--bg-surface:#fff;--bg-faint:#faf9f7;--bg-muted:#f0efe9;--text-1:#1a1a18;--text-2:#888780;--text-3:#b4b2a9;--text-4:#ccc9bf;--border:#d3d1c7;--border-2:#e8e6df;--accent:#7f77dd;--accent-2:#6b63c9;--accent-3:#534ab7;--accent-4:#eeedfe;--accent-5:#faf9ff;--accent-mid:#c5c2f5;--font:system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden}body{background:var(--bg-page);color:var(--text-1);max-width:100vw;font-family:system-ui,-apple-system,sans-serif;overflow-x:hidden}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit}#app{max-width:100vw;min-height:100vh;overflow-x:hidden}.auth-wrap{min-height:100vh;display:flex}.auth-left{color:#fff;background:#1a1a18;flex-direction:column;flex:1;justify-content:space-between;min-height:100vh;padding:2.5rem 3rem;display:flex}.auth-brand{align-items:center;gap:10px;display:flex}.auth-brand-icon{font-size:22px}.auth-brand-name{color:#fff;letter-spacing:-.3px;font-size:18px;font-weight:600}.auth-intro{flex-direction:column;flex:1;justify-content:center;padding:3rem 0;display:flex}.auth-intro-headline{color:#fff;letter-spacing:-1.5px;margin-bottom:1.25rem;font-size:48px;font-weight:300;line-height:1.15}.auth-intro-sub{color:var(--text-2);max-width:420px;margin-bottom:2.5rem;font-size:15px;line-height:1.7}.auth-features{flex-direction:column;gap:1rem;display:flex}.auth-feature{align-items:flex-start;gap:14px;display:flex}.auth-feature-icon{flex-shrink:0;margin-top:1px;font-size:20px}.auth-feature div{flex-direction:column;gap:1px;display:flex}.auth-feature strong{color:var(--border-2);font-size:13px;font-weight:600}.auth-feature span{color:var(--text-2);font-size:12px}.auth-right{background:var(--bg-page);flex-direction:column;flex-shrink:1;justify-content:center;align-items:center;width:460px;max-width:100%;min-height:100vh;padding:2.5rem 2rem;display:flex}.auth-card{background:var(--bg-surface);border:.5px solid var(--border);border-radius:16px;flex-direction:column;gap:1.25rem;width:100%;max-width:380px;padding:1.75rem;display:flex}.auth-card-brand{text-align:center;padding-bottom:.25rem}.auth-card-brand-name{letter-spacing:-.03em;color:var(--accent);font-size:2rem;font-weight:800;line-height:1}.auth-card-brand-tagline{letter-spacing:.08em;color:#999;text-transform:lowercase;margin-top:3px;font-size:.75rem;font-weight:400}.auth-tabs{background:var(--bg-page);border-radius:10px;gap:4px;padding:4px;display:flex}.auth-tabs--hidden{display:none}.auth-tab{cursor:pointer;color:var(--text-2);background:0 0;border-radius:8px;flex:1;padding:8px;font-size:13px;font-weight:500;transition:background .12s,color .12s}.auth-tab.active{background:var(--bg-surface);color:var(--text-1);box-shadow:0 1px 3px #00000014}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-form--hidden{display:none}.auth-field{flex-direction:column;gap:5px;display:flex}.auth-label{color:var(--text-2);font-size:12px;font-weight:500}.auth-label-row{justify-content:space-between;align-items:center;display:flex}.auth-input-wrap{position:relative}.auth-input{border:.5px solid var(--text-3);background:var(--bg-page);width:100%;color:var(--text-1);border-radius:9px;outline:none;padding:9px 12px;font-size:13px;transition:border-color .15s,background .15s}.auth-input:focus{border-color:var(--accent);background:var(--bg-surface)}.auth-input-wrap .auth-input{padding-right:38px}.auth-eye{color:var(--text-3);cursor:pointer;font-size:15px;line-height:1;transition:color .12s;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.auth-eye:hover{color:var(--text-1)}.auth-strength{background:var(--border-2);border-radius:99px;height:3px;margin-top:6px;overflow:hidden}.auth-strength-fill{border-radius:99px;width:0;height:100%;transition:width .3s,background .3s}.auth-strength-label{margin-top:3px;font-size:11px}.auth-msg{text-align:center;min-height:1em;font-size:12px;display:block}.auth-msg--error{color:#993c1d}.auth-msg--ok{color:#3b6d11}.auth-submit{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:.01em;border-radius:9px;width:100%;padding:11px;font-size:14px;font-weight:600;transition:background .12s}.auth-submit:hover{background:var(--accent-2)}.auth-submit:disabled{opacity:.6;cursor:default}.auth-link{color:var(--accent);cursor:pointer;background:0 0;font-size:12px;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-terms{color:var(--text-3);text-align:center;font-size:11px;line-height:1.5}.auth-reset-info{color:var(--text-2);font-size:13px;line-height:1.6}.auth-back{color:var(--text-2);cursor:pointer;text-align:center;margin-top:-6px;font-size:12px;transition:color .12s;display:block}.auth-back:hover{color:var(--text-1)}.auth-footer{color:var(--text-3);text-align:center;margin-top:1.25rem;font-size:12px}@media (width<=860px){.auth-left{display:none}.auth-right{width:100%}}@media (width<=480px){.auth-right{padding:1.5rem 1rem}}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-surface);border-right:.5px solid var(--border);z-index:200;flex-direction:column;flex-shrink:0;width:220px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:.5px solid var(--border);align-items:center;gap:10px;height:56px;padding:1rem 1.25rem;display:flex}.brand-text{color:var(--text-1);font-size:15px;font-weight:500}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.nav-item{width:100%;color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:var(--bg-page);color:var(--text-1)}.nav-item.active{background:var(--bg-muted);color:var(--text-1)}.nav-item.dragging{opacity:.4}.nav-item.drag-over{background:var(--border-2);color:var(--text-1);outline:1.5px dashed var(--text-3);outline-offset:-2px}.nav-drag-handle{color:var(--text-4);cursor:grab;opacity:.3;flex-shrink:0;font-size:14px;line-height:1;transition:opacity .15s}.nav-item:hover .nav-drag-handle{opacity:1}.nav-drag-handle:active{cursor:grabbing}.nav-icon{flex-shrink:0;font-size:16px}.sidebar-footer{border-top:.5px solid var(--border);flex-direction:column;align-items:flex-start;gap:4px;padding:8px 8px 12px;display:flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.mobile-bar{background:var(--bg-surface);border-bottom:.5px solid var(--border);z-index:150;justify-content:space-between;align-items:center;height:48px;padding:0 1rem;display:none;position:sticky;top:0}.hamburger{color:var(--text-2);font-size:18px}.main-area{flex-direction:column;flex:1;min-height:100vh;margin-left:220px;display:flex}.topbar{background:var(--bg-surface);border-bottom:.5px solid var(--border);z-index:100;align-items:center;gap:12px;height:56px;padding:0 1.5rem;display:flex;position:sticky;top:0}.topbar-title{color:var(--text-1);letter-spacing:-.2px;flex:1;font-size:16px;font-weight:700}.topbar-actions{align-items:center;gap:8px;display:flex}.search-bar{background:var(--bg-page);border:.5px solid var(--text-3);border-radius:8px;align-items:center;gap:6px;padding:5px 10px;display:flex}.search-bar input{color:var(--text-1);background:0 0;border:none;outline:none;width:160px;font-size:13px}.search-bar input::placeholder{color:var(--text-3)}.icon-btn{border:.5px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background .12s;display:flex}.icon-btn:hover{background:var(--bg-page)}#view-content{flex:1}.view-wrap{max-width:900px;margin:0 auto;padding:1.5rem}.view-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.view-title{color:var(--text-1);letter-spacing:-.3px;font-size:20px;font-weight:700}.tab-bar{background:var(--bg-muted);border-radius:8px;gap:2px;width:fit-content;margin-bottom:1rem;padding:3px;display:flex}.tab-btn{color:var(--text-2);white-space:nowrap;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .12s}.tab-btn:hover{color:var(--text-1)}.tab-btn.active{background:var(--bg-surface);color:var(--text-1);box-shadow:0 1px 3px #00000012}.stats-bar{flex-wrap:wrap;gap:16px;margin-bottom:1rem;display:flex}.stat-chip{color:var(--text-2);font-size:13px}.stat-chip strong{color:var(--text-1)}.btn-action{background:var(--accent);color:#fff;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:500;transition:opacity .12s}.btn-action:hover{opacity:.88}.btn-secondary{border:.5px solid var(--text-3);color:var(--text-1);background:var(--bg-surface);border-radius:8px;padding:6px 12px;font-size:13px;transition:background .12s}.btn-secondary:hover{background:var(--bg-page)}.tag-badge{border-radius:999px;padding:2px 9px;font-size:11px;font-weight:500;display:inline-block}.empty-msg{color:var(--text-3);text-align:center;padding:2rem 0;font-size:13px}.row-del{color:var(--text-3);opacity:0;padding:0 3px;font-size:16px;line-height:1;transition:opacity .12s}.row-del:hover{color:#e24b4a}.board-wrap{max-width:1200px;margin:0 auto;padding:1.5rem}.week-bar{background:var(--bg-surface);border:1px solid #00000012;border-radius:12px;margin-bottom:1.5rem;padding:1rem 1.25rem;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 4px #0000000d}.week-bar.drag-over{border-color:var(--accent);box-shadow:0 0 0 3px #7f77dd26}.week-header{align-items:center;margin-bottom:10px;display:flex}.week-bar h2{color:var(--text-1);letter-spacing:.02em;text-transform:uppercase;font-size:13px;font-weight:600}.week-header-meta{align-items:center;gap:8px;margin-left:auto;display:flex}.week-count{color:var(--text-2);background:var(--bg-page);border:.5px solid var(--border);font-variant-numeric:tabular-nums;border-radius:999px;padding:2px 8px;font-size:11px}.week-progress-wrap{background:var(--bg-muted);border-radius:999px;height:3px;margin-bottom:12px;overflow:hidden}.week-progress-bar{background:var(--accent);border-radius:999px;min-width:0;height:100%;transition:width .3s}.week-progress-bar.complete{background:#5aad6f}.week-tasks{flex-direction:column;gap:2px;margin-bottom:8px;display:flex}.week-empty{color:var(--text-3);padding:10px 4px;font-size:12px}.week-item{cursor:default;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:8px;padding:7px 6px;transition:background .1s;display:flex}.week-item:hover{background:#f7f6f2}.week-drag-handle{cursor:grab;color:var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:12px;line-height:1}.week-drag-handle:active{cursor:grabbing}.week-item:hover .week-drag-handle{color:var(--text-2)}.week-bullet{background:var(--accent-4);width:18px;height:18px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:flex}.week-item.done .week-bullet{background:var(--bg-muted);color:var(--text-3)}.week-item input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:14px;height:14px}.week-item-text{color:var(--text-1);flex:1;font-size:13px;line-height:1.4}.week-item.done .week-item-text{color:var(--text-3);text-decoration:line-through}.week-item-del{opacity:0;color:var(--text-3);flex-shrink:0;padding:0 2px;font-size:15px;line-height:1;transition:opacity .12s}.week-item:hover .week-item-del{opacity:1}.week-item-del:hover{color:#e24b4a}.week-item.dragging{opacity:.35}.week-item.drag-week-above{border-top:2px solid var(--accent)}.week-item.drag-week-below{border-bottom:2px solid var(--accent)}.week-add-row{border-top:.5px solid #f0eeea;gap:6px;padding-top:6px;display:flex}.week-add-row input{border:.5px solid var(--border);background:var(--bg-faint);color:var(--text-1);border-radius:8px;outline:none;flex:1;padding:6px 10px;font-size:13px;transition:border-color .15s}.week-add-row input:focus{border-color:var(--accent);background:var(--bg-surface)}.week-add-row button{background:var(--accent);color:#fff;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:500;transition:background .12s}.week-add-row button:hover{background:var(--accent-2)}.sections{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;display:grid}.section{background:var(--bg-surface);border:1px solid #00000012;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000d}.section-header{border-bottom:.5px solid var(--border);align-items:center;gap:8px;padding:.75rem 1rem;display:flex}.section-icon{font-size:16px}.section-title{color:var(--text-1);flex:1;font-size:14px;font-weight:500}.section-count{background:var(--bg-page);color:var(--text-2);border:.5px solid var(--border);border-radius:999px;padding:2px 8px;font-size:12px}.section-header-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.section-header-clickable:hover{background:var(--bg-faint)}.section-chevron{color:var(--text-3);margin-left:6px;font-size:14px;transition:transform .2s;display:inline-block;transform:rotate(90deg)}.section-chevron.collapsed{transform:rotate(0)}.task-list{padding:8px}.sub-label{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;padding:6px 8px 2px;font-size:11px;font-weight:500}.task{border-radius:8px;align-items:flex-start;gap:8px;padding:6px 8px;transition:background .12s;display:flex}.task:hover{background:var(--bg-page)}.task:hover .row-del,.task:hover .add-week-btn{opacity:1}.task.dragging{opacity:.35}.task.drag-over-above{border-top:2px solid var(--accent)}.task.drag-over-below{border-bottom:2px solid var(--accent)}.drag-handle{cursor:grab;color:var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;margin-top:2px;padding:0 1px;font-size:13px;line-height:1}.drag-handle:active{cursor:grabbing}.task:hover .drag-handle{color:var(--text-2)}.task input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:14px;height:14px;margin-top:2px}.task-text{color:var(--text-1);cursor:pointer;-webkit-user-select:none;user-select:none;flex:1;font-size:13px;line-height:1.45}.task.done .task-text{color:var(--text-3);text-decoration:line-through}.del-btn{opacity:0;color:var(--text-3);flex-shrink:0;padding:0 2px;font-size:16px;line-height:1;transition:opacity .12s}.task:hover .del-btn{opacity:1}.del-btn:hover{color:#e24b4a}.add-week-btn{opacity:0;border:.5px solid var(--text-3);color:var(--text-2);border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:10px;transition:opacity .1s}.add-week-btn:hover{background:var(--bg-page)}.badge-urgent{color:#993c1d;vertical-align:middle;background:#faece7;border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-someday{color:#5f5e5a;background:#f1efe8;border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-batch{background:var(--accent-4);color:var(--accent-3);border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-priority-high{color:#993c1d;background:#faece7;border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-priority-medium{color:#854f0b;background:#faeeda;border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-priority-low,.badge-recurring{color:#3b6d11;background:#eaf3de;border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-due{background:var(--bg-page);color:var(--text-2);border-radius:999px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:500;display:inline-block}.badge-due.overdue{color:#993c1d;background:#faece7}.divider{background:var(--border);height:.5px;margin:4px 8px}.add-row{gap:6px;padding:4px 8px 8px;display:flex}.add-row input{border:.5px solid var(--text-3);background:var(--bg-page);min-width:0;color:var(--text-1);border-radius:8px;outline:none;flex:1;padding:5px 8px;font-size:13px}.add-row input:focus{border-color:var(--text-2);background:var(--bg-surface)}.add-row button{border:.5px solid var(--text-3);color:var(--text-1);white-space:nowrap;background:0 0;border-radius:8px;padding:5px 12px;font-size:13px}.add-row button:hover{background:var(--bg-page)}.fab{background:var(--accent);color:#fff;z-index:300;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:28px;line-height:1;transition:background .15s,transform .15s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 18px #7f77dd59}.fab:hover{background:var(--accent-2);transform:scale(1.07)}.fab:active{transform:scale(.95)}.modal-backdrop{z-index:400;background:#00000038;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-backdrop.open{display:flex}.modal{background:var(--bg-surface);border-radius:14px;width:380px;max-width:calc(100vw - 2rem);padding:1.5rem;box-shadow:0 8px 40px #00000024}.modal h3{color:var(--text-1);margin-bottom:1rem;font-size:15px;font-weight:600}.modal-field{margin-top:12px}.modal-field:first-of-type{margin-top:0}.modal label{color:var(--text-2);letter-spacing:.05em;text-transform:uppercase;margin-bottom:5px;font-size:11px;font-weight:500;display:block}.modal select,.modal input[type=text],.modal input[type=email],.modal input[type=date]{border:.5px solid var(--text-3);background:var(--bg-page);width:100%;color:var(--text-1);border-radius:8px;outline:none;padding:7px 10px;font-size:13px}.modal select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888780'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-color:var(--bg-page);padding-right:28px}.modal select:focus,.modal input:focus{border-color:var(--accent);background:var(--bg-surface)}.modal-actions{justify-content:flex-end;gap:8px;margin-top:1.25rem;display:flex}.modal-actions button{border:.5px solid var(--text-3);border-radius:8px;padding:7px 16px;font-size:13px;transition:background .12s}.btn-cancel{color:var(--text-2);background:0 0}.btn-cancel:hover{background:var(--bg-page)}.btn-add-task{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:500}.btn-add-task:hover{background:var(--accent-2);border-color:var(--accent-2)}.btn-danger-sm{color:#993c1d;background:#faece7;border:.5px solid #f0c4b4;border-radius:8px;padding:6px 12px;font-size:12px}.btn-cancel-plain{color:var(--text-2);background:0 0;border-radius:8px;padding:6px 12px;font-size:13px}.btn-cancel-plain:hover{background:var(--bg-page)}.focus-overlay{z-index:500;background:#0f0e18;flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0;overflow-y:auto}.focus-label{color:#ffffff47;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.5rem;font-size:10px;font-weight:700}.focus-progress{color:#fff;letter-spacing:-3px;font-variant-numeric:tabular-nums;margin-bottom:.25rem;font-size:64px;font-weight:800;line-height:1}.focus-progress-sub{color:#ffffff59;text-align:center;margin-bottom:2.5rem;font-size:13px}.focus-tasks{flex-direction:column;gap:6px;width:100%;max-width:520px;display:flex}.focus-task{color:#ffffffe6;background:#ffffff0f;border:1px solid #ffffff14;border-radius:14px;align-items:flex-start;gap:14px;padding:15px 20px;font-size:16px;transition:opacity .2s;display:flex}.focus-task input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:18px;height:18px;margin-top:1px}.focus-task.done{opacity:.3}.focus-task.done span{text-decoration:line-through}.focus-exit{color:#ffffff4d;border:1px solid #ffffff1a;border-radius:999px;margin-top:2.5rem;padding:8px 22px;font-size:12px;transition:all .2s}.focus-exit:hover{color:#ffffffb3;background:#ffffff0d;border-color:#ffffff4d}.books-list{flex-direction:column;gap:8px;display:flex}.book-card{background:var(--bg-surface);border:1px solid #00000012;border-radius:10px;align-items:center;gap:12px;padding:.9rem 1rem;transition:box-shadow .12s;display:flex;box-shadow:0 1px 3px #0000000d}.book-card:hover{box-shadow:0 3px 10px #00000017}.book-card:hover .row-del{opacity:1}.book-spine{flex-shrink:0;font-size:24px}.book-info{cursor:pointer;flex:1;min-width:0}.book-title{color:var(--text-1);font-size:14px;font-weight:500}.book-title-link{color:var(--text-1);text-decoration:none}.book-title-link:hover{color:var(--accent);text-decoration:underline}.book-author{color:var(--text-2);margin-top:2px;font-size:12px}.book-notes{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.book-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.book-stars{color:#ba7517;letter-spacing:1px;font-size:12px}.event-name-row{align-items:center;gap:10px;margin-bottom:1rem;display:flex}.event-name-row label{color:var(--text-2);white-space:nowrap;font-size:12px;font-weight:500}.event-name-input{border:.5px solid var(--text-3);background:var(--bg-page);max-width:320px;color:var(--text-1);border-radius:8px;outline:none;flex:1;padding:7px 10px;font-size:14px}.event-name-input:focus{border-color:var(--accent);background:var(--bg-surface)}.guests-list{flex-direction:column;gap:6px;display:flex}.guest-row{background:var(--bg-surface);border:.5px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:.75rem 1rem;display:flex}.guest-row:hover .row-del{opacity:1}.guest-avatar{background:var(--bg-page);width:36px;height:36px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:500;display:flex}.guest-info{flex:1;min-width:0}.guest-name{color:var(--text-1);font-size:14px;font-weight:500}.guest-sub{color:var(--text-2);margin-top:1px;font-size:12px}.rsvp-select{cursor:pointer;border:none;border-radius:999px;flex-shrink:0;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:500}.icon-btn-sm{color:var(--text-3);border-radius:6px;padding:2px 4px;font-size:14px;transition:background .1s}.icon-btn-sm:hover{background:var(--bg-page);color:var(--text-1)}.archive-section{background:var(--bg-surface);border:.5px solid var(--border);border-radius:12px;margin-bottom:1rem;overflow:hidden}.archive-sec-head{border-bottom:.5px solid var(--bg-muted);background:var(--bg-faint);align-items:center;gap:8px;padding:.75rem 1.25rem;display:flex}.archive-sec-icon{font-size:15px}.archive-sec-title{color:var(--text-1);letter-spacing:.02em;text-transform:uppercase;font-size:13px;font-weight:600}.archive-section .sub-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:.5rem 1.25rem .25rem;font-size:11px;font-weight:600}.archive-row{border-bottom:.5px solid #f7f6f2;align-items:center;gap:8px;padding:7px 1.25rem;display:flex}.archive-row:last-child{border-bottom:none}.archive-row input[type=checkbox]{accent-color:var(--accent);flex-shrink:0;width:15px;height:15px}.archive-task-text{color:var(--text-3);flex:1;font-size:13px;text-decoration:line-through}.archive-row .row-del{opacity:0}.archive-row:hover .row-del{opacity:1}.journal-wrap{height:calc(100vh - 56px);display:flex;position:relative;overflow:hidden}.journal-left{border-right:.5px solid var(--border);background:var(--bg-surface);flex-direction:column;flex-shrink:0;width:280px;display:flex}.journal-left-head{border-bottom:.5px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.journal-entry-list{flex:1;overflow-y:auto}.journal-list-item{border-bottom:.5px solid var(--bg-muted);cursor:pointer;padding:.85rem 1.25rem;transition:background .1s}.journal-list-item:hover{background:var(--bg-page)}.journal-list-item.active{background:var(--bg-muted)}.jli-date{color:var(--text-3);margin-bottom:2px;font-size:11px}.jli-title{color:var(--text-1);margin-bottom:2px;font-size:13px;font-weight:500}.jli-preview{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.journal-list-empty{color:var(--text-3);text-align:center;padding:1.5rem;font-size:13px}.journal-right{background:var(--bg-page);flex:1;overflow-y:auto}.journal-empty{height:100%;color:var(--text-3);text-align:center;justify-content:center;align-items:center;padding:2rem;font-size:14px;display:flex}.journal-editor,.journal-viewer{background:var(--bg-surface);border:.5px solid var(--border);border-radius:14px;max-width:680px;margin:2rem auto;padding:2rem}.journal-date{color:var(--text-3);margin-bottom:.75rem;font-size:12px}.journal-title-input{width:100%;color:var(--text-1);background:0 0;border:none;outline:none;margin-bottom:1rem;font-size:22px;font-weight:500}.journal-view-title{color:var(--text-1);margin-bottom:.75rem;font-size:22px;font-weight:500}.mood-bar{gap:6px;margin-bottom:1rem;display:flex}.mood-btn{opacity:.5;border-radius:8px;padding:4px 8px;font-size:20px;transition:background .1s}.mood-btn:hover,.mood-btn.active{opacity:1;background:var(--bg-page)}.mood-badge{background:var(--bg-page);color:var(--text-2);border-radius:999px;margin-bottom:1rem;padding:3px 12px;font-size:13px;display:inline-block}.journal-content{resize:vertical;width:100%;min-height:280px;color:var(--text-1);background:0 0;border:none;outline:none;margin-bottom:1.25rem;font-size:14px;line-height:1.7}.journal-view-content{color:var(--text-1);white-space:pre-wrap;margin-bottom:1.5rem;font-size:14px;line-height:1.7}.journal-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.notes-search-wrap{padding:.5rem 1rem .25rem}.notes-search{border:1px solid var(--border);background:var(--bg-page);width:100%;color:var(--text-1);border-radius:8px;outline:none;padding:6px 10px;font-family:inherit;font-size:13px}.notes-search:focus{border-color:var(--accent)}.jli-meta-row{justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:2px;display:flex}.jli-title{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;font-weight:600;overflow:hidden}.jli-date{color:var(--text-3);flex-shrink:0;font-size:11px}.notes-editor{background:var(--bg-surface);border:.5px solid var(--border);border-radius:14px;max-width:680px;margin:2rem auto;padding:2rem}.notes-title-input{width:100%;color:var(--text-1);background:0 0;border:none;outline:none;margin-bottom:.75rem;padding:0;font-family:inherit;font-size:24px;font-weight:700}.notes-content{resize:none;width:100%;min-height:200px;color:var(--text-1);box-sizing:border-box;background:0 0;border:none;outline:none;font-family:inherit;font-size:14px;line-height:1.75;display:block;overflow:hidden}.notes-meta-row{margin-bottom:.75rem}.notes-toolbar{border-top:.5px solid var(--border);justify-content:flex-end;align-items:center;gap:6px;margin-top:1.5rem;padding-top:1rem;display:flex}.notes-toolbar-btn{background:var(--bg-page);border:.5px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:7px;padding:5px 12px;font-family:inherit;font-size:12px;transition:background .1s,color .1s}.notes-toolbar-btn:hover{background:var(--bg-muted);color:var(--text-1)}.notes-toolbar-danger{color:#993c1d!important}.notes-toolbar-danger:hover{background:#fff0ec!important}.notes-new-actions{justify-content:flex-end;align-items:center;gap:8px;margin-top:1.25rem;display:flex}.notes-archive-toggle{width:100%;color:var(--text-3);border:none;border-top:.5px solid var(--border);cursor:pointer;text-align:left;background:0 0;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;font-family:inherit;font-size:12px;display:flex}.notes-archive-toggle:hover{background:var(--bg-page)}.notes-archive-chevron{font-size:14px;transition:transform .15s;display:inline-block}.notes-archive-list{background:var(--bg-page)}.journal-list-item.archived-note{opacity:.6}.cal-wrap{max-width:1100px;margin:0 auto;padding:1.5rem}.cal-nav{align-items:center;gap:12px;margin-bottom:1.25rem;display:flex}.cal-period{color:var(--text-1);min-width:180px;font-size:15px;font-weight:500}.cal-nav-btn{border:.5px solid var(--border);width:30px;height:30px;color:var(--text-2);border-radius:8px;justify-content:center;align-items:center;font-size:16px;transition:background .12s;display:flex}.cal-nav-btn:hover{background:var(--bg-page);color:var(--text-1)}.cal-body{background:var(--bg-surface);border:.5px solid var(--border);border-radius:12px;overflow:hidden}.cal-month-head{background:var(--bg-page);border-bottom:.5px solid var(--border);grid-template-columns:repeat(7,1fr);display:grid}.cal-day-name{text-align:center;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;padding:8px;font-size:11px;font-weight:500}.cal-month-grid{grid-template-columns:repeat(7,1fr);display:grid}.cal-cell{border-right:.5px solid var(--border);border-bottom:.5px solid var(--border);cursor:pointer;min-height:100px;padding:6px;transition:background .1s;position:relative}.cal-cell:nth-child(7n){border-right:none}.cal-cell:hover{background:var(--bg-faint)}.cal-cell:hover .cal-add-day{opacity:1}.cal-cell.other-month{background:var(--bg-faint)}.cal-cell.other-month .cal-day-num{color:var(--border)}.cal-cell.today{background:var(--accent-4)}.cal-cell.today .cal-day-num{color:var(--accent-3);font-weight:700}.cal-day-num{color:var(--text-2);margin-bottom:4px;font-size:12px;font-weight:500}.cal-task-chip{background:var(--bg-muted);white-space:nowrap;text-overflow:ellipsis;color:var(--text-1);border-radius:4px;margin-bottom:2px;padding:2px 6px;font-size:10px;overflow:hidden}.cal-more{color:var(--text-3);padding:1px 4px;font-size:10px}.cal-add-day{background:var(--accent);color:#fff;opacity:0;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;transition:opacity .12s;display:flex;position:absolute;top:4px;right:4px}.cal-week-grid{grid-template-columns:repeat(7,1fr);min-height:400px;display:grid}.cal-week-col{border-right:.5px solid var(--border);flex-direction:column;padding:0;display:flex}.cal-week-col:last-child{border-right:none}.cal-week-col.today{background:var(--accent-5)}.cal-week-head{text-align:center;border-bottom:.5px solid var(--border);background:var(--bg-page);padding:10px 8px}.cal-week-day{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:500;display:block}.cal-week-num{width:28px;height:28px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;margin-top:2px;font-size:14px;font-weight:500;display:inline-flex}.cal-week-num.today-num{background:var(--accent);color:#fff}.week-task-chip{background:var(--accent-4);color:var(--accent-3);white-space:nowrap;text-overflow:ellipsis;border-radius:6px;margin:4px 6px 0;padding:3px 7px;font-size:11px;overflow:hidden}.cal-week-add{color:var(--text-3);text-align:left;border-radius:6px;margin:8px 6px;padding:4px 6px;font-size:11px;transition:background .1s}.cal-week-add:hover{background:var(--bg-page);color:var(--accent)}.agenda-group{border-bottom:.5px solid var(--bg-muted)}.agenda-date{color:var(--text-2);background:var(--bg-faint);text-transform:uppercase;letter-spacing:.04em;padding:.6rem 1.25rem;font-size:12px;font-weight:500}.agenda-date.agenda-today{color:var(--accent-3);background:var(--accent-4)}.agenda-date.agenda-overdue{color:#993c1d;background:#faece7}.agenda-task{border-top:.5px solid #f5f4f0;align-items:center;gap:10px;padding:.65rem 1.25rem;display:flex}.bulk-backdrop .bulk-modal{flex-direction:column;width:640px;max-width:calc(100vw - 2rem);max-height:calc(100vh - 4rem);display:flex}.bulk-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.bulk-header h3{color:var(--text-1);font-size:15px;font-weight:600}.bulk-close{color:var(--text-3);border-radius:6px;padding:2px 6px;font-size:20px;line-height:1}.bulk-close:hover{background:var(--bg-page);color:var(--text-1)}.bulk-hint{color:var(--text-2);margin-bottom:10px;font-size:12px;display:block}#bulk-textarea{resize:vertical;border:.5px solid var(--text-3);background:var(--bg-page);width:100%;min-height:200px;color:var(--text-1);border-radius:8px;outline:none;margin-bottom:10px;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.6}#bulk-textarea:focus{border-color:var(--accent);background:var(--bg-surface)}.bulk-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.bulk-actions .bulk-hint{flex:1;margin:0}#bulk-preview{max-height:360px;margin-bottom:4px;overflow-y:auto}.bulk-row{border-bottom:.5px solid var(--bg-muted);align-items:center;gap:8px;padding:7px 4px;display:flex}.bulk-row:last-child{border-bottom:none}.bulk-row-text{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;overflow:hidden}.bulk-sec-sel,.bulk-grp-sel{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23888780'/%3E%3C/svg%3E");background-position:right 7px center;background-repeat:no-repeat;border:none;border-radius:999px;flex-shrink:0;padding:3px 22px 3px 8px;font-family:inherit;font-size:11px;font-weight:500}.bulk-grp-sel{background-color:var(--bg-page);color:var(--text-2);max-width:150px}.bulk-del{opacity:0;color:var(--text-3);flex-shrink:0;font-size:16px}.bulk-row:hover .bulk-del{opacity:1}.bulk-del:hover{color:#e24b4a}@media (width<=768px){.sidebar{transition:transform .2s;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 20px #0000001f}.mobile-bar{display:flex}.main-area{margin-left:0}.topbar{height:44px;padding:0 .875rem;display:flex;top:48px}.topbar-title{display:none}.search-bar{flex:1}.search-bar input{width:100%;min-width:0;max-width:none}input,select,textarea{font-size:16px}.cal-wrap{padding:.75rem}.view-wrap,.board-wrap{padding:.875rem}.sections{grid-template-columns:1fr}.week-tasks{gap:2px}.week-item{padding:7px 4px}.journal-wrap{height:calc(100dvh - 92px)}.journal-left{border-bottom:none;border-right:none;width:100%;max-height:none;position:absolute;inset:0;overflow-y:auto}.journal-right{position:absolute;inset:0;overflow-y:auto}.journal-editor,.journal-viewer,.notes-editor{box-shadow:none;border:none;border-radius:0;max-width:100%;min-height:100%;margin:0;padding:1.25rem 1rem 2rem}.journal-empty{height:100%}.grocery-picker-row{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.grocery-chip,.grocery-new-btn{flex-shrink:0}.cal-wrap{overflow-x:hidden}.cal-week-grid{grid-template-columns:repeat(7,minmax(90px,1fr));max-width:100%;overflow-x:auto}.cal-cell{min-height:70px;padding:4px}.cal-task-chip,.cal-more{display:none}.cal-day-num{font-size:11px}.event-name-row{flex-wrap:wrap}.event-name-input{max-width:100%}.stats-bar{gap:10px}}@media (hover:none) and (pointer:coarse){.del-btn{opacity:1}.add-week-btn{opacity:1;padding:3px 7px;font-size:11px}.row-del,.week-item-del,.bulk-del,.cal-add-day,.book-card .row-del,.guest-row .row-del{opacity:1}}@media (width<=480px){.mobile-bar{padding-top:env(safe-area-inset-top);height:calc(48px + env(safe-area-inset-top))}.topbar{top:calc(48px + env(safe-area-inset-top))}.sidebar{padding-top:env(safe-area-inset-top)}.fab{bottom:calc(20px + env(safe-area-inset-bottom));right:calc(16px + env(safe-area-inset-right));width:48px;height:48px;font-size:24px}.modal-backdrop.open{align-items:flex-end}.modal{width:100%;max-width:100%;padding:1.25rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom));border-radius:16px 16px 0 0}.bulk-backdrop .bulk-modal{width:100%;max-width:100%;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));border-radius:16px 16px 0 0;max-height:85vh}.bulk-backdrop.open{align-items:flex-end}.bulk-row{flex-wrap:wrap;gap:5px;padding:8px 4px}.bulk-row-text{white-space:normal;width:100%;font-size:13px}.bulk-sec-sel,.bulk-grp-sel{font-size:13px}.board-wrap{padding:.75rem}.week-bar{padding:.875rem 1rem}.section-header{padding:.625rem .875rem}.cal-cell{min-height:52px;padding:3px}.cal-add-day{width:16px;height:16px;font-size:11px}.task{padding:8px 6px}.task-text{font-size:13px}.tab-bar{width:100%;overflow-x:auto}.icon-btn{width:36px;height:36px}.cal-nav-btn{width:34px;height:34px}.search-bar{padding:5px 8px}.journal-wrap{height:calc(100dvh - 92px - env(safe-area-inset-top))}.journal-editor,.journal-viewer,.notes-editor{padding-bottom:calc(2rem + env(safe-area-inset-bottom))}.journal-title-input,.notes-title-input{font-size:18px}.guest-row{gap:8px;padding:.625rem .875rem}.guest-avatar{width:32px;height:32px;font-size:13px}.book-card{gap:10px;padding:.75rem .875rem}.book-spine{font-size:20px}}.home-wrap{flex-direction:column;gap:1.25rem;max-width:1200px;margin:0 auto;padding:1.5rem;display:flex}.home-greeting{color:var(--text-1);letter-spacing:-.02em;padding-bottom:.25rem;font-size:1.5rem;font-weight:600}.home-strip{background:var(--bg-surface);border:.5px solid var(--border);border-radius:14px;justify-content:space-between;align-items:center;padding:1.25rem 1.75rem;display:flex}.home-dt{flex-direction:column;gap:2px;display:flex}.home-date{color:var(--text-2);font-size:13px;font-weight:500}.home-time{color:var(--text-1);font-variant-numeric:tabular-nums;letter-spacing:-1px;font-size:42px;font-weight:300;line-height:1}.home-weather{align-items:center;gap:12px;display:flex}.home-weather-loading{color:var(--text-3);font-size:13px}.home-weather-icon{font-size:40px;line-height:1}.home-weather-info{flex-direction:column;gap:2px;display:flex}.home-weather-temp{color:var(--text-1);font-size:28px;font-weight:300;line-height:1}.home-weather-desc{color:var(--text-2);font-size:12px}.home-grid{grid-template-columns:1fr 1fr 1fr;align-items:start;gap:1.25rem;display:grid}.home-widget{background:var(--bg-surface);border:1px solid #00000012;border-radius:14px;flex-direction:column;gap:1rem;padding:1.25rem;display:flex;box-shadow:0 1px 4px #0000000d}.home-widget-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.home-widget-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-1);font-size:11px;font-weight:700}.home-tasks-list{flex-direction:column;gap:2px;display:flex}.home-task-row{border-radius:8px;align-items:flex-start;gap:10px;padding:8px 6px;transition:background .1s;display:flex}.home-task-row:hover{background:var(--bg-page)}.home-task-row.done .home-task-text{color:var(--text-3);text-decoration:line-through}.home-task-cb{accent-color:var(--accent);cursor:pointer;flex-shrink:0;margin-top:2px}.home-task-text{color:var(--text-1);flex:1;font-size:13px;line-height:1.4}.home-task-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;display:flex}.home-task-meta{color:var(--text-3);white-space:nowrap;font-size:11px}.home-tasks-section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);padding:8px 0 2px;font-size:10px;font-weight:700}.home-quick-add{gap:6px;padding:.5rem 0 .25rem;display:flex}.home-quick-input{border:1px solid var(--border);background:var(--bg-page);color:var(--text-1);border-radius:8px;outline:none;flex:1;min-width:0;padding:6px 10px;font-family:inherit;font-size:13px}.home-quick-input:focus{border-color:var(--accent)}.home-quick-input::placeholder{color:var(--text-4)}.home-quick-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:18px;font-weight:400;line-height:1;transition:opacity .12s;display:flex}.home-quick-btn:hover{opacity:.85}.home-cal-arrow{color:var(--text-2);border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:16px;transition:background .12s,color .12s;display:flex}.home-cal-arrow:hover{background:var(--bg-muted);color:var(--text-1)}.home-cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.home-cal-dayname{text-align:center;color:var(--text-3);padding-bottom:4px;font-size:10px;font-weight:600}.home-cal-cell{text-align:center;color:var(--text-1);border-radius:6px;padding:5px 2px;font-size:12px;line-height:1;position:relative}.home-cal-cell.other{color:var(--border)}.home-cal-cell.today{background:var(--accent);color:#fff;font-weight:600}.home-cal-cell.has-tasks:not(.today):after{content:"";background:var(--accent);border-radius:50%;width:4px;height:4px;margin:2px auto 0;display:block}.home-cal-cell.today:after{display:none}.home-articles-list{flex-direction:column;gap:2px;display:flex}.home-article-item{color:inherit;border-radius:8px;padding:8px 6px;text-decoration:none;transition:background .1s;display:block}.home-article-item:hover{background:var(--bg-page)}.home-article-title{color:var(--text-1);font-size:13px;font-weight:500;line-height:1.4}.home-article-source{color:var(--text-3);margin-top:2px;font-size:11px}@media (width<=900px){.home-grid{grid-template-columns:1fr 1fr}}@media (width<=600px){.home-wrap{padding:1rem}.home-grid{grid-template-columns:1fr}.home-time{font-size:28px}.home-strip{flex-flow:wrap;align-items:center;gap:1rem;padding:1rem 1.25rem}.home-dt{gap:1px}.home-date{font-size:12px}.home-weather-icon{font-size:28px}.home-weather-temp{font-size:22px}.home-weather-desc{font-size:11px}}.lists-page{flex-direction:column;height:100%;display:flex}.lists-tabbar{border-bottom:.5px solid var(--border);background:var(--bg-surface);z-index:50;gap:0;padding:1rem 1.5rem .75rem;display:flex;position:sticky;top:56px}.lists-tab{color:var(--text-2);white-space:nowrap;border-radius:8px;padding:7px 20px;font-size:13px;font-weight:500;transition:all .12s}.lists-tab:hover{background:var(--bg-page);color:var(--text-1)}.lists-tab.active{background:var(--accent-4);color:var(--accent-3)}.lists-content{flex:1;overflow-y:auto}.grocery-wrap{flex-direction:column;gap:1rem;max-width:800px;margin:0 auto;padding:1.5rem;display:flex}.grocery-picker-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.grocery-new-btn{background:var(--accent);color:#fff;white-space:nowrap;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:500;transition:opacity .12s}.grocery-new-btn:hover{opacity:.88}.grocery-chip{background:var(--bg-surface);border:.5px solid var(--border);color:var(--text-1);white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .12s;display:flex}.grocery-chip:hover{border-color:var(--accent);color:var(--accent)}.grocery-chip.active{background:var(--accent-4);border-color:var(--accent-mid);color:var(--accent-3)}.grocery-chip-count{background:var(--accent);color:#fff;text-align:center;border-radius:999px;min-width:20px;padding:1px 7px;font-size:11px;font-weight:600}.grocery-empty-detail{text-align:center;color:var(--text-3);padding:4rem 1rem;font-size:14px}.grocery-detail-area{flex-direction:column;gap:0;display:flex}.grocery-detail-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding-bottom:1rem;display:flex}.grocery-list-name-input{color:var(--text-1);letter-spacing:-.3px;background:0 0;border:none;border-bottom:1.5px solid #0000;outline:none;flex:1;min-width:0;padding:2px 0;font-family:inherit;font-size:20px;font-weight:600;transition:border-color .15s}.grocery-list-name-input:hover{border-bottom-color:var(--border)}.grocery-list-name-input:focus{border-bottom-color:var(--accent)}.grocery-head-right{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.grocery-share-bar{background:var(--accent-5);border:.5px solid var(--accent-mid);border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:.5rem;padding:.625rem .875rem;display:flex}.grocery-share-url{min-width:0;color:var(--accent-3);cursor:text;background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:12px}.grocery-copy-btn{background:var(--accent);color:#fff;white-space:nowrap;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:opacity .12s}.grocery-copy-btn:hover{opacity:.88}.grocery-live-badge{color:#3b6d11;white-space:nowrap;background:#eaf3de;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600}.grocery-add-row{background:var(--bg-surface);border:.5px solid var(--border);border-radius:12px;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:.25rem;padding:.875rem 1rem;display:flex}.grocery-add-name{border:.5px solid var(--border);background:var(--bg-page);min-width:140px;color:var(--text-1);border-radius:8px;outline:none;flex:1;padding:7px 10px;font-family:inherit;font-size:14px;transition:border-color .15s}.grocery-add-name:focus{border-color:var(--accent);background:var(--bg-surface)}.grocery-add-qty{border:.5px solid var(--border);background:var(--bg-page);width:64px;color:var(--text-1);border-radius:8px;outline:none;padding:7px 8px;font-family:inherit;font-size:14px;transition:border-color .15s}.grocery-add-qty:focus{border-color:var(--accent);background:var(--bg-surface)}.grocery-add-cat{border:.5px solid var(--border);background:var(--bg-page);color:var(--text-1);cursor:pointer;border-radius:8px;outline:none;padding:7px 8px;font-family:inherit;font-size:13px;transition:border-color .15s}.grocery-add-cat:focus{border-color:var(--accent)}.grocery-add-btn{white-space:nowrap;padding:7px 16px;font-size:13px}.grocery-stats{flex-wrap:wrap;gap:16px;margin-bottom:.5rem;display:flex}.grocery-prog-wrap{background:var(--bg-muted);border-radius:999px;height:4px;margin-bottom:1rem;overflow:hidden}.grocery-prog-bar{background:var(--accent);border-radius:999px;min-width:0;height:100%;transition:width .3s}.grocery-prog-bar.complete{background:#5aad6f}.grocery-items-area{flex-direction:column;display:flex}.grocery-items-empty{color:var(--text-3);text-align:center;padding:2rem;font-size:13px}.grocery-group{background:var(--bg-surface);border:.5px solid var(--border);border-radius:12px;margin-bottom:10px;overflow:hidden}.grocery-group-head{border-bottom:.5px solid var(--border-2);background:var(--bg-faint);align-items:center;gap:8px;padding:.6rem 1rem;display:flex}.grocery-group-icon{flex-shrink:0;font-size:16px}.grocery-group-name{color:var(--text-1);flex:1;font-size:13px;font-weight:600}.grocery-group-count{color:var(--text-2);background:var(--bg-page);border:.5px solid var(--border);border-radius:999px;padding:1px 8px;font-size:11px}.grocery-item{border-bottom:.5px solid var(--border-2);align-items:center;gap:10px;padding:.6rem 1rem;transition:background .1s;display:flex}.grocery-item:last-child{border-bottom:none}.grocery-item:hover{background:var(--bg-page)}.grocery-item:hover .row-del{opacity:1}.grocery-item.checked{opacity:.55}.grocery-cb{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.grocery-item-name{color:var(--text-1);cursor:text;border-radius:4px;outline:none;flex:1;min-width:0;margin:-1px -4px;padding:1px 4px;font-size:14px;line-height:1.4}.grocery-item-name:focus{background:var(--accent-5);color:var(--accent-3)}.grocery-item.checked .grocery-item-name{color:var(--text-3);text-decoration:line-through}.grocery-item-qty{color:var(--text-2);background:var(--bg-page);border:.5px solid var(--border);text-align:center;cursor:text;border-radius:6px;outline:none;min-width:36px;padding:2px 8px;font-family:inherit;font-size:12px}.grocery-item-qty:empty:before{content:attr(data-placeholder);color:var(--text-4)}.grocery-item-qty:focus{border-color:var(--accent);background:var(--bg-surface);color:var(--text-1)}@media (width<=768px){.lists-tabbar{gap:2px;padding:.75rem 1rem .625rem;top:92px}.lists-tab{padding:6px 14px;font-size:12px}.grocery-wrap{padding:.875rem}.grocery-add-row{padding:.75rem}.grocery-add-cat{display:none}.grocery-detail-head{gap:8px}.grocery-head-right{gap:4px}.grocery-head-right .btn-secondary{padding:5px 8px;font-size:11px}}@media (width<=480px){.grocery-add-qty{display:none}.grocery-list-name-input{font-size:16px}}.news-wrap{height:calc(100dvh - 56px);display:flex;overflow:hidden}.news-aside{border-right:.5px solid var(--border);background:var(--bg-surface);flex-direction:column;flex-shrink:0;gap:0;width:240px;display:flex;overflow-y:auto}.news-aside-head{border-bottom:.5px solid var(--border-2);justify-content:space-between;align-items:center;padding:16px 16px 10px;display:flex}.news-aside-title{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.news-refresh-btn{color:var(--text-2);border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;font-size:16px;transition:background .12s,color .12s;display:flex}.news-refresh-btn:hover{background:var(--bg-muted);color:var(--text-1)}.news-add-form{border-bottom:.5px solid var(--border-2);flex-direction:column;gap:6px;padding:12px 12px 10px;display:flex}.news-input{border:1px solid var(--border);background:var(--bg-faint);width:100%;color:var(--text-1);border-radius:7px;outline:none;padding:7px 10px;font-size:12.5px;transition:border-color .15s}.news-input:focus{border-color:var(--accent)}.news-add-btn{background:var(--accent);color:#fff;border-radius:7px;width:100%;padding:7px 0;font-size:12.5px;font-weight:500;transition:background .12s}.news-add-btn:hover{background:var(--accent-2)}.news-source-list{flex-direction:column;flex:1;gap:2px;padding:8px;display:flex}.news-source-tip{color:var(--text-3);padding:6px 4px;font-size:12px;line-height:1.5}.news-source-row{border-radius:7px;align-items:center;gap:8px;padding:7px 8px;transition:background .12s;display:flex}.news-source-row:hover{background:var(--bg-page)}.news-source-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.news-source-label{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:12.5px;overflow:hidden}.news-source-rm{color:var(--text-4);opacity:0;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;font-size:16px;transition:opacity .12s,color .12s;display:flex}.news-source-row:hover .news-source-rm{opacity:1}.news-source-rm:hover{color:#993c1d}.news-feed-area{background:var(--bg-faint);flex-direction:column;flex:1;display:flex;overflow:hidden}.news-feed-head{border-bottom:.5px solid var(--border-2);background:var(--bg-surface);flex-shrink:0;align-items:center;gap:10px;padding:14px 20px;display:flex}.news-feed-title{color:var(--text-1);font-size:14px;font-weight:600}.news-count{color:var(--text-3);font-size:12px}.news-articles{flex-direction:column;flex:1;gap:10px;padding:16px 20px;display:flex;overflow-y:auto}.news-status{color:var(--text-3);text-align:center;padding:48px 0;font-size:14px}.news-error-note{color:#993c1d;background:#faece7;border-radius:7px;padding:8px 12px;font-size:12px}.news-error-detail{opacity:.85;word-break:break-all;margin-top:3px;font-size:11px}.news-card{background:var(--bg-surface);border:.5px solid var(--border-2);color:inherit;border-radius:10px;gap:14px;padding:14px;transition:box-shadow .15s,border-color .15s;display:flex}.news-card:hover{border-color:var(--border);box-shadow:0 2px 10px #00000012}.news-card-img{background:var(--bg-muted);border-radius:7px;flex-shrink:0;width:100px;height:72px;overflow:hidden}.news-card-img img{object-fit:cover;width:100%;height:100%;display:block}.news-card-body{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.news-card-meta{align-items:center;gap:8px;display:flex}.news-card-source{font-size:11.5px;font-weight:600}.news-card-date{color:var(--text-3);font-size:11px}.news-card-title{color:var(--text-1);font-size:13.5px;font-weight:500;line-height:1.4;text-decoration:none;display:block}.news-card-title:hover{color:var(--accent)}.news-card-desc{color:var(--text-2);font-size:12px;line-height:1.5}.news-save-btn{color:var(--text-2);background:var(--bg-page);border:.5px solid var(--border);cursor:pointer;border-radius:6px;align-self:flex-start;margin-top:5px;padding:3px 8px;font-size:11.5px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.news-save-btn:hover{background:var(--accent-4);color:var(--accent-3);border-color:var(--accent-mid)}.news-save-btn.saved{color:var(--accent-3);background:var(--accent-4);border-color:var(--accent-mid);cursor:default}@keyframes spin{to{transform:rotate(360deg)}}.news-spinner{border:2px solid var(--border);border-top-color:var(--accent);vertical-align:middle;border-radius:50%;width:14px;height:14px;margin-right:6px;animation:.7s linear infinite spin;display:inline-block}@media (width<=768px){.news-wrap{flex-direction:column;height:auto}.news-aside{border-right:none;border-bottom:.5px solid var(--border);width:100%}.news-feed-area{overflow:visible}.news-articles{padding:12px;overflow:visible}}[data-theme=cozy]{--bg-page:#fdf6ec;--bg-surface:#fffcf5;--bg-faint:#faf1e2;--bg-muted:#f0e5d0;--text-1:#2c1a0e;--text-2:#8a6840;--text-3:#b89870;--text-4:#d4bca0;--border:#ddd0b8;--border-2:#ece0cc;--accent:#c17b3a;--accent-2:#a8672e;--accent-3:#8a5022;--accent-4:#fdefd8;--accent-5:#fef8f0;--accent-mid:#e8c090;--font:Georgia, "Times New Roman", serif}[data-theme=cozy] body{font-family:var(--font)}[data-theme=cozy] .sidebar{background:#2d1f12;border-right-color:#4a3220}[data-theme=cozy] .brand-text,[data-theme=cozy] .sidebar-brand{color:#f5ebe0}[data-theme=cozy] .nav-item{color:#b08060}[data-theme=cozy] .nav-item:hover,[data-theme=cozy] .nav-item.active{color:#f5ebe0;background:#3d2c1e}[data-theme=cozy] .nav-drag-handle{color:#5a3a24}[data-theme=cozy] .nav-item:hover .nav-drag-handle{color:#b08060}[data-theme=cozy] .sidebar-footer{border-top-color:#4a3220}[data-theme=cozy] .auth-card{border-radius:20px}[data-theme=cozy] .auth-input,[data-theme=cozy] .auth-submit{border-radius:12px}[data-theme=cozy] .auth-tab{border-radius:10px}[data-theme=cozy] .auth-tabs{border-radius:14px}[data-theme=cozy] .week-bar,[data-theme=cozy] .section{border-radius:16px}[data-theme=cozy] .section-header{border-radius:0}[data-theme=cozy] .modal{border-radius:20px}[data-theme=cozy] .nav-item{border-radius:12px}[data-theme=cozy] .home-strip,[data-theme=cozy] .home-widget{border-radius:18px}[data-theme=cozy] .book-card,[data-theme=cozy] .guest-row{border-radius:14px}[data-theme=cozy] .journal-editor,[data-theme=cozy] .journal-viewer{border-radius:18px}[data-theme=pro]{--bg-page:#eef1f5;--bg-surface:#fff;--bg-faint:#f4f6f9;--bg-muted:#e8ecf1;--text-1:#0d1117;--text-2:#4b5563;--text-3:#9ca3af;--text-4:#d1d5db;--border:#cbd5e1;--border-2:#e2e8f0;--accent:#2563eb;--accent-2:#1d4ed8;--accent-3:#1e3a8a;--accent-4:#dbeafe;--accent-5:#eff6ff;--accent-mid:#93c5fd;--font:system-ui, -apple-system, sans-serif}[data-theme=pro] .sidebar{background:#0f172a;border-right-color:#1e293b}[data-theme=pro] .sidebar-brand{border-bottom-color:#1e293b}[data-theme=pro] .brand-text{color:#f1f5f9}[data-theme=pro] .nav-item{color:#94a3b8}[data-theme=pro] .nav-item:hover,[data-theme=pro] .nav-item.active{color:#f1f5f9;background:#1e293b}[data-theme=pro] .nav-drag-handle{color:#334155}[data-theme=pro] .nav-item:hover .nav-drag-handle{color:#94a3b8}[data-theme=pro] .sidebar-footer{border-top-color:#1e293b}[data-theme=pro] .auth-card,[data-theme=pro] .week-bar,[data-theme=pro] .section,[data-theme=pro] .modal,[data-theme=pro] .home-strip,[data-theme=pro] .home-widget,[data-theme=pro] .book-card,[data-theme=pro] .guest-row,[data-theme=pro] .journal-editor,[data-theme=pro] .journal-viewer{border-radius:4px}[data-theme=pro] .auth-input,[data-theme=pro] .auth-submit,[data-theme=pro] .auth-tab,[data-theme=pro] .btn-action,[data-theme=pro] .icon-btn,[data-theme=pro] .week-add-row button{border-radius:3px}[data-theme=pro] .auth-tabs{border-radius:5px}[data-theme=pro] .nav-item{border-radius:2px}[data-theme=funky]{--bg-page:#f7f0ff;--bg-surface:#fff;--bg-faint:#f0e6ff;--bg-muted:#e5d0ff;--text-1:#1a003d;--text-2:#8b3bb8;--text-3:#c07ae0;--text-4:#dab0f0;--border:#d09ae8;--border-2:#e8c8f5;--accent:#e0149e;--accent-2:#c00d8a;--accent-3:#9c0870;--accent-4:#fce4f6;--accent-5:#fff0fc;--accent-mid:#f0a0e0;--font:system-ui, -apple-system, sans-serif}[data-theme=funky] .sidebar{background:#1e0035;border-right-color:#3d0060}[data-theme=funky] .sidebar-brand{border-bottom-color:#3d0060}[data-theme=funky] .brand-text{color:#f0d8ff}[data-theme=funky] .nav-item{color:#c080e0}[data-theme=funky] .nav-item:hover,[data-theme=funky] .nav-item.active{color:#f0d8ff;background:#305}[data-theme=funky] .nav-drag-handle{color:#4a0080}[data-theme=funky] .nav-item:hover .nav-drag-handle{color:#c080e0}[data-theme=funky] .sidebar-footer{border-top-color:#3d0060}[data-theme=funky] .auth-card{border-radius:28px}[data-theme=funky] .auth-input,[data-theme=funky] .auth-submit,[data-theme=funky] .auth-tabs{border-radius:20px}[data-theme=funky] .auth-tab{border-radius:16px}[data-theme=funky] .week-bar,[data-theme=funky] .section{border-radius:24px}[data-theme=funky] .modal{border-radius:28px}[data-theme=funky] .nav-item{border-radius:20px}[data-theme=funky] .home-strip,[data-theme=funky] .home-widget{border-radius:24px}[data-theme=funky] .book-card,[data-theme=funky] .guest-row{border-radius:20px}[data-theme=funky] .journal-editor,[data-theme=funky] .journal-viewer{border-radius:28px}[data-theme=funky] .icon-btn{border-radius:12px}[data-theme=funky] .btn-action,[data-theme=funky] .week-add-row button{border-radius:20px}[data-theme=funky] .fab{border-radius:50%}[data-theme=funky] .search-bar{border-radius:20px}.theme-picker{gap:4px;padding:6px 8px 2px;display:flex}.theme-btn{letter-spacing:.02em;cursor:pointer;text-align:center;white-space:nowrap;border:1.5px solid #0000;border-radius:8px;flex:1;padding:5px 4px;font-family:inherit;font-size:10px;font-weight:600;transition:all .15s}.theme-btn[data-t=default]{color:#888780;background:#f5f4f0;border-color:#d3d1c7}.theme-btn[data-t=cozy]{color:#8a5022;background:#fdefd8;border-color:#ddd0b8;font-family:Georgia,serif}.theme-btn[data-t=pro]{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.theme-btn[data-t=funky]{color:#9c0870;background:#fce4f6;border-color:#d09ae8}.theme-btn.active{outline-offset:1px;outline:2.5px solid}.theme-label{letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);padding:4px 8px 0;font-size:10px;font-weight:500}.sync-pill{opacity:0;pointer-events:none;border-radius:999px;align-items:center;gap:6px;margin:4px 8px;padding:4px 11px;font-size:11px;font-weight:500;transition:opacity .3s,transform .3s;display:flex;transform:translateY(3px)}.sync-pill.visible{opacity:1;transform:translateY(0)}.sync-pill.syncing{color:#92400e;background:#fef3c7}.sync-pill.synced{color:#065f46;background:#d1fae5}.sync-pill.error{color:#991b1b;background:#fee2e2}.sync-pill:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px}.sync-pill.syncing:before{background:#d97706;animation:.8s infinite pulse}.sync-pill.synced:before{background:#059669}.sync-pill.error:before{background:#dc2626}.theme-picker{flex-direction:column;gap:3px;padding:4px 8px 2px;display:flex}.theme-swatch-btn{cursor:pointer;color:var(--text-2);text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:8px;width:100%;padding:5px 8px;font-family:inherit;font-size:11px;font-weight:500;transition:background .12s,color .12s;display:flex}.theme-swatch-btn:hover{background:var(--bg-page);color:var(--text-1)}.theme-swatch-btn.active{background:var(--bg-muted);color:var(--text-1)}.theme-swatch-dots{flex-shrink:0;gap:3px;display:flex}.theme-swatch-dot{border:1px solid #0000001a;border-radius:50%;width:10px;height:10px}.overflow-menu-wrap{position:relative}.overflow-dropdown{background:var(--bg-surface);z-index:200;border:1px solid #00000014;border-radius:10px;min-width:165px;padding:4px;display:none;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 4px 20px #0000001a}.overflow-dropdown.open{flex-direction:column;display:flex}.overflow-item{color:var(--text-1);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;width:100%;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background .1s;display:flex}.overflow-item:hover{background:var(--bg-page)}.overflow-item.danger{color:#993c1d}.overflow-item.danger:hover{background:#faece7}.overflow-sep{background:var(--border-2);height:1px;margin:3px 6px}.home-widget.tasks-widget{border-left:3px solid var(--accent);padding-left:calc(1.25rem - 2px)}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:2rem 1rem;display:flex}.empty-state-icon{opacity:.35;font-size:28px;line-height:1}.empty-state-text{color:var(--text-2);font-size:13px;font-weight:500}.empty-state-sub{color:var(--text-3);max-width:200px;font-size:12px;line-height:1.5}@keyframes check-flash{0%{background:var(--accent-4)}to{background:0 0}}.check-flash,.home-task-row.check-flash,.week-item.check-flash{animation:.45s ease-out check-flash}.bottom-nav{z-index:200;background:var(--bg-surface);padding-bottom:env(safe-area-inset-bottom,0);border-top:1px solid #00000012;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0000000f}.bottom-nav-items{justify-content:space-around;align-items:flex-end;display:flex}.bottom-nav-btn{color:var(--text-3);cursor:pointer;letter-spacing:.03em;text-transform:uppercase;background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 4px 6px;font-family:inherit;font-size:10px;font-weight:600;transition:color .15s;display:flex}.bottom-nav-btn.active{color:var(--accent)}.bottom-nav-icon{margin-bottom:1px;font-size:20px;line-height:1}@media (width<=768px){.bottom-nav{display:block}.main-area{padding-bottom:calc(62px + env(safe-area-inset-bottom,0px))}.hamburger{display:none}.mobile-bar{gap:10px;padding-left:1rem}}.mobile-brand-btn{cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:0;font-family:inherit;display:flex}.home-widget-head{flex-wrap:wrap}.home-widget-head .tab-bar{margin-bottom:0}.tasks-widget .tab-btn.active{background:var(--accent);color:#fff;box-shadow:0 1px 4px #00000026}.settings-wrap{flex-direction:column;gap:20px;max-width:680px;margin:0 auto;padding:1.5rem 1rem 3rem;display:flex}.settings-section{background:var(--bg-surface);border:1px solid #00000012;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000d}.settings-section-title{text-transform:uppercase;letter-spacing:.09em;color:var(--text-3);border-bottom:1px solid var(--border-2);padding:14px 18px 10px;font-size:11px;font-weight:700}.settings-section-body{padding:16px 18px}.settings-account-card{align-items:center;gap:14px;display:flex}.settings-avatar{background:var(--accent-4);width:48px;height:48px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:700;line-height:1;display:flex}.settings-account-info{flex-direction:column;gap:2px;display:flex}.settings-account-email{color:var(--text-1);font-size:14px;font-weight:500}.settings-account-label{color:var(--text-3);font-size:12px}.settings-theme-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width<=480px){.settings-theme-grid{grid-template-columns:1fr 1fr;gap:8px}}.settings-theme-card{cursor:pointer;background:var(--bg-faint);text-align:left;border:2px solid #0000;border-radius:12px;flex-direction:column;padding:0;font-family:inherit;transition:border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.settings-theme-card:hover{border-color:var(--border)}.settings-theme-card.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-4)}.settings-theme-preview{border-radius:10px 10px 0 0;height:72px;display:flex;overflow:hidden}.settings-theme-sidebar{flex-direction:column;flex-shrink:0;gap:5px;width:28%;padding:8px 6px;display:flex}.settings-theme-sidebar-dot{border-radius:50%;width:12px;height:12px;margin-bottom:4px}.settings-theme-sidebar-line{border-radius:999px;height:4px}.settings-theme-content{flex-direction:column;flex:1;justify-content:flex-end;gap:4px;padding:8px 8px 6px;display:flex;position:relative}.settings-theme-card-block{border-radius:6px;flex-direction:column;gap:4px;padding:6px 7px;display:flex}.settings-theme-card-line{border-radius:999px;height:3px}.settings-theme-card-line:first-child{width:75%}.settings-theme-card-line:last-child{width:50%}.settings-theme-fab{border-radius:50%;width:16px;height:16px;position:absolute;bottom:7px;right:7px}.settings-theme-meta{flex-direction:column;gap:1px;padding:8px 10px 10px;display:flex}.settings-theme-name{color:var(--text-1);font-size:13px;font-weight:600}.settings-theme-desc{color:var(--text-3);font-size:11px}.settings-theme-check{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:none;position:absolute;top:7px;right:8px}.settings-theme-card.active .settings-theme-check{display:flex}.settings-hint{color:var(--text-3);margin-bottom:12px;font-size:12px}.settings-nav-list{flex-direction:column;gap:2px;display:flex}.settings-nav-row{background:var(--bg-faint);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:background .1s;display:flex}.settings-nav-row:hover{background:var(--bg-muted)}.settings-nav-row.dragging{opacity:.4}.settings-nav-row.drag-over{background:var(--accent-4);outline:2px dashed var(--accent)}.settings-nav-handle{color:var(--text-4);cursor:grab;flex-shrink:0;font-size:14px}.settings-nav-icon{flex-shrink:0;font-size:16px}.settings-nav-label{color:var(--text-1);flex:1;font-size:13px;font-weight:500}.settings-nav-pos{color:var(--text-4);font-size:11px}.settings-nav-vis-btn{cursor:pointer;color:var(--accent);background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px 4px;font-size:13px;transition:opacity .15s}.settings-nav-vis-btn.off{color:var(--text-4)}.settings-nav-vis-btn:disabled{opacity:.35;cursor:default}.settings-nav-vis-btn:not(:disabled):hover{background:var(--bg-muted)}.settings-nav-row.nav-hidden{opacity:.45}.settings-nav-row.nav-hidden .settings-nav-label{text-decoration:line-through}.settings-nav-row.nav-hidden .settings-nav-handle{cursor:default}.settings-nav-remove-btn{cursor:pointer;color:var(--text-4);background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px 5px;font-size:11px;transition:color .12s,background .12s}.settings-nav-remove-btn:hover{color:#c0392b;background:#fdf0ed}.plugin-drop-zone{border:1.5px dashed var(--border);text-align:center;cursor:default;border-radius:12px;margin-bottom:1rem;padding:2rem 1.5rem;transition:background .15s,border-color .15s}.plugin-drop-zone.dragover{background:var(--accent-4);border-color:var(--accent)}.plugin-drop-icon{margin-bottom:.5rem;font-size:28px}.plugin-drop-label{color:var(--text-1);margin-bottom:4px;font-size:13px;font-weight:500}.plugin-drop-sub{color:var(--text-3);font-size:12px}.plugin-drop-browse{color:var(--accent);cursor:pointer;text-decoration:underline}.plugin-drop-msg{margin-top:.5rem;font-size:12px;display:none}.plugin-installed-list{flex-direction:column;gap:4px;margin-bottom:1rem;display:flex}.plugin-installed-row{background:var(--bg-muted);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:flex}.plugin-installed-icon{flex-shrink:0;font-size:16px}.plugin-installed-label{color:var(--text-1);flex:1;font-size:13px;font-weight:500}.plugin-installed-remove{border:1px solid var(--border);color:var(--text-3);cursor:pointer;background:0 0;border-radius:6px;padding:3px 10px;font-size:11px;transition:color .12s,border-color .12s}.plugin-installed-remove:hover{color:#c0392b;border-color:#c0392b}.plugin-how-to{margin-top:.5rem}.plugin-how-to summary{color:var(--accent);cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0;font-size:12px;font-weight:500}.plugin-how-to p{color:var(--text-2);margin:.5rem 0;font-size:12px}.plugin-how-to pre{background:var(--bg-muted);border:1px solid var(--border-2);border-radius:8px;margin:.5rem 0;padding:1rem;font-size:11px;overflow-x:auto}.plugin-how-to code{color:var(--text-1);font-family:ui-monospace,monospace}
