@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--surface: #f6fafe;--surface-low: #eff4f9;--surface-lowest: rgba(255, 255, 255, .8);--surface-container: #e8eff4;--surface-high: #e1e9f0;--primary: #815163;--primary-dim: #e9aec3;--primary-container: #f5d6e4;--on-primary-container: #5c2f42;--secondary: #3c6663;--secondary-dim: #beebe7;--secondary-container: #ccfaf5;--on-secondary-container: #37615e;--tertiary: #645a7a;--tertiary-dim: #d6c9ee;--tertiary-container: #e4d7fd;--on-tertiary-variant: #5d5372;--on-surface: #2a3439;--on-surface-variant: #576067;--outline-variant: rgba(169, 179, 186, .15);--success: #3c8c6e;--success-bg: #d4f0e3;--danger: #a84040;--danger-bg: #f5d4d4;--shadow-primary: rgba(129, 81, 99, .08);--mobile-dock-height: 76px}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--surface);color:var(--on-surface);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden;-webkit-user-select:none;user-select:none;min-height:100vh}.app{width:100vw;height:100vh;display:flex;position:relative;background:radial-gradient(ellipse 600px 500px at 15% 20%,var(--primary-container) 0%,transparent 70%),radial-gradient(ellipse 500px 400px at 85% 75%,var(--secondary-container) 0%,transparent 70%),radial-gradient(ellipse 400px 350px at 50% 10%,var(--tertiary-container) 0%,transparent 70%),var(--surface)}.top-bar{position:fixed;top:0;left:0;right:0;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:40;background:#f6fafea6;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.top-bar-left{display:flex;align-items:center;gap:16px}.logo{font-size:20px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--primary),var(--primary-dim));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stats{display:flex;gap:14px}.stat{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--on-surface-variant)}.stat-dot{width:7px;height:7px;border-radius:9999px}.stat-dot.active{background:var(--primary)}.stat-dot.done{background:var(--success)}.top-bar-right{display:flex;align-items:center;gap:8px}.timeline-toggle{padding:8px 16px;background:var(--surface-lowest);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:none;border-radius:9999px;color:var(--on-surface-variant);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:none;font-family:inherit}.timeline-toggle:hover{background:var(--surface-high);transform:scale(1.02)}.timeline-sidebar{position:fixed;top:56px;left:0;bottom:0;width:300px;background:#f6fafebf;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);z-index:30;transform:translate(-100%);transition:transform .35s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column}.timeline-sidebar.open{transform:translate(0)}.timeline-header{padding:16px 20px 12px;display:flex;align-items:center;justify-content:space-between}.timeline-header h3{font-size:15px;font-weight:600;color:var(--on-surface)}.timeline-header-actions{display:flex;align-items:center;gap:4px}.sidebar-add-btn{width:28px;height:28px;border-radius:9999px;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.sidebar-add-btn:hover{opacity:.85}.sidebar-add-btn:disabled{opacity:.3;cursor:default}.sidebar-fold-btn{width:28px;height:28px;border-radius:9999px;border:none;background:var(--surface-low);color:var(--on-surface-variant);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:none}.sidebar-fold-btn:hover{background:var(--surface-high)}.sidebar-top{flex-shrink:0}.sidebar-section{padding:0 12px 12px}.sidebar-section.completed-section{flex:1;overflow-y:auto;padding-top:4px;border-top:1px solid var(--outline-variant)}.sidebar-section-label{font-size:11px;font-weight:600;color:var(--on-tertiary-variant);text-transform:uppercase;letter-spacing:.5px;padding:8px 8px 6px}.sidebar-nav{padding:0 8px 8px;display:flex;flex-direction:column;gap:1px}.sidebar-nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:.75rem;cursor:pointer;font-size:13px;font-weight:500;color:var(--on-surface-variant);transition:background .12s}.sidebar-nav-item:hover{background:var(--surface-high)}.sidebar-nav-item.active{background:var(--tertiary-container);color:var(--on-tertiary-variant);font-weight:600}.sidebar-nav-item.add{color:var(--on-surface-variant);opacity:.6;font-size:12px}.sidebar-nav-item.add:hover{opacity:1}.sidebar-nav-icon{width:18px;text-align:center;font-size:10px;flex-shrink:0}.sidebar-nav-count{margin-left:auto;font-size:11px;color:var(--on-surface-variant);opacity:.6}.category-input{flex:1;padding:4px 8px;background:var(--surface-low);border:none;border-radius:6px;color:var(--on-surface);font-size:12px;outline:none;font-family:inherit}.category-input:focus{background:var(--tertiary-container)}.edit-category-pills{display:flex;gap:4px;flex-wrap:wrap}.cat-pill{padding:6px 12px;border-radius:9999px;border:none;background:var(--surface-low);color:var(--on-surface-variant);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:none}.cat-pill:hover{background:var(--surface-high);transform:scale(1.04)}.cat-pill.active{background:var(--tertiary-container);color:var(--on-tertiary-variant)}.sidebar-task-list{display:flex;flex-direction:column;gap:2px}.sidebar-task-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:.75rem;cursor:pointer;transition:background .12s;font-size:13px}.sidebar-task-item:hover{background:var(--surface-high)}.sidebar-task-item.active{background:var(--tertiary-container)}.sidebar-priority-dot{width:8px;height:8px;border-radius:9999px;flex-shrink:0}.sidebar-priority-dot.p1{background:#9badb8}.sidebar-priority-dot.p2{background:#3c9e90}.sidebar-priority-dot.p3{background:#7b5fcf}.sidebar-priority-dot.p4{background:#c0604a}.sidebar-priority-dot.p5{background:#b83050}.sidebar-task-title{flex:1;font-weight:500;color:var(--on-surface);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-task-time{font-size:11px;color:var(--on-surface-variant);flex-shrink:0}.timeline-list{flex:1;overflow-y:auto;padding:4px 12px}.timeline-item{display:flex;gap:12px;padding:10px 8px;cursor:pointer;border-radius:1rem;transition:background .15s}.timeline-item:hover{background:var(--surface-high)}.timeline-item.selected{background:var(--tertiary-container)}.timeline-line{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}.timeline-dot{width:10px;height:10px;border-radius:9999px;background:var(--success);flex-shrink:0}.timeline-connector{width:2px;flex:1;background:var(--surface-high);margin-top:4px}.timeline-content{flex:1;min-width:0}.timeline-title{font-size:13px;font-weight:500;color:var(--on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-time{font-size:11px;color:var(--on-surface-variant);margin-top:2px}.timeline-detail{padding:4px 12px 12px 44px;display:flex;flex-direction:column;gap:6px}.td-memo{font-size:12px;color:var(--on-surface-variant);line-height:1.5}.td-est{font-size:11px;color:var(--on-surface-variant)}.td-reactivate{padding:6px 16px;background:var(--tertiary-container);color:var(--on-tertiary-variant);border:none;border-radius:9999px;font-size:11px;font-weight:600;cursor:pointer;align-self:flex-start;box-shadow:none;font-family:inherit;transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.td-reactivate:hover{transform:scale(1.04)}.timeline-group-block{background:var(--surface-low);border-radius:1rem;padding:4px 0;margin-bottom:6px}.timeline-group-header{display:flex;align-items:center;gap:6px;padding:8px 16px 4px;font-size:11px;font-weight:600;color:var(--on-tertiary-variant)}.timeline-group-icon{font-size:12px;opacity:.6}.timeline-group-label{flex:1}.timeline-group-time{font-size:10px;color:var(--on-surface-variant);font-weight:500}.timeline-item.grouped{padding-left:12px}.timeline-dot.small{width:7px;height:7px}.timeline-empty{padding:40px 20px;text-align:center;color:var(--on-surface-variant);font-size:13px}.te-icon{font-size:28px;margin-bottom:8px;opacity:.4}.canvas-area{flex:1;padding-top:56px;margin-left:0;transition:margin-left .35s cubic-bezier(.34,1.56,.64,1)}.canvas-area.with-timeline{margin-left:300px}.empty-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.empty-hint p{color:var(--on-surface-variant);font-size:16px;font-weight:500;letter-spacing:-.02em}.empty-hint p:first-child{font-size:48px;margin-bottom:12px}.edit-panel{position:fixed;right:0;top:56px;bottom:0;width:320px;background:#f6fafec7;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);z-index:50;padding:24px;display:flex;flex-direction:column;gap:20px;animation:slideIn .3s cubic-bezier(.34,1.56,.64,1);overflow-y:auto}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes popUp{0%{transform:translate(-50%,-120%) scale(.9);opacity:0}to{transform:translate(-50%,-120%) scale(1);opacity:1}}.edit-panel-header{display:flex;align-items:center;justify-content:space-between}.edit-header-actions{display:flex;align-items:center;gap:4px}.edit-icon-btn{width:36px;height:36px;border-radius:9999px;border:none;background:var(--surface-low);color:var(--on-surface-variant);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s cubic-bezier(.34,1.56,.64,1);font-family:inherit;box-shadow:none}.edit-icon-btn:hover{background:var(--surface-high);transform:scale(1.08)}.edit-icon-btn.complete{color:var(--success)}.edit-icon-btn.complete:hover{background:var(--success-bg)}.edit-icon-btn.danger:hover{background:var(--danger-bg);color:var(--danger)}.edit-icon-btn.ai{color:var(--tertiary)}.edit-icon-btn.ai:hover{background:var(--tertiary-container)}.edit-icon-btn.ai.loading{animation:pulse 1s ease-in-out infinite;pointer-events:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.edit-close{background:var(--surface-low);border:none;color:var(--on-surface-variant);font-size:14px;cursor:pointer;padding:6px 10px;border-radius:9999px;box-shadow:none;transition:background .12s;font-family:inherit}.edit-close:hover{background:var(--surface-high)}.edit-field{display:flex;flex-direction:column;gap:8px}.edit-field label{font-size:11px;font-weight:600;color:var(--on-tertiary-variant);text-transform:uppercase;letter-spacing:.5px}.edit-title-input{padding:12px 16px;background:var(--surface-lowest);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:none;border-radius:1.5rem;color:var(--on-surface);font-size:16px;font-weight:600;outline:none;font-family:inherit;transition:background .2s}.edit-title-input:focus{background:var(--tertiary-container)}.edit-priority{display:flex;gap:4px}.ep-btn{flex:1;padding:10px 0;border-radius:9999px;border:none;background:var(--surface-low);color:var(--on-surface-variant);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:none;font-family:inherit}.ep-btn:hover{background:var(--surface-high);transform:scale(1.04)}.ep-btn.active.p1{background:var(--surface-high);color:var(--on-surface)}.ep-btn.active.p2{background:var(--secondary-container);color:var(--on-secondary-container)}.ep-btn.active.p3{background:var(--tertiary-container);color:var(--on-tertiary-variant)}.ep-btn.active.p4{background:var(--primary-container);color:var(--on-primary-container)}.ep-btn.active.p5{background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff}.edit-priority-hint{font-size:11px;color:var(--on-surface-variant)}.edit-time-row{display:flex;align-items:center;gap:6px}.edit-minutes{width:70px;padding:10px 12px;background:var(--surface-lowest);border:none;border-radius:1.5rem;color:var(--on-surface);font-size:13px;outline:none;font-family:inherit}.edit-minutes:focus{background:var(--tertiary-container)}.edit-time-row span{font-size:12px;color:var(--on-surface-variant)}.edit-timer-presets{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.timer-preset-btn{padding:4px 10px;border:1px solid var(--outline-variant);border-radius:9999px;background:transparent;color:var(--on-surface-variant);font-size:11px;cursor:pointer;transition:all .15s}.timer-preset-btn:hover{background:var(--surface-container)}.timer-preset-btn:disabled{opacity:.3}.timer-start-btn{margin-top:8px;padding:8px 16px;border:none;border-radius:9999px;background:var(--secondary);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;width:100%}.timer-start-btn:hover{opacity:.85}.timer-start-btn.active{background:var(--danger, #a84040)}.edit-memo{padding:12px 16px;background:var(--surface-lowest);border:none;border-radius:1rem;color:var(--on-surface);font-size:13px;outline:none;resize:vertical;font-family:inherit;min-height:70px;line-height:1.5}.edit-memo:focus{background:var(--tertiary-container)}.edit-group-info{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--secondary-container);border-radius:1rem}.edit-group-badge{font-size:12px;color:var(--on-secondary-container);font-weight:500}.edit-ungroup{padding:6px 14px;background:#ffffff80;color:var(--on-secondary-container);border:none;border-radius:9999px;font-size:11px;font-weight:600;cursor:pointer;box-shadow:none;font-family:inherit;transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.edit-ungroup:hover{transform:scale(1.04)}.edit-ungroup:disabled{opacity:.5;cursor:not-allowed;transform:none}.edit-bottom-actions{display:flex;gap:8px;margin-top:auto}.edit-complete-btn{flex:1;padding:14px;background:linear-gradient(135deg,var(--secondary),var(--secondary-dim));color:#fff;border:none;border-radius:9999px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 10px 40px var(--shadow-primary);font-family:inherit;transition:transform .15s cubic-bezier(.34,1.56,.64,1);box-shadow:inset 0 1px #ffffff4d,0 10px 40px var(--shadow-primary)}.edit-complete-btn:hover{transform:scale(1.03)}.edit-delete-btn{padding:14px 18px;background:var(--danger-bg);color:var(--danger);border:none;border-radius:9999px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:none;font-family:inherit;transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.edit-delete-btn:hover{transform:scale(1.03)}.edit-hint{text-align:center;font-size:11px;color:var(--on-surface-variant);padding-top:4px}.group-confirm{position:fixed;transform:translate(-50%,-120%);background:var(--surface-lowest);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:1.5rem;padding:20px 24px;z-index:60;text-align:center;box-shadow:0 10px 40px var(--shadow-primary);animation:popUp .25s cubic-bezier(.34,1.56,.64,1)}.group-confirm p{font-size:14px;font-weight:500;color:var(--on-surface);margin-bottom:14px}.group-confirm-actions{display:flex;gap:8px;justify-content:center}.gc-btn{padding:10px 20px;border:none;border-radius:9999px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:none;font-family:inherit;transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.gc-btn:hover{transform:scale(1.05)}.gc-btn.yes{background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;box-shadow:inset 0 1px #ffffff4d}.gc-btn.no{background:var(--surface-low);color:var(--on-surface-variant)}.add-trigger{display:flex;align-items:center;gap:6px;padding:8px 18px;background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;border:none;border-radius:9999px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:inset 0 1px #ffffff4d,0 4px 16px var(--shadow-primary);transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s}.add-trigger:hover{transform:scale(1.05);box-shadow:inset 0 1px #ffffff4d,0 6px 24px var(--shadow-primary)}.add-trigger:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:inset 0 1px #ffffff4d,0 4px 16px var(--shadow-primary)}.add-trigger kbd{background:#fff3;padding:1px 6px;border-radius:4px;font-size:10px;font-family:inherit}.spotlight-overlay{position:fixed;inset:0;background:#2a34394d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:20vh;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.spotlight-card{width:480px;background:var(--surface-lowest);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-radius:1.5rem;padding:28px;box-shadow:0 20px 60px var(--shadow-primary),0 0 0 1px var(--outline-variant);animation:spotlightIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes spotlightIn{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.spotlight-input{width:100%;padding:16px 20px;background:var(--surface-low);border:none;border-radius:1rem;color:var(--on-surface);font-size:18px;font-weight:500;outline:none;font-family:inherit;letter-spacing:-.02em;transition:background .2s}.spotlight-input:focus{background:var(--tertiary-container)}.spotlight-input::placeholder{color:var(--on-surface-variant)}.spotlight-options{display:flex;gap:20px;margin-top:16px;align-items:center}.spotlight-opt{display:flex;align-items:center;gap:8px}.spotlight-label{font-size:12px;font-weight:600;color:var(--on-tertiary-variant);white-space:nowrap}.spotlight-pills{display:flex;gap:4px}.sp-pill{padding:6px 12px;border-radius:9999px;border:none;background:var(--surface-low);color:var(--on-surface-variant);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:none}.sp-pill:hover{background:var(--surface-high);transform:scale(1.04)}.sp-pill.active.p1{background:var(--surface-high);color:var(--on-surface)}.sp-pill.active.p2{background:var(--secondary-container);color:var(--on-secondary-container)}.sp-pill.active.p3{background:var(--tertiary-container);color:var(--on-tertiary-variant)}.sp-pill.active.p4{background:var(--primary-container);color:var(--on-primary-container)}.sp-pill.active.p5{background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff}.spotlight-minutes{width:60px;padding:8px 12px;background:var(--surface-low);border:none;border-radius:9999px;color:var(--on-surface);font-size:12px;outline:none;font-family:inherit}.spotlight-minutes:focus{background:var(--tertiary-container)}.spotlight-footer{display:flex;align-items:center;justify-content:space-between;margin-top:20px}.spotlight-hint{font-size:11px;color:var(--on-surface-variant)}.spotlight-submit{padding:10px 24px;background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;border:none;border-radius:9999px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:inset 0 1px #ffffff4d,0 4px 16px var(--shadow-primary);transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.spotlight-submit:hover{transform:scale(1.04)}.spotlight-submit:disabled{opacity:.35;cursor:not-allowed}.search-bar{position:relative}.search-toggle{padding:8px 14px;background:var(--surface-lowest);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:none;border-radius:9999px;color:var(--on-surface-variant);font-size:12px;font-weight:500;cursor:pointer;box-shadow:none;font-family:inherit;transition:all .15s cubic-bezier(.34,1.56,.64,1)}.search-toggle:hover{background:var(--surface-high);transform:scale(1.02)}.search-toggle.compact{width:52px;height:52px;padding:0;display:flex;align-items:center;justify-content:center}.search-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:var(--surface-lowest);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:1.5rem;padding:16px;z-index:60;box-shadow:0 10px 40px var(--shadow-primary);animation:dropIn .2s cubic-bezier(.34,1.56,.64,1)}.search-input{width:100%;padding:10px 14px;background:var(--surface-low);border:none;border-radius:9999px;color:var(--on-surface);font-size:13px;font-weight:500;outline:none;font-family:inherit;margin-bottom:10px}.search-input:focus{background:var(--tertiary-container)}.search-results{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.search-result-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:.75rem;cursor:pointer;transition:background .12s}.search-result-item:hover{background:var(--surface-high)}.sr-dot{width:8px;height:8px;border-radius:9999px;flex-shrink:0}.sr-dot.active-dot{background:var(--primary)}.sr-dot.done-dot{background:var(--success)}.sr-title{flex:1;font-size:13px;font-weight:500;color:var(--on-surface);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-title.completed-title{text-decoration:line-through;color:var(--on-surface-variant)}.sr-meta{font-size:10px;color:var(--on-surface-variant);flex-shrink:0}.search-empty{text-align:center;padding:20px;font-size:13px;color:var(--on-surface-variant)}mark{background:var(--primary-container);color:var(--on-primary-container);border-radius:2px;padding:0 1px}.login-banner{position:fixed;top:0;left:0;right:0;height:36px;display:flex;align-items:center;justify-content:center;gap:12px;padding:0 20px;background:var(--primary);color:#fff;font-size:12px;font-weight:500;z-index:50}.login-banner~.top-bar{top:36px}.login-banner~.timeline-sidebar{top:92px}.login-banner~.canvas-area{padding-top:92px}.login-banner~.edit-panel{top:92px}.login-banner-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.login-banner-btn{padding:4px 12px;border:1px solid rgba(255,255,255,.5);border-radius:9999px;background:transparent;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}.login-banner-btn:hover{background:#ffffff26}.login-banner-dismiss{background:none;border:none;font-size:16px;color:#ffffffb3;cursor:pointer;padding:0 2px;line-height:1}.login-banner-dismiss:hover{color:#fff}.undo-redo{display:flex;gap:2px;margin-left:8px}.ur-btn{padding:4px 6px;border:none;border-radius:6px;background:transparent;color:var(--on-surface-variant);cursor:pointer;display:flex;align-items:center;transition:all .15s}.ur-btn:hover:not(:disabled){background:var(--surface-container)}.ur-btn:disabled{opacity:.25;cursor:default}.modal-overlay{position:fixed;inset:0;background:#0000004d;z-index:300;display:flex;align-items:center;justify-content:center}.delete-confirm-dialog{background:var(--surface-lowest);border-radius:1.5rem;padding:24px;text-align:center;box-shadow:0 10px 40px #00000026;min-width:240px}.delete-confirm-dialog p{font-size:14px;font-weight:600;margin-bottom:16px;color:var(--on-surface)}.delete-confirm-actions{display:flex;gap:8px;justify-content:center}.gc-btn.danger{background:var(--danger, #a84040)!important}.locale-select{padding:4px 8px;border:1px solid var(--outline-variant);border-radius:8px;background:transparent;color:var(--on-surface-variant);font-size:11px;cursor:pointer;outline:none}.login-topbar-btn{padding:6px 14px;border:1px solid var(--outline-variant);border-radius:9999px;background:transparent;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.login-topbar-btn:hover{background:var(--primary-container)}@media(max-width:480px){.login-banner span:first-child{display:none}.login-banner-btn{font-size:12px;padding:5px 14px}}.auth-screen{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 600px 500px at 30% 25%,var(--primary-container) 0%,transparent 70%),radial-gradient(ellipse 500px 400px at 70% 70%,var(--secondary-container) 0%,transparent 70%),var(--surface)}.auth-loading{text-align:center}.auth-card{width:380px;background:var(--surface-lowest);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:2rem;padding:48px 36px;text-align:center;box-shadow:0 20px 60px var(--shadow-primary)}.auth-logo{font-size:32px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--primary),var(--primary-dim));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.auth-tagline{font-size:14px;color:var(--on-surface-variant);margin-bottom:32px}.auth-buttons{display:flex;flex-direction:column;gap:10px}.auth-btn{padding:14px;border:none;border-radius:9999px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .15s cubic-bezier(.34,1.56,.64,1);box-shadow:none}.auth-btn:hover{transform:scale(1.02)}.auth-btn.google{background:#fff;color:var(--on-surface);box-shadow:0 2px 8px #00000014}.auth-btn.github{background:var(--on-surface);color:#fff}.auth-footer{font-size:11px;color:var(--on-surface-variant);margin-top:24px}.share-wrapper{position:relative}.share-btn{width:36px;height:36px;border-radius:9999px;border:none;background:var(--surface-lowest);color:var(--on-surface-variant);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:none}.share-btn:hover{transform:scale(1.05);background:var(--surface-high)}.share-btn.with-label{width:auto;padding:0 16px;gap:8px;border-radius:18px;font-size:13px;font-weight:600}.share-panel{position:fixed;top:64px;right:16px;width:280px;background:var(--surface-lowest);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:1.5rem;padding:20px;z-index:200;box-shadow:0 10px 40px var(--shadow-primary);animation:dropIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes dropIn{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}.share-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.share-panel-header h4{font-size:14px;font-weight:600;color:var(--on-surface);margin:0}.share-refresh-btn{border:none;background:var(--surface-low);color:var(--on-surface-variant);font-size:11px;font-weight:600;border-radius:9999px;padding:7px 12px;cursor:pointer;font-family:inherit;transition:background .15s ease,transform .15s ease}.share-refresh-btn:hover{background:var(--surface-high);transform:scale(1.03)}.share-refresh-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.share-permission{display:flex;gap:4px;margin-bottom:16px;background:var(--surface-low);border-radius:9999px;padding:3px}.share-perm-btn{flex:1;padding:8px 0;border:none;border-radius:9999px;background:transparent;color:var(--on-surface-variant);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;box-shadow:none}.share-perm-btn.active{background:#fff;color:var(--on-surface);box-shadow:0 1px 4px #00000014}.share-status-card{background:var(--surface-low);border-radius:1rem;padding:12px 14px;margin-bottom:14px}.share-status-title{font-size:12px;font-weight:700;color:var(--on-surface)}.share-status-copy{margin-top:4px;font-size:12px;line-height:1.45;color:var(--on-surface-variant)}.share-loading,.share-error{padding:24px 12px;border-radius:1rem;text-align:center;font-size:12px}.share-loading{background:var(--surface-low);color:var(--on-surface-variant)}.share-error{background:var(--danger-bg);color:var(--danger)}.share-qr{display:flex;justify-content:center;padding:12px 0}.share-qr canvas{border-radius:12px;box-shadow:0 2px 8px #0000000f}.share-link-row{display:flex;gap:6px;margin-top:8px}.share-link-input{flex:1;padding:8px 12px;background:var(--surface-low);border:none;border-radius:9999px;color:var(--on-surface);font-size:11px;outline:none;font-family:inherit;min-width:0}.share-copy-btn{padding:8px 14px;background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;border:none;border-radius:9999px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:inset 0 1px #ffffff4d;white-space:nowrap;transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.share-copy-btn:hover{transform:scale(1.04)}.share-copy-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.share-native-btn{width:100%;margin-top:10px;padding:10px 14px;border:none;border-radius:9999px;background:var(--surface-low);color:var(--on-surface);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s ease,transform .15s ease}.share-native-btn:hover{background:var(--surface-high);transform:scale(1.02)}.share-native-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.share-hint{font-size:11px;color:var(--on-surface-variant);margin-top:10px;text-align:center;line-height:1.4}.user-avatar{width:32px;height:32px;border-radius:9999px;background:var(--tertiary-container);color:var(--on-tertiary-variant);border:none;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;font-family:inherit;box-shadow:none;transition:transform .12s}.user-avatar:hover{transform:scale(1.08)}.user-avatar img{width:100%;height:100%;object-fit:cover}.edit-readonly-notice{text-align:center;font-size:12px;color:var(--on-surface-variant);padding:12px;background:var(--surface-low);border-radius:.75rem}.edit-panel-title-label{font-size:13px;font-weight:600;color:var(--on-surface-variant)}.sub-bubble-input-row{display:flex;gap:8px;animation:fadeIn .15s ease}.sub-bubble-input{flex:1;padding:10px 14px;background:var(--surface-low);border:none;border-radius:9999px;color:var(--on-surface);font-size:13px;font-weight:500;outline:none;font-family:inherit}.sub-bubble-input:focus{background:var(--tertiary-container)}.sub-bubble-add-btn{padding:10px 16px;background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;border:none;border-radius:9999px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:inset 0 1px #ffffff4d;transition:transform .15s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}.sub-bubble-add-btn:hover{transform:scale(1.04)}.sub-bubble-add-btn:disabled{opacity:.35;cursor:not-allowed}.edit-colors{display:flex;gap:6px;flex-wrap:wrap}.color-dot{width:28px;height:28px;border-radius:9999px;border:2.5px solid transparent;cursor:pointer;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 4px #00000014}.color-dot:hover{transform:scale(1.15)}.color-dot.active{transform:scale(1.1);box-shadow:0 2px 8px #00000026}.edit-group-text-header{display:flex;align-items:center;justify-content:space-between}.copy-icon-btn{background:none;border:none;cursor:pointer;padding:4px;color:var(--on-surface-variant);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}.copy-icon-btn:hover{background:var(--surface-high)}.edit-group-text-list{display:flex;flex-direction:column;gap:2px;margin-top:8px}.group-text-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:.75rem;cursor:pointer;transition:background .12s;font-size:13px}.group-text-item:hover{background:var(--surface-high)}.group-text-item.current{background:var(--tertiary-container)}.group-text-dot{width:6px;height:6px;border-radius:9999px;background:var(--primary);flex-shrink:0}.group-text-title{flex:1;font-weight:500;color:var(--on-surface);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-text-time{font-size:11px;color:var(--on-surface-variant);flex-shrink:0}.bubble-floating-actions{position:fixed;transform:translate(-50%,-100%);display:flex;gap:4px;z-index:55;animation:popUp .2s cubic-bezier(.34,1.56,.64,1)}.bfa-btn{width:32px;height:32px;border-radius:9999px;border:none;background:#fff;color:var(--on-surface-variant);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0000001f;transition:all .15s cubic-bezier(.34,1.56,.64,1)}.bfa-btn:hover{transform:scale(1.15);box-shadow:0 4px 16px #0000002e}.bfa-btn.ai{background:linear-gradient(135deg,#e4d7fd,#f5d6e4);color:var(--tertiary)}.bfa-btn.ai:hover{background:linear-gradient(135deg,#d6c9ee,#e9aec3)}.bubble-tooltip{position:fixed;transform:translate(-50%);background:var(--on-surface);color:var(--surface);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;pointer-events:none;z-index:100;white-space:nowrap;max-width:280px;overflow:hidden;text-overflow:ellipsis;animation:fadeIn .15s ease;box-shadow:0 4px 12px #00000026}.sub-task-dialog-card{background:var(--surface-lowest);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-radius:1.5rem;padding:24px;width:380px;box-shadow:0 20px 60px var(--shadow-primary),0 0 0 1px var(--outline-variant);animation:spotlightIn .25s cubic-bezier(.34,1.56,.64,1)}.sub-task-dialog-parent{font-size:12px;color:var(--on-surface-variant);margin-bottom:14px;padding:8px 12px;background:var(--surface-low);border-radius:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.sub-task-color-grid{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px}.stc-dot{width:26px;height:26px;border-radius:9999px;border:2.5px solid transparent;cursor:pointer;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 4px #00000014}.stc-dot:hover{transform:scale(1.15)}.stc-dot.active{transform:scale(1.1);border-color:var(--primary);box-shadow:0 2px 8px #00000026}.sub-task-form-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.sub-task-submit{padding:10px 22px;background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;border:none;border-radius:9999px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:inset 0 1px #ffffff4d,0 4px 16px var(--shadow-primary);transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.sub-task-submit:hover{transform:scale(1.04)}.sub-task-submit:disabled{opacity:.35;cursor:not-allowed}.sub-task-cancel{padding:10px 18px;background:var(--surface-low);color:var(--on-surface-variant);border:none;border-radius:9999px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.sub-task-cancel:hover{background:var(--surface-high)}.multi-select-bar{position:fixed;transform:translate(-50%,-100%);background:var(--surface-lowest);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:1.5rem;padding:10px 14px;display:flex;align-items:center;gap:6px;box-shadow:0 8px 28px var(--shadow-primary),0 0 0 1px var(--outline-variant);z-index:100;white-space:nowrap;animation:popUp .2s cubic-bezier(.34,1.56,.64,1)}.msb-count{font-size:12px;font-weight:600;color:var(--on-surface-variant);margin-right:4px;padding:0 4px}.msb-btn{font-size:12px;font-weight:600;padding:6px 12px;border-radius:9999px;border:none;background:var(--surface-low);color:var(--on-surface);cursor:pointer;font-family:inherit;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:none}.msb-btn:hover{background:var(--surface-high);transform:scale(1.04)}.msb-btn.danger{color:var(--danger)}.msb-btn.danger:hover{background:var(--danger-bg)}.msb-btn.cancel{background:transparent;color:var(--on-surface-variant);padding:6px 8px}.mobile-sheet-handle{display:none;width:44px;height:5px;border-radius:9999px;background:#57606740;margin:12px auto 0;flex-shrink:0}.mobile-dock{display:none}@keyframes mobileSheetIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.top-bar{padding:0 12px;background:#f6fafed6}.top-bar-left .stats{display:none}.top-bar-right{gap:6px}.canvas-area{padding-bottom:calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 18px)}.canvas-area.with-timeline{margin-left:0}.timeline-sidebar{inset:auto 0 0;width:100%;max-height:70dvh;border-radius:26px 26px 0 0;box-shadow:0 -8px 48px #2a343924;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateY(100%);padding-bottom:calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 8px);z-index:35}.timeline-sidebar.open{transform:translateY(0)}.mobile-sheet-handle{display:block}.timeline-header{padding-top:10px}.sidebar-fold-btn{width:32px;height:32px}.edit-panel{inset:auto 0 0;width:100%;max-height:75dvh;border-radius:26px 26px 0 0;padding:12px 18px calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 12px);overflow-y:auto;-webkit-overflow-scrolling:touch;animation:mobileSheetIn .25s cubic-bezier(.34,1.56,.64,1)}.edit-panel-overlay{position:fixed;inset:0;background:#0003;z-index:49}.spotlight-overlay{align-items:flex-end;padding:0 12px calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 8px)}.spotlight-card,.sub-task-dialog-card{width:100%;border-radius:26px;padding:22px 18px}.spotlight-options{flex-direction:column;align-items:stretch;gap:12px}.spotlight-opt{justify-content:space-between}.spotlight-footer{flex-direction:column;align-items:stretch;gap:12px}.spotlight-submit{width:100%}.spotlight-hint{text-align:center}.search-dropdown,.share-panel{position:fixed;left:12px;right:12px;top:auto;bottom:calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 12px);width:auto;border-radius:24px}.search-results{max-height:34dvh}.bubble-floating-actions,.multi-select-bar{left:50%!important;top:auto!important;bottom:calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 12px);transform:translate(-50%);background:var(--surface-lowest);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:10px 12px;border-radius:18px;box-shadow:0 10px 32px #2a343924}.bfa-btn{width:38px;height:38px}.group-confirm{left:50%!important;top:auto!important;bottom:calc(var(--mobile-dock-height) + env(safe-area-inset-bottom) + 12px);transform:translate(-50%);width:min(calc(100vw - 24px),380px)}.mobile-dock{position:fixed;left:12px;right:12px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:120;display:flex;align-items:center;gap:8px;padding:8px;border-radius:24px;background:#f6fafed6;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 12px 36px #2a343924}.mobile-dock .search-bar,.mobile-dock .share-wrapper{flex:1;min-width:0}.mobile-dock-btn,.mobile-dock .share-btn{width:100%;height:52px;border:none;border-radius:18px;background:var(--surface-lowest);color:var(--on-surface);display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:transform .15s ease,background .15s ease}.mobile-dock-btn.active{background:var(--tertiary-container);color:var(--on-tertiary-variant)}.mobile-dock-btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-dim));color:#fff;box-shadow:inset 0 1px #ffffff4d,0 8px 22px #8151632e}.mobile-dock-btn:disabled{opacity:.45;cursor:not-allowed}.mobile-dock .search-toggle{width:100%;height:52px;border-radius:18px}.mobile-dock .share-btn.with-label{padding:0 14px}.empty-hint{top:calc(50% - 18px)}}@media(max-width:480px){.logo{font-size:18px}.timeline-sidebar,.edit-panel,.search-dropdown,.share-panel{left:10px;right:10px}.mobile-dock{left:10px;right:10px;gap:6px;padding:7px}.mobile-dock-btn,.mobile-dock .share-btn,.mobile-dock .search-toggle{height:50px}}
