.alert{background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary);border-radius:.375rem}.alert-primary{background-color:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info-text)}.alert-success{background-color:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success-text)}.alert-warning{background-color:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning-text)}.alert-danger,.alert-error{background-color:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error-text)}.alert-info{background-color:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info-text)}.modal-content{background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary);box-shadow:var(--shadow-xl)}.modal-header{background-color:var(--surface-0);border-bottom:1px solid var(--border-divider);color:var(--text-primary)}.modal-header .btn-close{filter:invert(var(--theme-is-dark, 0))}.modal-footer{background-color:var(--surface-0);border-top:1px solid var(--border-divider)}.modal-body{background-color:var(--surface-0);color:var(--text-primary)}.modal .form-control,.modal .form-select{background-color:var(--surface-1);border-color:var(--surface-2)}.modal .form-control:focus,.modal .form-select:focus{background-color:var(--surface-1);border-color:var(--border-focus)}.modal .btn-outline-secondary{background-color:transparent}.modal .btn-outline-secondary:hover{background-color:var(--surface-1)}.modal-backdrop{background-color:#0000007f}.card{background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary)}.card-header{background-color:var(--surface-0);border-bottom:1px solid var(--border-divider);color:var(--text-primary)}.card-body{background-color:var(--surface-0);color:var(--text-primary)}.card-footer{background-color:var(--surface-0);border-top:1px solid var(--border-divider);color:var(--text-secondary)}.card .form-control,.card .form-select{background-color:var(--surface-1);border-color:var(--surface-2)}.card .form-control:focus,.card .form-select:focus{background-color:var(--surface-1);border-color:var(--border-focus)}.card .btn-outline-secondary:hover{background-color:var(--surface-1)}.list-group{border-radius:.375rem}.list-group-item{background-color:var(--surface-0);border:1px solid var(--border-muted);color:var(--text-primary)}.list-group-item:hover{background-color:var(--surface-hover)}.list-group-item:focus{background-color:var(--surface-active);outline:2px solid var(--border-focus);outline-offset:-2px}.list-group-item.active{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.badge{font-weight:600;border-radius:.25rem}.badge.bg-primary{background-color:var(--accent-primary)!important;color:#fff}.badge.bg-secondary{background-color:var(--surface-border)!important;color:var(--text-secondary)}.badge.bg-success{background-color:var(--color-success)!important;color:#fff}.badge.bg-warning{background-color:var(--color-warning)!important;color:var(--text-primary)}.badge.bg-danger{background-color:var(--color-error)!important;color:#fff}.badge.bg-info{background-color:var(--color-info)!important;color:#fff}.form-control,.form-select{background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary)}.form-control:focus,.form-select:focus{background-color:var(--surface-0);border-color:var(--border-focus);outline:none;box-shadow:var(--shadow-focus-ring);color:var(--text-primary)}.form-control::placeholder{color:var(--text-muted)}.form-label{color:var(--text-primary)}.form-check-input{background-color:var(--surface-0);border:1px solid var(--border-default)}.form-check-input:checked{background-color:var(--accent-primary);border-color:var(--accent-primary)}.task-card.task-completing .form-check-input:checked{animation:checkbox-bounce .4s ease}@keyframes checkbox-bounce{0%{transform:scale(1);box-shadow:0 0 0 0 transparent}50%{transform:scale(1.2);box-shadow:0 0 20px 6px color-mix(in srgb,var(--accent-primary) 80%,transparent)}to{transform:scale(1);box-shadow:0 0 0 0 transparent}}.form-check-input:focus{border-color:var(--border-focus);box-shadow:var(--shadow-focus-ring)}.form-check-label{color:var(--text-primary)}.btn{border-radius:.375rem;font-weight:500;transition:all .15s ease}.btn-primary{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:var(--accent-primary-hover);border-color:var(--accent-primary-hover);color:#fff}.btn-primary:active,.btn-primary.active{background-color:var(--accent-primary-active);border-color:var(--accent-primary-active);color:#fff}.btn-secondary{background-color:var(--surface-border);border-color:var(--surface-border);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--surface-active);border-color:var(--surface-active);color:var(--text-primary)}.btn-outline-secondary{background-color:transparent;border-color:var(--border-default);color:var(--text-primary)}.btn-outline-secondary:hover{background-color:var(--surface-hover);border-color:var(--border-strong);color:var(--text-primary)}.btn-outline-primary{background-color:transparent;border-color:var(--accent-primary);color:var(--accent-primary)}.btn-outline-primary:hover{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.btn-danger{background-color:var(--color-error);border-color:var(--color-error);color:#fff}.btn-danger:hover{background-color:color-mix(in srgb,var(--color-error) 85%,black);border-color:color-mix(in srgb,var(--color-error) 85%,black);color:#fff}.btn-success{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.btn-success:hover{background-color:color-mix(in srgb,var(--color-success) 85%,black);border-color:color-mix(in srgb,var(--color-success) 85%,black);color:#fff}.btn-link{color:var(--text-link)}.btn-link:hover{color:var(--text-link-hover)}.btn-close{filter:invert(var(--theme-is-dark, 0));opacity:.5}.btn-close:hover{opacity:1}.btn-outline-secondary:active,.btn-outline-secondary.active{background-color:var(--surface-active);border-color:var(--border-strong);color:var(--text-primary)}.btn-outline-primary:active,.btn-outline-primary.active{background-color:var(--accent-primary-active);border-color:var(--accent-primary-active);color:#fff}.btn-danger:active,.btn-danger.active{background-color:color-mix(in srgb,var(--color-error) 75%,black);border-color:color-mix(in srgb,var(--color-error) 75%,black);color:#fff}.btn-success:active,.btn-success.active{background-color:color-mix(in srgb,var(--color-success) 75%,black);border-color:color-mix(in srgb,var(--color-success) 75%,black);color:#fff}.input-group-text{background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary)}.dropdown-menu{background-color:var(--surface-0);border:1px solid var(--border-default);box-shadow:var(--shadow-md)}.dropdown-item{color:var(--text-primary)}.dropdown-item:hover{background-color:var(--surface-hover);color:var(--text-primary)}.dropdown-item:active,.dropdown-item.active{background-color:var(--accent-primary);color:#fff}.dropdown-divider{border-top:1px solid var(--border-divider)}.nav-link{color:var(--text-secondary);transition:color .15s ease}.nav-link:hover{color:var(--text-primary)}.nav-link.active{color:var(--accent-primary)}.nav-tabs{border-bottom:1px solid var(--border-default)}.nav-tabs .nav-link{border:1px solid transparent;border-top-left-radius:.375rem;border-top-right-radius:.375rem;color:var(--text-secondary)}.nav-tabs .nav-link:hover{border-color:var(--border-subtle) var(--border-subtle) var(--border-default);color:var(--text-primary);isolation:isolate}.nav-tabs .nav-link.active,.nav-tabs .nav-item.show .nav-link{color:var(--accent-primary);background-color:var(--surface-0);border-color:var(--border-default) var(--border-default) var(--surface-0)}.nav-pills .nav-link{border-radius:.375rem;color:var(--text-secondary)}.nav-pills .nav-link:hover{background-color:var(--surface-hover);color:var(--text-primary)}.nav-pills .nav-link.active{background-color:var(--accent-primary);color:#fff}.text-primary{color:var(--accent-primary)!important}.text-success{color:var(--color-success)!important}.text-warning{color:var(--color-warning)!important}.text-danger{color:var(--color-error)!important}.text-info{color:var(--color-info)!important}.bg-light{background-color:var(--surface-0)!important;color:var(--text-primary)!important}.bg-dark{background-color:var(--bg-elevated)!important;color:var(--text-primary)!important}.border{border-color:var(--border-default)!important}body[data-theme-type=dark]{--theme-is-dark: 1}body[data-theme-type=light]{--theme-is-dark: 0}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html,body{margin:0;padding:0;height:100%;font-family:var(--font-family-base, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);background-color:var(--bg-base);color:var(--text-primary)}body{padding-top:env(safe-area-inset-top);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);touch-action:manipulation}#app{min-height:100vh}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.loading-container .spinner-border{width:3rem;height:3rem;border-width:.3rem}.loading-container h1{font-weight:600;letter-spacing:-.5px}.loading-container p{font-size:.9rem;opacity:.8}button,a,.btn,.clickable{min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--surface-1);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.text-muted{color:var(--text-muted)!important}.surface{background-color:var(--surface-0)}.list-group-item.task-card{min-height:60px;padding:.6rem .75rem;margin-bottom:0;border-radius:.5rem}.task-card-grid{display:grid;grid-template-columns:auto auto 1fr;gap:.5rem;align-items:start}.task-card-grid.no-checkbox{grid-template-columns:auto 1fr}.task-grid-checkbox{display:flex;align-items:flex-start;padding-top:.2rem}.task-grid-handle{display:flex;align-items:flex-start;padding-top:.1rem}.task-grid-content{display:flex;flex-direction:column;gap:.3rem;min-width:0}.task-title-line{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.task-title-wrapper{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex-grow:1;min-width:0}.task-badges-line{display:flex;flex-wrap:wrap;gap:.3rem .4rem;align-items:center;line-height:1}.task-add-subtask-btn{margin-left:auto;padding:.1rem .25rem!important;line-height:1!important;min-height:auto!important;font-size:.75rem!important;border:none!important;vertical-align:baseline}.task-card .task-title{line-height:1.4;font-size:.95rem;flex-grow:1;transition:color .4s ease}.task-card .task-title.text-decoration-line-through{text-decoration:none!important}.task-card .task-title-text{display:inline-block;position:relative}.task-card.task-completing .task-title-text:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:0;height:2px;background-color:var(--text-muted);animation:strikethrough .4s ease forwards}@keyframes strikethrough{0%{width:0}to{width:100%}}.task-card .task-title.text-decoration-line-through .task-title-text{text-decoration:line-through}.task-card .badge{padding:.2rem .45rem;font-size:.72rem;line-height:1.3;margin-right:.25rem;display:inline-flex;align-items:center;vertical-align:middle;height:fit-content}.task-card .badge i{line-height:1}.task-card .btn-sm.btn-link{padding:.2rem .3rem!important;min-height:unset;min-width:unset;font-size:.95rem;opacity:.7}.task-card .btn-sm.btn-link:hover{opacity:1}.task-card{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:manipulation;-webkit-touch-callout:none;transition:background-color .2s ease}.task-card input,.task-card textarea{user-select:auto;-webkit-user-select:auto}.task-card.task-selected{outline:3px solid var(--accent-primary);outline-offset:-3px;background-color:color-mix(in srgb,var(--accent-primary) 5%,transparent);transition:outline .2s ease,background-color .2s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.tasks-nested-list{margin-left:1rem;padding-left:1rem;border-left:2px solid color-mix(in srgb,var(--accent-primary) 30%,transparent)}.tasks-nested-list:empty{display:none}.st-metadata{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;color:var(--text-primary);margin-right:.5rem}.st-metadata i{font-size:.85rem}.st-metadata i.bi-bell-fill{color:var(--util-color-3)}.st-metadata i.bi-calendar,.st-metadata i.bi-calendar3,.st-metadata i.bi-clock,.st-metadata i.bi-arrow-repeat{color:var(--util-color-5)}.st-metadata.st-overdue,.st-metadata.st-overdue i{color:var(--color-error)}.st-repeat{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;color:var(--text-primary);margin-right:.4rem}.st-repeat i{color:var(--util-color-8);font-size:.85rem}.st-project{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;color:var(--text-primary);margin-right:.4rem}.st-project i{color:var(--item-color);font-size:.85rem}.st-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.1rem .25rem;font-size:.75rem;font-weight:500;color:var(--text-primary)}.task-card .st-tag i,.st-tag i{color:var(--item-color)!important;font-size:.85rem}.pwa-update-banner{position:fixed;bottom:0;left:0;right:0;background:var(--surface-2);border-top:1px solid var(--border-subtle);padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));z-index:9999;animation:slideUp .3s ease-out}.pwa-update-content{display:flex;align-items:center;justify-content:center;gap:.5rem}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}:root{--snackbar-enter-from: translateY(100%);--snackbar-exit-to: translateY(100%);--snackbar-duration-enter: .3s;--snackbar-duration-exit: .25s;--snackbar-easing: cubic-bezier(.4, 0, .2, 1);--snackbar-bottom-offset: calc(env(safe-area-inset-bottom) + 80px + 1rem) ;--snackbar-gap: .5rem}#snackbar-container{position:fixed;bottom:var(--snackbar-bottom-offset);left:1rem;right:1rem;z-index:1058;display:flex;flex-direction:column-reverse;gap:var(--snackbar-gap);pointer-events:none;max-width:400px;margin:0 auto}@media (min-width: 500px){#snackbar-container{left:50%;right:auto;transform:translate(-50%)}}#snackbar-container.above-sheet{bottom:calc(var(--sheet-height, 200px) + env(safe-area-inset-bottom) + 1rem)}body:has(.modal.show) #snackbar-container{z-index:1060}.snackbar{position:relative;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--surface-0);border-radius:.75rem;box-shadow:0 4px 16px #00000040;pointer-events:auto;overflow:hidden;touch-action:pan-x;user-select:none;will-change:transform,opacity;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:0;transform:var(--snackbar-enter-from);transition:transform var(--snackbar-duration-enter) var(--snackbar-easing),opacity var(--snackbar-duration-enter) var(--snackbar-easing)}.snackbar.show{opacity:1;transform:translateY(0) translate(0)}.snackbar.hiding{opacity:0;transform:var(--snackbar-exit-to);transition-duration:var(--snackbar-duration-exit)}.snackbar.swiping{transition:none}.snackbar-success{border-left-color:var(--color-success)}.snackbar-error{border-left-color:var(--color-error)}.snackbar-warning{border-left-color:var(--color-warning)}.snackbar-info{border-left-color:var(--accent-primary)}.snackbar-icon{font-size:1.25rem;flex-shrink:0;line-height:1}.snackbar-success .snackbar-icon{color:var(--color-success)}.snackbar-error .snackbar-icon{color:var(--color-error)}.snackbar-warning .snackbar-icon{color:var(--color-warning)}.snackbar-info .snackbar-icon{color:var(--accent-primary)}.snackbar-content{flex:1;display:flex;align-items:center;gap:.5rem;min-width:0}.snackbar-message{font-size:.9rem;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.snackbar-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.snackbar-action-btn{background:color-mix(in srgb,var(--accent-primary) 15%,transparent);color:var(--accent-primary);border:none;border-radius:999px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;transition:background .15s ease,transform .1s ease}.snackbar-action-btn:active{background:color-mix(in srgb,var(--accent-primary) 25%,transparent);transform:scale(.95)}@media (hover: hover){.snackbar-action-btn:hover{background:color-mix(in srgb,var(--accent-primary) 25%,transparent)}}.snackbar-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;padding:.5rem;line-height:1;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s ease,color .15s ease}.snackbar-close:active{background:var(--surface-hover);color:var(--text-primary)}@media (hover: hover){.snackbar-close:hover{background:var(--surface-hover);color:var(--text-primary)}}.snackbar-progress{position:absolute;bottom:0;left:0;height:3px;width:100%;background:transparent;overflow:hidden;border-radius:0 0 .75rem}.snackbar-progress:after{content:"";position:absolute;top:0;left:0;height:100%;width:100%;background:var(--accent-primary);transform-origin:left}.snackbar-success .snackbar-progress:after{background:var(--color-success)}.snackbar-error .snackbar-progress:after{background:var(--color-error)}.snackbar-warning .snackbar-progress:after{background:var(--color-warning)}.snackbar-info .snackbar-progress:after{background:var(--accent-primary)}@keyframes snackbar-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.snackbar-progress.running:after{animation:snackbar-progress var(--progress-duration, 4s) linear forwards}.snackbar-progress.paused:after{animation-play-state:paused}.snackbar:nth-child(2){opacity:.9;transform:scale(.95)}.snackbar:nth-child(2).show{transform:translateY(0) scale(.95)}.snackbar:nth-child(n+3){display:none}body[data-theme-type=dark] .snackbar{box-shadow:0 4px 16px #0006}@media (max-width: 360px){:root{--snackbar-bottom-offset: calc(env(safe-area-inset-bottom) + 60px + .75rem) }#snackbar-container{left:.5rem;right:.5rem}.snackbar{padding:.75rem;gap:.5rem}.snackbar-message{font-size:.85rem}.snackbar-action-btn{padding:.4rem .75rem;font-size:.8rem}}.color-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.color-picker-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem;min-height:44px;background:var(--surface-1);border:2px solid var(--border-muted);border-radius:6px;cursor:pointer;transition:all .15s ease;text-align:left}.color-picker-btn:hover{background:var(--surface-2);border-color:var(--border-default)}.color-picker-btn.active{background:var(--surface-2);border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--bg-base),0 0 0 4px var(--accent-primary)}.color-preview{width:24px;height:24px;border-radius:50%;border:1px solid var(--border-muted);flex-shrink:0}.color-label{font-size:.875rem;color:var(--text-primary);flex:1}.color-swatches{display:flex;flex-wrap:wrap;gap:.5rem}.color-swatch{width:44px;height:44px;border:2px solid var(--surface-1);border-radius:8px;cursor:pointer;padding:0;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.color-swatch:hover{transform:scale(1.05);border-color:var(--text-primary)}.color-swatch.active{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--surface-0),0 0 0 4px var(--text-primary);transform:scale(1.05)}.color-swatch:active{transform:scale(.95)}.color-picker-btn:active{transform:scale(.98)}.icons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem;max-height:400px;overflow-y:auto;padding:.5rem;border:1px solid var(--border-muted);border-radius:6px;background:var(--surface-0)}.icon-btn{width:50px;height:50px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;background:var(--surface-1);border:2px solid var(--border-muted);border-radius:6px;cursor:pointer;transition:all .15s ease;font-size:1.25rem;color:var(--text-primary);padding:0;-webkit-tap-highlight-color:transparent}.icon-btn:hover{background:var(--surface-2);border-color:var(--border-default);transform:scale(1.05)}.icon-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-base);box-shadow:0 0 0 2px var(--bg-base),0 0 0 4px var(--accent-primary)}.icon-btn:active{transform:scale(.95)}.icon-btn i{font-size:1.25rem;line-height:1}#icon-search-input{font-size:1rem;padding:.75rem;border:2px solid var(--border-muted);border-radius:6px;background:var(--surface-1);color:var(--text-primary);transition:border-color .15s ease}#icon-search-input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px var(--accent-primary-alpha)}#iconPickerModal .modal-dialog{max-width:600px}#iconPickerModal .modal-body{padding:1.5rem}#iconPickerModal .alert-info{font-size:.875rem;padding:.75rem;background:var(--info-bg, #d1ecf1);border-color:var(--info-border, #bee5eb);color:var(--info-text, #0c5460)}@media (max-width: 576px){.icons-grid{grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:.375rem;max-height:350px}.icon-btn{width:48px;height:48px;font-size:1.125rem}#iconPickerModal .modal-dialog{margin:.5rem}}.icon-btn-wrapper{position:relative;display:inline-block}.pack-badge{position:absolute;top:-4px;right:-4px;background:var(--accent-primary);color:var(--bg-base);font-size:.625rem;font-weight:700;padding:2px 4px;border-radius:3px;line-height:1;pointer-events:none;box-shadow:0 1px 3px #0000004d;z-index:10}.icons-grid.loading{opacity:.5;pointer-events:none}.icons-grid.loading:after{content:"Loading icons...";display:block;text-align:center;padding:2rem;color:var(--text-muted)}.color-swatch-btn{width:32px;height:32px;border:2px solid var(--border-muted);border-radius:6px;cursor:pointer;padding:0;transition:all .15s ease;background:none}.color-swatch-btn:hover{transform:scale(1.1);border-color:var(--text-primary)}.color-swatch-btn:active{transform:scale(.95)}.color-preview-circle{display:inline-block;width:20px;height:20px;border-radius:50%;border:1px solid var(--border-muted);vertical-align:middle}#edit-project-form{padding:.75rem;background:var(--surface-1);border:1px solid var(--border-muted);border-radius:6px}#edit-project-form .form-label{color:var(--text-secondary);margin-bottom:.5rem}#edit-project-form .input-group{flex-wrap:nowrap}#edit-project-form .input-group .form-control{flex:1;min-width:0}#edit-project-form .input-group .btn{flex-shrink:0}#project-color-dropdown .dropdown-menu{min-width:200px!important;padding:.5rem}@media (max-width: 576px){.color-swatch-btn{width:36px;height:36px}}.task-card input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;border-radius:.25rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;border:2px solid var(--text-secondary)!important;background:transparent;transition:all .2s ease;position:relative;flex-shrink:0}.task-card input[type=checkbox]:hover{background:var(--surface-hover)}.task-card input[type=checkbox]:checked{background-image:none!important}.task-card input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-primary);font-size:.85rem;font-weight:700}.task-card input[type=checkbox][data-priority="1"]{border-color:var(--color-error)!important}.task-card input[type=checkbox][data-priority="1"]:hover{box-shadow:0 0 0 3px rgba(var(--color-error-rgb),.2)!important}.task-card input[type=checkbox][data-priority="1"]:checked{background:var(--color-error)!important;border-color:var(--color-error)!important;box-shadow:0 0 8px rgba(var(--color-error-rgb),.5)!important}.task-card input[type=checkbox][data-priority="2"]{border-color:var(--color-warning)!important}.task-card input[type=checkbox][data-priority="2"]:hover{box-shadow:0 0 0 3px rgba(var(--color-warning-rgb),.2)!important}.task-card input[type=checkbox][data-priority="2"]:checked{background:var(--color-warning)!important;border-color:var(--color-warning)!important;box-shadow:0 0 8px rgba(var(--color-warning-rgb),.5)!important}.task-card input[type=checkbox][data-priority="3"]{border-color:var(--color-info)!important}.task-card input[type=checkbox][data-priority="3"]:hover{box-shadow:0 0 0 3px rgba(var(--color-info-rgb),.2)!important}.task-card input[type=checkbox][data-priority="3"]:checked{background:var(--color-info)!important;border-color:var(--color-info)!important;box-shadow:0 0 8px rgba(var(--color-info-rgb),.5)!important}.task-card input[type=checkbox][data-priority="4"]{border-color:var(--color-success)!important}.task-card input[type=checkbox][data-priority="4"]:hover{box-shadow:0 0 0 3px rgba(var(--color-success-rgb),.2)!important}.task-card input[type=checkbox][data-priority="4"]:checked{background:var(--color-success)!important;border-color:var(--color-success)!important;box-shadow:0 0 8px rgba(var(--color-success-rgb),.5)!important}.task-card input[type=checkbox][data-priority="5"]{border-color:var(--text-secondary)!important}.task-card input[type=checkbox][data-priority="5"]:hover{background:var(--surface-hover);box-shadow:none!important}.task-card input[type=checkbox][data-priority="5"]:checked{background:var(--text-secondary)!important;border-color:var(--text-secondary)!important;box-shadow:none!important}.task-context-menu{position:fixed;z-index:9999;background:var(--surface-2);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;padding:4px;display:none}.context-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:transparent;color:var(--text-primary);font-size:15px;text-align:left;cursor:pointer;border-radius:6px;transition:background .2s ease;min-height:44px}.context-menu-item:hover,.context-menu-item:active{background:var(--surface-3)}.context-menu-item.danger{color:var(--danger, #ef4444)}.context-menu-item.danger:hover,.context-menu-item.danger:active{background:var(--danger-bg, rgba(239, 68, 68, .1))}.context-menu-item i{font-size:18px;width:20px;text-align:center}.context-menu-item span{flex:1;font-weight:500}.context-menu-item:active{transform:scale(.98)}.quick-subtask-container{padding:.75rem 1rem;background:var(--surface-0);border-left:3px solid var(--accent-primary);margin-left:1rem;margin-bottom:.5rem;border-radius:4px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quick-subtask-input{font-size:.875rem;border-color:var(--border-color);background:var(--surface-1);color:var(--text-primary)}.quick-subtask-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 .2rem rgba(var(--accent-primary-rgb),.25);background:var(--surface-1)}.quick-subtask-input::placeholder{color:var(--text-muted);opacity:.6}.quick-subtask-submit,.quick-subtask-modal{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.quick-subtask-submit{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--surface-0)}.quick-subtask-submit:hover{background:var(--accent-secondary);border-color:var(--accent-secondary)}.quick-subtask-modal{border-color:var(--border-color);color:var(--text-secondary)}.quick-subtask-modal:hover{background:var(--surface-2);border-color:var(--accent-primary);color:var(--accent-primary)}.quick-subtask-preview{min-height:0;transition:all .2s ease}.quick-subtask-preview:empty{display:none}@media (max-width: 768px){.quick-subtask-container{padding:.5rem .75rem;margin-left:.5rem}.quick-subtask-input{font-size:1rem}}.task-drag-handle{display:inline-flex;align-items:center;justify-content:center;min-width:44px;cursor:grab;color:var(--text-secondary);opacity:.6;transition:opacity .2s ease,color .2s ease;flex-shrink:0;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:none;-ms-touch-action:none}.task-drag-handle:hover{opacity:1;color:var(--accent-primary)}.task-drag-handle:active{cursor:grabbing}.task-drag-handle i{font-size:1.2rem}.task-drag-ghost{height:4px!important;background-color:var(--accent-primary)!important;border:none!important;margin:16px 0!important;padding:0!important;opacity:.9!important;overflow:hidden!important;box-shadow:0 0 8px var(--accent-primary)}.task-drag-ghost *{display:none!important;min-height:0!important;max-height:0!important;margin:0!important;padding:0!important;border:none!important}.task-drag-chosen{box-shadow:0 4px 16px #00000040;z-index:100;cursor:grabbing!important}.task-dragging{opacity:.9;cursor:grabbing!important;box-shadow:0 8px 24px #0006;transform:scale(1.05);z-index:9999!important}.task-dragging *{cursor:grabbing!important}body.sortable-fallback-active .tasks-nested-list{min-height:40px;padding:6px}body.sortable-fallback-active .tasks-nested-list:empty{min-height:50px;padding:10px;opacity:.3;display:block!important}.drop-invalid{background-color:var(--util-color-11)!important;opacity:.5;border:2px dashed var(--util-color-11)!important;cursor:not-allowed!important}.tasks-nested-list.sortable-drag-over{background-color:color-mix(in srgb,var(--accent-primary) 10%,transparent);outline-color:var(--accent-primary);outline-width:3px;opacity:1;animation:pulse .6s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}#tasks-list.sortable-drag-over{background-color:color-mix(in srgb,var(--accent-primary) 5%,transparent)}.task-card{user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.task-card input,.task-card textarea{user-select:text;-webkit-user-select:text}.task-item-wrapper{margin-bottom:0}.task-item-wrapper>.tasks-nested-list{margin-top:4px}body.sortable-fallback-active .task-item-wrapper>.tasks-nested-list{margin-top:12px}#filters-bar{transition:opacity .2s ease-in-out,height .2s ease-in-out}#filters-bar[style*="display: none"]{display:none!important;height:0;margin:0;padding:0;overflow:hidden;opacity:0}.filter-toggle-btn{min-width:44px;min-height:44px;padding:.5rem;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary);transition:all .2s ease}.filter-toggle-btn:hover{background-color:var(--surface-hover);border-color:var(--accent-primary);color:var(--accent-primary)}.filter-toggle-btn:focus{box-shadow:var(--shadow-focus-ring);outline:none}.filter-toggle-btn[aria-expanded=true]{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.chevron-icon{transition:transform .2s ease;font-size:.875rem;margin-left:.125rem}.filter-toggle-btn[aria-expanded=true] .chevron-icon{transform:rotate(180deg)}#reset-filters-btn{min-width:44px;min-height:44px;padding:.5rem;font-size:1.25rem;background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-secondary);transition:all .2s ease}#reset-filters-btn:hover{background-color:var(--color-error);border-color:var(--color-error);color:#fff}#collapse-projects .card,#collapse-tags .card,#collapse-priority .card,#collapse-date .card{background-color:var(--surface-0);border:1px solid var(--border-default)}#collapse-projects .card-body,#collapse-tags .card-body,#collapse-priority .card-body,#collapse-date .card-body{padding:1rem;background-color:var(--surface-0)}#filter-projects-list,#filter-tags-list,#filter-priority-list,#filter-date-list{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}#filter-projects-list button,#filter-tags-list button,#filter-priority-list button,#filter-date-list button{min-height:36px;padding:.375rem .75rem;font-size:.875rem;white-space:nowrap;display:inline-flex;align-items:center;gap:.25rem;background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary);transition:all .15s ease;border-radius:.375rem}#filter-projects-list button:hover,#filter-tags-list button:hover,#filter-priority-list button:hover,#filter-date-list button:hover{background-color:var(--surface-hover);border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}#filter-projects-list button.btn-primary,#filter-tags-list button.btn-primary,#filter-priority-list button.btn-primary,#filter-date-list button.btn-primary{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}#show-project-form-btn,#show-tag-form-btn{background-color:var(--surface-0);border:1px dashed var(--accent-primary);color:var(--accent-primary)}#show-project-form-btn:hover,#show-tag-form-btn:hover{background-color:var(--accent-primary-muted);border-style:solid}#filter-project-form-container,#filter-tag-form-container{margin-top:.75rem;padding:.75rem;background-color:var(--surface-hover);border:1px solid var(--border-default);border-radius:.375rem}#filter-projects-list .badge,#filter-tags-list .badge,#filter-priority-list .badge,#filter-date-list .badge{font-size:.75rem;font-weight:600;padding:.25em .5em;background-color:var(--surface-border);color:var(--text-secondary)}#filter-projects-list button.btn-primary .badge,#filter-tags-list button.btn-primary .badge,#filter-priority-list button.btn-primary .badge,#filter-date-list button.btn-primary .badge{background-color:#fff3;color:#fff}@media (max-width: 576px){#filters-bar{flex-wrap:wrap}.filter-toggle-btn,#reset-filters-btn{min-width:40px;min-height:40px;padding:.375rem}#filter-projects-list,#filter-tags-list,#filter-priority-list,#filter-date-list{gap:.375rem}#filter-projects-list button,#filter-tags-list button,#filter-priority-list button,#filter-date-list button{min-height:32px;padding:.25rem .5rem;font-size:.8125rem}}@media (min-width: 577px) and (max-width: 768px){#filters-bar{gap:.5rem!important}}@media (pointer: coarse){.filter-toggle-btn,#reset-filters-btn{min-width:44px;min-height:44px}#filter-projects-list button,#filter-tags-list button,#filter-priority-list button,#filter-date-list button{min-height:40px;padding:.5rem .875rem}}.filter-sheet-backdrop{position:fixed;inset:0;background:transparent;z-index:1054;opacity:0;pointer-events:none;transition:opacity .3s ease-out}.filter-sheet-backdrop.show{opacity:1;pointer-events:auto}.filter-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--surface-0);border-radius:16px 16px 0 0;padding:0;padding-bottom:env(safe-area-inset-bottom);z-index:1055;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;box-shadow:none;max-height:60vh;display:flex;flex-direction:column}.filter-sheet.show{transform:translateY(0);box-shadow:0 -4px 12px #00000026}body[data-theme-type=dark] .filter-sheet{border-top:1px solid rgba(255,255,255,.1)}body[data-theme-type=dark] .filter-sheet.show{box-shadow:0 -4px 12px #0000004d}.filter-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-default);flex-shrink:0}.filter-sheet-header h6{margin:0;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.filter-sheet-header h6 i{color:var(--accent-primary)}.filter-sheet-close{width:32px;height:32px;padding:0;border:none;background:var(--surface-1);border-radius:50%;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.filter-sheet-close:active{transform:scale(.9);background:var(--surface-2)}.filter-sheet-header-actions{display:flex;gap:.5rem;align-items:center}.filter-sheet-pin{width:32px;height:32px;padding:0;border:none;background:var(--surface-1);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;border-radius:50%}.filter-sheet-pin:active{transform:scale(.9);background:var(--surface-2)}.filter-sheet-pin.pinned{background:color-mix(in srgb,var(--accent-primary) 20%,var(--surface-1));color:var(--accent-primary)}.filter-sheet-pin.pinned i{transform:rotate(-45deg)}.filter-sheet-content{flex:1;overflow-y:auto;padding:1rem;-webkit-overflow-scrolling:touch}.filter-sheet-options{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-start}.filter-sheet-options button{min-height:40px;padding:.5rem .875rem;font-size:.875rem;white-space:nowrap;display:inline-flex;align-items:center;gap:.375rem;background-color:var(--surface-0);border:1px solid var(--border-default);color:var(--text-primary);transition:all .15s ease;border-radius:.5rem;cursor:pointer}.filter-sheet-options button:active{transform:scale(.95)}.filter-sheet-options button.active,.filter-sheet-options button.btn-primary{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.filter-sheet-options button .badge{font-size:.7rem;font-weight:600;padding:.2em .4em;background-color:var(--surface-border);color:var(--text-secondary);border-radius:.25rem}.filter-sheet-options button.active .badge,.filter-sheet-options button.btn-primary .badge{background-color:#fff3;color:#fff}.filter-sheet-options button i:first-child{font-size:1rem}.filter-sheet-empty{text-align:center;padding:2rem 1rem;color:var(--text-muted)}.filter-sheet-empty i{font-size:2rem;margin-bottom:.5rem;display:block}.filter-sheet-back{width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--accent-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;transition:all .15s ease}.filter-sheet-back:active{transform:scale(.9);opacity:.7}.filter-sheet-header:has(.filter-sheet-back){justify-content:space-between}.filter-sheet-header:has(.filter-sheet-back) h6{flex:1;text-align:center}.filter-menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.filter-menu-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem 1rem;background:var(--surface-1);border:1px solid var(--border-default);border-radius:.75rem;color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .15s ease;position:relative}.filter-menu-item i{font-size:1.5rem;color:var(--accent-primary)}.filter-menu-item span:not(.filter-menu-badge){font-size:.875rem}.filter-menu-item:active{transform:scale(.95);background:var(--surface-2)}.filter-menu-badge{position:absolute;top:.5rem;right:.5rem;min-width:20px;height:20px;padding:0 .375rem;font-size:.7rem;font-weight:600;background:var(--accent-primary);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center}.filter-menu-pinned-indicator{position:absolute;top:.5rem;left:.5rem;font-size:.75rem;color:var(--accent-primary);opacity:0;transition:opacity .15s ease}.filter-menu-pinned-indicator i{font-size:.75rem;transform:rotate(-45deg)}.filter-menu-pinned-indicator.visible{opacity:1}.filter-menu-badge:empty{display:none}.filter-sheet-options .priority-option{border-width:2px}.filter-sheet-options .priority-option i{font-size:.875rem}.filter-sheet-options .priority-p1{border-color:var(--color-error);color:var(--color-error)}.filter-sheet-options .priority-p1 i{color:var(--color-error)}.filter-sheet-options .priority-p1.active{background-color:var(--color-error);border-color:var(--color-error);color:#fff}.filter-sheet-options .priority-p1.active i{color:#fff}.filter-sheet-options .priority-p2{border-color:var(--color-warning);color:var(--color-warning)}.filter-sheet-options .priority-p2 i{color:var(--color-warning)}.filter-sheet-options .priority-p2.active{background-color:var(--color-warning);border-color:var(--color-warning);color:#fff}.filter-sheet-options .priority-p2.active i{color:#fff}.filter-sheet-options .priority-p3{border-color:var(--color-info);color:var(--color-info)}.filter-sheet-options .priority-p3 i{color:var(--color-info)}.filter-sheet-options .priority-p3.active{background-color:var(--color-info);border-color:var(--color-info);color:#fff}.filter-sheet-options .priority-p3.active i{color:#fff}.filter-sheet-options .priority-p4{border-color:var(--color-success);color:var(--color-success)}.filter-sheet-options .priority-p4 i{color:var(--color-success)}.filter-sheet-options .priority-p4.active{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.filter-sheet-options .priority-p4.active i{color:#fff}.filter-sheet-options .priority-p5{border-color:var(--text-secondary);color:var(--text-secondary)}.filter-sheet-options .priority-p5 i{color:var(--text-secondary)}.filter-sheet-options .priority-p5.active{background-color:var(--text-secondary);border-color:var(--text-secondary);color:#fff}.filter-sheet-options .priority-p5.active i{color:#fff}.floating-ui-container{position:fixed;bottom:calc(env(safe-area-inset-bottom) + 90px + var(--pinned-banners-height, 0px));right:1rem;display:flex;flex-direction:column-reverse;align-items:flex-end;gap:.75rem;z-index:1056;pointer-events:none;transition:bottom .3s cubic-bezier(.4,0,.2,1)}.floating-ui-container.above-sheet{bottom:calc(var(--sheet-height, 200px) + env(safe-area-inset-bottom) + var(--pinned-banners-height, 0px) + 20px)}body:has(.modal.show) .floating-ui-container{display:none!important}.floating-ui-pills{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.5rem;max-width:calc(100vw - 2rem)}.floating-ui-pills:empty{display:none}.floating-ui-pills>*{pointer-events:auto}.floating-ui-fabs{display:flex;flex-direction:column;gap:.75rem;align-items:center}.floating-ui-fabs>*{pointer-events:auto}.filter-pill{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:500;border-radius:999px;border:none;cursor:pointer;transition:all .15s ease;background:color-mix(in srgb,var(--surface-0) 30%,transparent);color:var(--text-primary);box-shadow:0 2px 8px #00000026;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.filter-pill i:first-child{font-size:.75rem}.filter-pill .pill-close{font-size:.625rem;opacity:.6;margin-left:.125rem}.filter-pill:active{transform:scale(.95)}@media (hover: hover){.filter-pill:hover{background:color-mix(in srgb,var(--surface-hover) 50%,transparent)}.filter-pill:hover .pill-close{opacity:1;color:var(--color-error)}}.filter-pill.pill-project{background:color-mix(in srgb,var(--accent-primary) 15%,transparent);color:var(--accent-primary)}.filter-pill.pill-tag{background:color-mix(in srgb,var(--color-info) 15%,transparent);color:var(--color-info)}.filter-pill.pill-date{background:color-mix(in srgb,var(--surface-1) 30%,transparent);color:var(--text-secondary)}.filter-pill.pill-priority-1{background:color-mix(in srgb,var(--color-error) 15%,transparent);color:var(--color-error)}.filter-pill.pill-priority-2{background:color-mix(in srgb,var(--color-warning) 15%,transparent);color:var(--color-warning)}.filter-pill.pill-priority-3{background:color-mix(in srgb,var(--color-info) 15%,transparent);color:var(--color-info)}.filter-pill.pill-priority-4{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}.filter-pill.pill-priority-5{background:color-mix(in srgb,var(--surface-1) 30%,transparent);color:var(--text-secondary)}.filter-pill.pill-reset{background:color-mix(in srgb,var(--surface-0) 30%,transparent);color:var(--text-secondary);padding:.5rem .75rem}.filter-pill.pill-reset:active{background:var(--color-error);color:#fff}.floating-fab{width:56px;height:56px;border-radius:50%;background:color-mix(in srgb,var(--accent-primary) 30%,transparent);color:var(--bg-base);border:none;box-shadow:0 6px 12px #00000026,0 3px 6px #0000001a;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.floating-fab i{font-size:1.5rem}@media (hover: hover){.floating-fab:hover{background:color-mix(in srgb,var(--accent-secondary) 40%,transparent);transform:scale(1.08);box-shadow:0 8px 16px #0003,0 4px 8px #00000026}}.floating-fab:active{transform:scale(.92)}body[data-theme-type=dark] .floating-fab{box-shadow:0 6px 12px #0000004d,0 3px 6px #0003}.floating-fab:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}@media (max-width: 360px){.floating-fab{width:48px;height:48px}.floating-fab i{font-size:1.25rem}.floating-ui-pills{min-height:48px}}.pinned-banners-container{position:fixed;bottom:calc(env(safe-area-inset-bottom) + 70px);left:0;right:0;z-index:1001;display:flex;flex-direction:column-reverse;pointer-events:none;transition:bottom .3s cubic-bezier(.4,0,.2,1)}.pinned-banners-container.above-sheet{bottom:calc(var(--sheet-height, 200px) + env(safe-area-inset-bottom))}.pinned-banners-container:empty{display:none}body:has(.modal.show) .pinned-banners-container{display:none!important}.pinned-banner{position:relative;width:100%;background:color-mix(in srgb,var(--surface-0) 85%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-default);padding:.5rem 0;pointer-events:auto}body[data-theme-type=dark] .pinned-banner{box-shadow:0 -2px 8px #0003}body[data-theme-type=light] .pinned-banner{box-shadow:0 -2px 8px #00000014}.pinned-banner-scroll{display:flex;gap:.5rem;padding:0 1rem;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.pinned-banner-scroll::-webkit-scrollbar{display:none}.pinned-banner-fade{position:absolute;top:0;bottom:0;width:32px;pointer-events:none;opacity:0;transition:opacity .2s ease;z-index:1}.pinned-banner-fade-right{right:0;background:linear-gradient(to left,var(--surface-0),transparent)}.pinned-banner-fade-left{left:0;background:linear-gradient(to right,var(--surface-0),transparent)}.pinned-banner-fade.visible{opacity:1}.pinned-banner-item{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;white-space:nowrap;border:1px solid color-mix(in srgb,var(--accent-primary) 30%,var(--border-default));border-radius:999px;background:var(--surface-1);color:var(--text-primary);cursor:pointer;transition:all .15s ease;flex-shrink:0;box-shadow:0 1px 3px #00000014}.pinned-banner-item i{font-size:.75rem;color:var(--accent-primary);opacity:.8}.pinned-banner-item.active i{color:inherit;opacity:1}.pinned-banner-item.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-base)}.pinned-banner-item:active{transform:scale(.95)}@media (hover: hover){.pinned-banner-item:not(.active):hover{background:var(--surface-hover);border-color:var(--accent-primary)}}.pinned-banner-item.priority-p1.active{background:var(--color-error);border-color:var(--color-error)}.pinned-banner-item.priority-p2.active{background:var(--color-warning);border-color:var(--color-warning)}.pinned-banner-item.priority-p3.active{background:var(--color-info);border-color:var(--color-info)}.pinned-banner-item.priority-p4.active{background:var(--color-success);border-color:var(--color-success)}.pinned-banner-item.priority-p5.active{background:var(--text-secondary);border-color:var(--text-secondary)}.pinned-banner-reset{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid color-mix(in srgb,var(--accent-primary) 30%,var(--border-default));border-radius:50%;background:var(--surface-1);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #00000014}.pinned-banner-reset i{font-size:.875rem}.pinned-banner-reset:active{background:var(--color-error);border-color:var(--color-error);color:#fff;transform:scale(.9)}@media (hover: hover){.pinned-banner-reset:hover{border-color:var(--color-error);color:var(--color-error)}}@media (max-width: 360px){.pinned-banner-item{padding:.25rem .625rem;font-size:.75rem}.pinned-banner-reset{width:28px;height:28px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding-bottom:calc(env(safe-area-inset-bottom) + .5rem);padding-top:.5rem;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);background:var(--surface-0);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-default);user-select:none;-webkit-user-select:none}body[data-theme-type=dark] .bottom-nav{border-top-color:#ffffff1a}.bottom-nav-items{display:flex;justify-content:space-around;align-items:center;max-width:600px;margin:0 auto;position:relative;gap:.5rem}.bottom-nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:60px;min-height:60px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;border-radius:12px;padding:.5rem;flex:1}.bottom-nav-btn i{font-size:1.5rem;margin-bottom:.125rem}.bottom-nav-btn span{font-size:.65rem;font-weight:500;opacity:.8}.bottom-nav-btn.active{color:var(--accent-primary)}.bottom-nav-btn.active i{transform:scale(1.1)}@media (hover: hover){.bottom-nav-btn:hover{color:var(--text-primary);background:var(--surface-1)}.bottom-nav-btn.active:hover{color:var(--accent-primary)}}.bottom-nav-btn:active{transform:scale(.92)}#app{padding-bottom:calc(80px + env(safe-area-inset-bottom))}@media (min-width: 768px){.bottom-nav{max-width:100%}.bottom-nav-items{max-width:500px}}@media (max-width: 360px){.bottom-nav-btn{min-width:50px;min-height:50px}.bottom-nav-btn i{font-size:1.3rem}.bottom-nav-fab{flex:0 0 56px}.bottom-nav-fab button{width:56px;height:56px}}.bottom-nav-btn:focus-visible,.bottom-nav-fab button:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.bottom-nav-btn span{display:none}.bottom-nav{animation:slideUpNav .3s ease-out}@keyframes slideUpNav{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}#tagsProjectsModal .modal-dialog{margin:0;max-width:100%;width:100%;height:100dvh;padding-top:env(safe-area-inset-top)}#tagsProjectsModal .modal-content{height:100%;display:flex;flex-direction:column;border-radius:0;border:none}#tagsProjectsModal .modal-body{flex:1;overflow:hidden;min-height:0;display:flex;flex-direction:column;padding:0}#tagsProjectsModal .tab-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}#tagsProjectsModal .tab-pane{flex:1;display:none;flex-direction:column;overflow:hidden;min-height:0}#tagsProjectsModal .tab-pane.show.active{display:flex}.manage-modal-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;padding-bottom:calc(env(safe-area-inset-bottom) + .75rem);background:var(--surface-0);border-top:1px solid var(--border-default)}.manage-nav-segmented{display:flex;background:var(--surface-1);border-radius:.5rem;padding:.25rem;gap:.25rem}.manage-nav-segment{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;min-width:90px;background:transparent;border:none;border-radius:.375rem;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.manage-nav-segment i{font-size:1rem}.manage-nav-segment:active{transform:scale(.95)}.manage-nav-segment.active{background:var(--surface-0);color:var(--accent-primary);box-shadow:var(--shadow-sm)}.manage-nav-add-btn{width:44px;height:44px;flex-shrink:0;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--accent-primary);color:#fff;border:none;box-shadow:var(--shadow-sm);transition:all .15s ease}.manage-nav-add-btn:active{transform:scale(.9);background:var(--accent-secondary)}.manage-nav-spacer{width:44px;flex-shrink:0}.manage-add-form-area{background:var(--surface-1);border-top:1px solid var(--border-default)}.manage-add-form-area:not(:has(.manage-form-container:not(:empty))){display:none}.manage-form-container{padding:1rem}.manage-form-container:empty{display:none;padding:0}.manage-add-tag-form{display:flex;align-items:center;gap:.5rem}.manage-add-tag-form .input-group{flex:1}.manage-add-tag-form .form-control{border-radius:.5rem 0 0 .5rem;border-right:none}.manage-add-tag-form .btn-save{border-radius:0 .5rem .5rem 0;padding:.5rem .75rem;background:var(--accent-primary);border:1px solid var(--accent-primary);color:#fff}.manage-add-tag-form .btn-save:active{transform:scale(.95)}.manage-add-tag-form .btn-close-form{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer}.manage-add-tag-form .btn-close-form:active{transform:scale(.9);color:var(--color-error)}.manage-add-project-form{display:flex;flex-direction:column;gap:.75rem}.manage-add-project-form .input-row{display:flex;align-items:center;gap:.5rem}.manage-add-project-form .input-group{flex:1;display:flex;align-items:stretch}.manage-add-project-form .btn-icon-picker,.manage-add-project-form .btn-color-picker{width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--surface-0);border:1px solid var(--border-default);color:var(--text-secondary);font-size:1.125rem;cursor:pointer;transition:all .15s ease}.manage-add-project-form .btn-icon-picker{border-radius:.5rem 0 0 .5rem;border-right:none}.manage-add-project-form .btn-color-picker{border-radius:0;border-right:none}.manage-add-project-form .btn-icon-picker:active,.manage-add-project-form .btn-color-picker:active{transform:scale(.95);background:var(--surface-hover)}.manage-add-project-form .btn-color-picker .color-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--surface-0);box-shadow:0 0 0 1px var(--border-default)}.manage-add-project-form .btn-color-picker .bi-paint-bucket{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-warning) 25%,var(--color-success) 50%,var(--color-info) 75%,var(--accent-primary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.manage-add-project-form .form-control{flex:1;border-radius:0;height:44px}.manage-add-project-form .btn-save{width:44px;height:44px;padding:0;border-radius:0 .5rem .5rem 0;background:var(--accent-primary);border:1px solid var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.125rem}.manage-add-project-form .btn-save:active{transform:scale(.95)}.manage-add-project-form .btn-close-form{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;flex-shrink:0}.manage-add-project-form .btn-close-form:active{transform:scale(.9);color:var(--color-error)}.manage-add-project-form .color-swatches-row{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem 0}.manage-add-project-form .color-swatches-row:empty{display:none}.manage-add-project-form .color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s ease}.manage-add-project-form .color-swatch:active{transform:scale(.9)}.manage-add-project-form .color-swatch.selected,.manage-add-project-form .color-swatch:hover{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--surface-0)}#tagsProjectsModal .manage-list{flex:1;overflow-y:auto;padding:1rem;min-height:0;-webkit-overflow-scrolling:touch}.manage-list{display:flex;flex-direction:column;gap:.75rem}.manage-list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:var(--surface-0);border:1px solid var(--surface-border);border-radius:.375rem;transition:background-color .15s ease,border-color .15s ease}.manage-list-item:has(.manage-add-project-form),.manage-list-item:has(.manage-add-tag-form){display:block;padding:.5rem}.manage-list-item .manage-add-project-form,.manage-list-item .manage-add-tag-form{width:100%}@media (hover: hover){.manage-list-item:hover{background-color:var(--surface-hover);border-color:var(--accent-primary)}}.manage-list-item-content{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.manage-list-item-icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.manage-list-item-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.manage-list-item-title{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-list-item-meta{font-size:.75rem;color:var(--text-secondary)}.manage-list-item-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.manage-list-item-actions .btn{min-width:44px;min-height:44px;padding:.5rem}.manage-list-item-actions .badge{font-size:.75rem;padding:.375rem .75rem}.manage-list-item-edit-form{padding:.5rem;width:100%}.manage-list-item-edit-form .color-picker-swatch{width:32px;height:32px;border-radius:.25rem;border:2px solid var(--surface-border);cursor:pointer;transition:transform .15s ease,border-color .15s ease}.manage-list-item-edit-form .color-picker-swatch:hover{transform:scale(1.1);border-color:var(--accent-primary)}.manage-list-item-edit-form .color-picker-swatch.selected{border-color:var(--accent-primary);border-width:3px}.manage-list p.text-muted{text-align:center;padding:2rem 1rem;margin:0}@media (max-width: 576px){.manage-list-item{padding:.625rem .75rem}.manage-list-item-icon{font-size:1.125rem}.manage-list-item-title{font-size:.9375rem}.manage-list-item-actions .btn{min-width:40px;min-height:40px;padding:.375rem}}.markdown-editor{display:flex;flex-direction:column;gap:.5rem}.markdown-editor .editor-toolbar{display:flex;justify-content:flex-end}.markdown-editor .editor-textarea{min-height:100px;resize:vertical;font-family:inherit;font-size:16px;line-height:1.5;border:1px solid var(--border-default);border-radius:.375rem;background:var(--surface-1);color:var(--text-primary);padding:.75rem;transition:border-color .2s ease}.markdown-editor .editor-textarea:focus{border-color:var(--accent-primary);outline:none}.markdown-editor .editor-textarea::placeholder{color:var(--text-muted)}.markdown-editor .editor-preview{min-height:100px;padding:.75rem;background:var(--surface-0);border:1px solid var(--border-default);border-radius:.375rem;font-size:.95rem;line-height:1.6;color:var(--text-primary)}.markdown-editor .editor-preview p{margin:0 0 .5rem}.markdown-editor .editor-preview p:last-child{margin-bottom:0}.markdown-editor .editor-preview strong{font-weight:600;color:var(--accent-primary)}.markdown-editor .editor-preview em{font-style:italic}.markdown-editor .editor-preview code{background:var(--surface-2);padding:.125rem .375rem;border-radius:.25rem;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:.85em}.markdown-editor .editor-preview a{color:var(--accent-primary);text-decoration:underline}.markdown-editor .editor-preview a:hover{color:var(--accent-secondary)}.markdown-editor .editor-preview ul,.markdown-editor .editor-preview ol{margin:.5rem 0;padding-left:1.5rem}.markdown-editor .editor-preview li{margin-bottom:.25rem}@media (hover: none) and (pointer: coarse){.markdown-editor .editor-textarea{font-size:16px;-webkit-tap-highlight-color:transparent}}body[data-theme-type=dark] .markdown-editor .editor-preview code{background:var(--surface-0)}#settingsModal .modal-dialog{margin:0;max-width:100%;width:100%;height:100dvh;padding-top:env(safe-area-inset-top)}#settingsModal .modal-content{height:100%;display:flex;flex-direction:column;border-radius:0;border:none}#settingsModal .modal-body{flex:1;overflow:hidden;min-height:0}.settings-modal-body{position:relative;height:100%;overflow:hidden;padding:0!important}.settings-menu{position:relative;z-index:1;background:var(--surface-0);height:100%;overflow-y:auto}.settings-menu .list-group-item{background:var(--surface-0);color:var(--text-primary);border-color:var(--border-default);padding:1rem;cursor:pointer;transition:background-color .2s ease}.settings-menu .list-group-item:hover{background:var(--surface-1)}.settings-menu .list-group-item:active{background:var(--surface-2)}.settings-menu .list-group-item i.bi-chevron-right{color:var(--text-secondary);font-size:.9rem}.settings-menu .list-group-item i:not(.bi-chevron-right){color:var(--accent-primary);font-size:1.1rem}.settings-panel{position:absolute;inset:0;background:var(--surface-0);z-index:10;transform:translate(100%);transition:transform .3s ease-in-out;display:flex;flex-direction:column}.settings-panel.show{transform:translate(0);display:flex!important}.settings-panel-header{display:none}.settings-panel-header button{color:var(--accent-primary);font-size:1rem;display:flex;align-items:center;gap:.25rem}.settings-panel-header button:hover{color:var(--accent-primary);opacity:.8}.settings-panel-header h6{font-weight:600;color:var(--text-primary)}.settings-panel-content{flex:1;overflow-y:auto;padding:1.5rem;background:var(--surface-0)}.settings-panel-content::-webkit-scrollbar{width:8px}.settings-panel-content::-webkit-scrollbar-track{background:var(--surface-1);border-radius:4px}.settings-panel-content::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:4px}.settings-panel-content::-webkit-scrollbar-thumb:hover{background:var(--surface-4)}@media (max-width: 576px){.settings-menu .list-group-item{padding:.875rem}.settings-panel-content{padding:1rem}}body[data-theme-type=dark] .settings-menu .list-group-item:hover{background:var(--surface-2)}body[data-theme-type=dark] .settings-menu .list-group-item:active{background:var(--surface-3)}.settings-panel-content h6{color:var(--text-primary);font-weight:600}.settings-panel-content p{color:var(--text-secondary)}.settings-panel-content .form-label{color:var(--text-primary);font-weight:500}.settings-panel-content .form-text{color:var(--text-secondary)}.settings-panel-content .text-muted{color:var(--text-secondary)!important}.settings-panel-content .small{font-size:.875rem}.settings-panel-content .alert{background:var(--surface-1);border-color:var(--border-default);color:var(--text-primary)}#nav-buttons-reorder-list{display:flex;justify-content:space-between;gap:.25rem}.nav-reorder-chip{display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.5rem .25rem;min-width:52px;background:var(--surface-1);border-radius:10px;border:1px solid var(--border-default);color:var(--text-secondary);font-size:.65rem;font-weight:500;cursor:grab;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.nav-reorder-chip i{color:var(--accent-primary);font-size:1.1rem}.nav-reorder-chip span{white-space:nowrap}.nav-reorder-chip:active{cursor:grabbing;background:var(--surface-2)}#fabs-reorder-list{display:flex;flex-direction:column;gap:.5rem}.nav-reorder-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface-1);border-radius:12px;border:1px solid var(--border-default);cursor:grab;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.nav-reorder-item:active{cursor:grabbing;background:var(--surface-2)}.nav-reorder-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--surface-2);border-radius:8px;color:var(--accent-primary);font-size:1.1rem;flex-shrink:0}.nav-reorder-label{flex:1;font-weight:500;color:var(--text-primary)}.nav-reorder-grip{color:var(--text-muted);font-size:1.1rem}.nav-reorder-ghost{opacity:.4;background:var(--surface-2)!important}.nav-reorder-chosen{opacity:1!important;box-shadow:0 4px 12px #0000004d!important;z-index:1000!important}.quick-add-backdrop{position:fixed;inset:0;background:#00000080;z-index:1054;opacity:0;pointer-events:none;transition:opacity .3s ease-out}.quick-add-backdrop.show{opacity:1;pointer-events:auto}.quick-add-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--surface-0);border-radius:16px 16px 0 0;padding:.5rem 1rem 1rem;padding-bottom:calc(env(safe-area-inset-bottom) + 1rem);z-index:1055;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 12px #00000026;max-height:40vh;display:flex;flex-direction:column}.quick-add-sheet.show{transform:translateY(0)}.quick-add-sheet-content{flex:1;overflow-y:auto;padding-top:.5rem}.quick-add-sheet-content h6{color:var(--text-primary);margin-bottom:1rem}#quick-add-sheet-preview{display:flex;flex-wrap:wrap;gap:.25rem}#quick-add-sheet-preview:not(:empty){margin-bottom:.5rem}#quick-add-sheet-input{border:1px solid var(--border-default);background:var(--surface-1);color:var(--text-primary)}#quick-add-sheet-input:focus{border-color:var(--accent-primary);background:var(--bg-base)}body[data-theme-type=dark] .quick-add-sheet{border-top:1px solid rgba(255,255,255,.1);box-shadow:0 -4px 12px #0000004d}.bulk-action-bar{position:fixed;bottom:0;left:0;right:0;z-index:1040;background:var(--surface-0);border-radius:16px 16px 0 0;padding:1rem;padding-bottom:calc(env(safe-area-inset-bottom) + 1rem);box-shadow:0 -4px 12px #00000026;border-top:1px solid var(--border-default);transform:translateY(0);transition:transform .3s cubic-bezier(.4,0,.2,1)}body[data-theme-type=dark] .bulk-action-bar{border-top:1px solid rgba(255,255,255,.1);box-shadow:0 -4px 12px #0000004d}.bulk-action-bar .bulk-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;color:var(--text-primary)}.bulk-action-bar .bulk-header .bulk-counter{font-size:.95rem}.bulk-action-bar .bulk-header .bulk-counter strong{font-weight:600;color:var(--accent-primary)}.bulk-action-bar .bulk-actions{display:flex;gap:.5rem;justify-content:center}.bulk-action-bar .bulk-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;font-size:.875rem;padding:.5rem .75rem;white-space:nowrap}.bulk-action-bar .bulk-actions .btn i{font-size:1rem}@media (max-width: 360px){.bulk-action-bar .bulk-actions .btn-text{display:none}.bulk-action-bar .bulk-actions .btn{padding:.5rem}}.sync-status-wrapper{position:relative;display:inline-block;min-width:120px;height:1.25rem;text-align:right}.sync-status-wrapper span{position:absolute;right:0;top:50%;transform:translateY(-50%);white-space:nowrap;display:inline-flex;align-items:center}.sync-status-visible{opacity:1;pointer-events:auto}.sync-status-hidden{opacity:0;pointer-events:none}@keyframes sync-glow{0%{filter:drop-shadow(0 0 2px currentColor)}50%{filter:drop-shadow(0 0 6px currentColor)}to{filter:drop-shadow(0 0 2px currentColor)}}.sync-status-glow{animation:sync-glow 2s ease-in-out infinite}#sync-status-icon-passive,#sync-status-text i{font-size:1rem;line-height:1;vertical-align:middle}
