/* Add-task inline visual polish:
   hard override to ensure visible change over 18-global-sidebar.css */

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-card {
  border-radius: 12px !important;
  border: 1px solid #b8c3ff !important;
  background: #ffffff !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.app.app--with-global-nav
  #taskMode
  .list-panel
  #addTaskInlineHold.task-add-inline-open
  .task-ghost-card {
  animation: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-card:focus-within {
  border-color: #9eabff !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-card .task-ghost-input-row.task-row {
  background: #ffffff !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-input {
  font-weight: 400 !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-footer {
  border-top: 1px solid #d9e4f0 !important;
  border-radius: 0 !important;
  background: #ffffff !important;
  padding: 8px 10px !important;
  gap: 8px 10px !important;
  position: relative !important;
  z-index: 3 !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-input-row.task-row {
  position: relative !important;
  z-index: 1 !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-dropdown {
  z-index: 120 !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-dropdown.is-open {
  z-index: 220 !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-menu {
  z-index: 260 !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dashed-ring {
  background: transparent !important;
  border-color: #c4d1e1 !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-btn {
  min-height: 32px !important;
  padding: 0 9px !important;
  border-radius: 6px !important;
  border: 1px solid #dfe7f1 !important;
  background: #ffffff !important;
  color: #5f728d !important;
  font-size: 0.76rem !important;
  font-weight: 600 !important;
  box-shadow: none !important;
  transition:
    border-color 0.14s ease,
    color 0.14s ease !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-btn:hover {
  border-color: #d4dfec !important;
  background: #ffffff !important;
  color: #5b6f89 !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn:hover,
.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-btn:hover,
.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline-wrap:hover {
  border-color: #d4dfec !important;
  background: #ffffff !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline-wrap:focus-within {
  border-color: #d4dfec !important;
  background: #ffffff !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-btn svg {
  color: #8ca0b8 !important;
  width: 13px !important;
  height: 13px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-label {
  color: #7f91ab !important;
  font-weight: 560 !important;
  font-size: 0.68rem !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn {
  min-width: 124px !important;
  gap: 6px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-end-time-btn {
  min-width: 124px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn #tgTimeLabel,
.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn #tgEndTimeLabel {
  display: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline {
  -webkit-appearance: none !important;
  appearance: none !important;
  width: 64px !important;
  min-width: 64px !important;
  max-width: 64px !important;
  height: 22px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #1f3a5a !important;
  font-size: 0.86rem !important;
  font-weight: 700 !important;
  line-height: 22px !important;
  font-family: inherit !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: 0 !important;
  text-align: left !important;
  outline: none !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: text !important;
  caret-color: #1f4d8b !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline:focus,
.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline:active {
  border: 0 !important;
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
  transform: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline::placeholder {
  color: #6f84a0 !important;
  background: transparent !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline::selection {
  color: inherit !important;
  background: rgba(126, 146, 255, 0.28) !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn:focus-within {
  border-color: #d4dfec !important;
  background: #ffffff !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-btn {
  min-width: 114px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline-wrap {
  min-width: 138px !important;
  gap: 5px !important;
}

.app.app--with-global-nav
  #taskMode
  .list-panel
  #addTaskInlineHold
  .task-ghost-attr-btn.task-ghost-prio-high {
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-value {
  min-width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin-left: 6px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #5f728d !important;
  font-size: 0.75rem !important;
  font-weight: 620 !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline {
  width: 38px !important;
  min-width: 38px !important;
  height: 22px !important;
  padding: 0 3px !important;
  border-radius: 6px !important;
  border: 1px solid #e2e9f3 !important;
  background: #f7f9fc !important;
  color: #5f728d !important;
  font-weight: 620 !important;
  font-size: 0.72rem !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline:focus {
  border-color: #cad7e8 !important;
  background: #ffffff !important;
  box-shadow: none !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-menu {
  border: 1px solid #d4ddea !important;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08) !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .tg-kbd {
  background: #edf2f7 !important;
  border-color: #d3dce8 !important;
  box-shadow: none !important;
  padding: 3px 7px !important;
  font-size: 0.67rem !important;
  border-radius: 6px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .tg-save-btn {
  box-shadow: none !important;
  min-height: 32px !important;
  padding: 0 14px !important;
  font-size: 0.84rem !important;
  border-radius: 10px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-actions {
  gap: 7px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .tg-cancel-btn {
  font-size: 0.8rem !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .cancel-text {
  font-size: 0.82rem !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .tg-save-btn svg {
  width: 13px !important;
  height: 13px !important;
}

.app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .tg-save-btn:hover {
  transform: none !important;
  filter: brightness(1.02) !important;
  box-shadow: none !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-card {
  border-color: #6f7cd4 !important;
  background: #1b2839 !important;
  box-shadow: none !important;
}

.dark
  .app.app--with-global-nav
  #taskMode
  .list-panel
  #addTaskInlineHold
  .task-ghost-card:focus-within {
  border-color: #8794ef !important;
  box-shadow: none !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-card .task-ghost-input-row.task-row {
  background: transparent !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-footer {
  border-top-color: #415269 !important;
  border-radius: 0 !important;
  background: transparent !important;
  position: relative !important;
  z-index: 3 !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dashed-ring {
  border-color: #5d6d83 !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-btn {
  border-color: #576b84 !important;
  background: #1d2a3b !important;
  color: #d5dfec !important;
  box-shadow: none !important;
}

.dark
  .app.app--with-global-nav
  #taskMode
  .list-panel
  #addTaskInlineHold
  .task-ghost-attr-btn:hover {
  border-color: #687e9b !important;
  background: #1d2a3b !important;
  color: #e2e8f0 !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn:hover,
.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-btn:hover,
.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline-wrap:hover {
  border-color: #687e9b !important;
  background: #1d2a3b !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-btn svg {
  color: #9fb1c7 !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-label {
  color: #a7b7ca !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-attr-value {
  border: 0 !important;
  background: transparent !important;
  color: #dce6f4 !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline {
  color: #dce6f4 !important;
  caret-color: #a9c3eb !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline::placeholder {
  color: #9cb0c7 !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-inline::selection {
  color: inherit !important;
  background: rgba(146, 170, 255, 0.36) !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-time-btn:focus-within {
  border-color: #687e9b !important;
  background: #1d2a3b !important;
  box-shadow: none !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-dur-inline {
  border-color: #586b84 !important;
  background: #223347 !important;
  color: #dce6f4 !important;
}

.dark
  .app.app--with-global-nav
  #taskMode
  .list-panel
  #addTaskInlineHold
  .task-ghost-dur-inline:focus {
  border-color: #7388a6 !important;
  background: #1b293b !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .task-ghost-priority-menu {
  border-color: #50617b !important;
  background: #1a2738 !important;
  box-shadow: 0 10px 20px rgba(2, 6, 23, 0.3) !important;
}

.dark .app.app--with-global-nav #taskMode .list-panel #addTaskInlineHold .tg-kbd {
  background: #243247 !important;
  border-color: #51637c !important;
  color: #c6d2e1 !important;
}

/* Quick import now uses modal, hide old inline box permanently */
#quickImportBox {
  display: none !important;
}

.modal.qi-modal-shell {
  width: min(540px, 94vw) !important;
  max-width: min(540px, 94vw) !important;
  padding: 0 !important;
  border-radius: 18px !important;
  border: 1px solid #d9e3f0 !important;
  background: #ffffff !important;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14) !important;
  overflow: hidden !important;
  text-align: left !important;
}

.qi-modal-wrap {
  background: #ffffff;
  max-height: min(86vh, 880px);
  overflow: auto;
  display: flex;
  flex-direction: column;
}

.qi-modal-wrap[data-tab="template"] {
  overflow: hidden;
}

.qi-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 28px 14px;
}

.qi-modal-head-left {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.qi-modal-ico {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f3edff;
  color: #6844e4;
  flex-shrink: 0;
}

.qi-modal-ico svg {
  width: 20px;
  height: 20px;
}

.qi-modal-head-text h3 {
  margin: 0 0 4px;
  font-size: 1.6rem;
  line-height: 1.2;
  color: #1f2e44;
  font-weight: 760;
  letter-spacing: -0.015em;
}

.qi-modal-head-text p {
  margin: 0;
  color: #7d8fa8;
  font-size: 0.9rem;
  line-height: 1.45;
}

.qi-modal-close {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #93a5be;
  font-size: 1.45rem;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
}

.qi-modal-close:hover {
  background: #f3f6fb;
  color: #6f82a0;
}

.qi-tab-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 0 28px 12px;
}

.qi-tab-row.qi-tab-row--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.qi-tab-btn {
  height: 50px;
  border-radius: 12px;
  border: 1px solid #dde6f2;
  background: #ffffff;
  color: #667c98;
  font-size: 0.94rem;
  font-weight: 670;
  font-family: inherit;
  cursor: pointer;
  transition: border-color 0.14s ease, color 0.14s ease, background 0.14s ease;
}

.qi-tab-btn:hover {
  border-color: #ccd8e8;
  color: #4f6886;
  background: #fbfdff;
}

.qi-tab-btn.is-active {
  border-color: #bea9ff;
  color: #5f43d7;
  background: #faf7ff;
}

.qi-panel {
  display: none;
  padding: 0 28px;
}

.qi-panel.is-active {
  display: block;
}

.qi-upload-zone {
  min-height: 236px;
  border: 1px dashed #cbb8ff;
  border-radius: 14px;
  background: #fcfbff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 28px 20px;
  text-align: center;
}

.qi-upload-zone.is-dragover {
  border-color: #a182ff;
  background: #f6f2ff;
}

.qi-upload-ring {
  width: 50px;
  height: 50px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #efe8ff;
  color: #6b49e8;
}

.qi-upload-ring svg {
  width: 20px;
  height: 20px;
}

.qi-upload-title {
  margin: 2px 0 0;
  color: #5f44d7;
  font-size: 1.02rem;
  font-weight: 700;
}

.qi-upload-sub {
  margin: 0;
  color: #8ea0b8;
  font-size: 0.88rem;
}

.qi-upload-actions {
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.qi-upload-name {
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #7e90a9;
  font-size: 0.86rem;
}

.qi-file-input {
  display: none;
}

.qi-textarea {
  width: 100%;
  min-height: 230px;
  max-height: 320px;
  border-radius: 14px;
  border: 1px solid #d9e4f1;
  background: #ffffff;
  color: #324963;
  font-size: 0.95rem;
  line-height: 1.7;
  font-family: inherit;
  padding: 14px 15px;
  box-sizing: border-box;
  outline: none;
  resize: vertical;
}

.qi-textarea:focus {
  border-color: #bca8ff;
  box-shadow: 0 0 0 2px rgba(122, 87, 236, 0.11);
}

.qi-template-box {
  min-height: 230px;
  border: 1px solid #e3ebf4;
  border-radius: 14px;
  background: #fbfdff;
  padding: 14px;
}

.qi-modal-wrap[data-tab="template"] .qi-panel[data-qi-panel="template"].is-active {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  position: relative;
}

.qi-modal-wrap[data-tab="template"] .qi-template-box {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.qi-modal-wrap[data-tab="template"] .qi-template-box::-webkit-scrollbar {
  width: 0;
  height: 0;
  background: transparent;
}

.qi-template-tip {
  margin: 0 0 10px;
  color: #7f91a9;
  font-size: 0.88rem;
  line-height: 1.45;
}

.qi-template-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.qi-template-btn {
  height: 44px;
  border-radius: 10px;
  border: 1px solid #dbe4f1;
  background: #ffffff;
  color: #5f748f;
  font-size: 0.9rem;
  font-weight: 640;
  font-family: inherit;
  cursor: pointer;
}

.qi-template-btn:hover {
  border-color: #c8d6e8;
  color: #4f6686;
}

.qi-template-btn.is-std {
  border-color: #c8b6ff;
  color: #5f44d7;
  background: #faf7ff;
}

.qi-template-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.qi-template-add-btn {
  height: 34px;
  padding: 0 12px;
  border-radius: 9px;
  border: 1px solid #d8e3f0;
  background: #ffffff;
  color: #5d7390;
  font-size: 0.82rem;
  font-weight: 650;
  font-family: inherit;
  cursor: pointer;
  flex-shrink: 0;
}

.qi-template-add-btn:hover {
  border-color: #c5d4e8;
  color: #465f81;
}

.qi-template-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.qi-template-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
  border: 1px solid #dbe5f1;
  border-radius: 10px;
  background: #ffffff;
  padding: 9px 10px;
  transition: border-color 0.14s ease, background 0.14s ease;
}

.qi-template-row.is-editing {
  border-color: #bda9ff;
  background: #faf7ff;
}

.qi-template-row-main {
  flex: 1;
  min-width: 0;
  cursor: pointer;
}

.qi-template-row-title {
  margin: 0;
  color: #4d6584;
  font-size: 0.9rem;
  font-weight: 680;
  line-height: 1.3;
}

.qi-template-row-sub {
  margin: 2px 0 0;
  color: #90a1b8;
  font-size: 0.78rem;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.qi-template-row-actions {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.qi-template-action-btn {
  height: 30px;
  min-width: 48px;
  padding: 0 10px;
  border-radius: 8px;
  border: 1px solid #d7e2ef;
  background: #ffffff;
  color: #5b7392;
  font-size: 0.79rem;
  font-weight: 650;
  font-family: inherit;
  cursor: pointer;
}

.qi-template-action-btn:hover {
  border-color: #c4d3e7;
  color: #476184;
}

.qi-template-action-btn.is-soft {
  background: #f8fbff;
}

.qi-template-editor {
  display: none;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid #e7eef7;
}

.qi-template-editor.is-open {
  display: block;
}

.qi-template-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.qi-template-editor-head strong {
  color: #516a89;
  font-size: 0.86rem;
  font-weight: 700;
}

.qi-template-name {
  width: 100%;
  height: 34px;
  border-radius: 9px;
  border: 1px solid #d8e3f0;
  background: #ffffff;
  color: #3f5878;
  padding: 0 10px;
  font-size: 0.84rem;
  font-family: inherit;
  box-sizing: border-box;
  outline: none;
}

.qi-template-name:focus {
  border-color: #b8c8df;
}

.qi-template-editor-input {
  width: 100%;
  min-height: 120px;
  border-radius: 10px;
  border: 1px solid #d8e3f0;
  background: #ffffff;
  color: #3f5878;
  padding: 10px;
  margin-top: 8px;
  resize: vertical;
  font-size: 0.83rem;
  line-height: 1.55;
  font-family: inherit;
  box-sizing: border-box;
  outline: none;
}

.qi-template-editor-input:focus {
  border-color: #b8c8df;
}

.qi-template-editor-actions {
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
  gap: 7px;
  flex-wrap: wrap;
}

.qi-template-ghost-btn,
.qi-template-save-btn {
  height: 34px;
  padding: 0 12px;
  border-radius: 9px;
  font-size: 0.82rem;
  font-weight: 660;
  font-family: inherit;
  cursor: pointer;
}

.qi-template-ghost-btn {
  border: 1px solid #d7e2ef;
  background: #ffffff;
  color: #5b7392;
}

.qi-template-ghost-btn:hover {
  border-color: #c4d3e7;
  color: #476184;
}

.qi-template-save-btn {
  border: 0;
  color: #ffffff;
  background: linear-gradient(135deg, #6948ea, #4f47de);
}

.qi-template-save-btn:hover {
  filter: brightness(1.03);
}

.qi-hint-row {
  margin-top: 12px;
  padding: 0 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.qi-hint-row.qi-hint-row--in-panel {
  padding: 0;
}

.qi-hint-tip {
  color: #91a1b8;
  font-size: 0.84rem;
}

.qi-link-btn {
  border: 0;
  background: transparent;
  color: #6b4ce6;
  font-size: 0.85rem;
  font-weight: 650;
  font-family: inherit;
  cursor: pointer;
  padding: 0;
}

.qi-link-btn:hover {
  color: #5636d8;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.qi-preview-card {
  margin: 12px 28px 0;
  border: 1px solid #e2e8f2;
  border-radius: 12px;
  background: #ffffff;
  overflow: hidden;
}

.qi-preview-card.qi-preview-card--in-panel {
  margin-left: 0;
  margin-right: 0;
}

.qi-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px 8px;
}

.qi-preview-head h4 {
  margin: 0;
  color: #2a3b53;
  font-size: 1rem;
  font-weight: 720;
}

.qi-preview-meta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: #8194ad;
  font-size: 0.82rem;
}

.qi-preview-hint {
  margin: 0;
  padding: 0 14px 10px;
  color: #8b9cb3;
  font-size: 0.82rem;
}

.qi-preview-table-wrap {
  overflow: auto;
  border-top: 1px solid #edf1f7;
}

.qi-preview-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.qi-preview-table th,
.qi-preview-table td {
  border-bottom: 1px solid #eef2f7;
  padding: 9px 12px;
  text-align: left;
  color: #5d718d;
  font-size: 0.84rem;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.qi-preview-table th {
  color: #7d90a9;
  font-weight: 650;
  background: #fbfcff;
}

.qi-preview-empty td {
  text-align: center;
  color: #9aacbf;
  padding: 14px 10px;
}

.qi-pri-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 680;
}

.qi-pri-high {
  color: #c63f3f;
  background: #ffeceb;
}

.qi-pri-mid {
  color: #c07b20;
  background: #fff7e8;
}

.qi-pri-low {
  color: #2a8c4e;
  background: #eaf8f0;
}

.qi-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding: 18px 28px 22px;
}

.qi-cancel-btn,
.qi-primary-btn {
  min-width: 120px;
  height: 48px;
  border-radius: 12px;
  padding: 0 20px;
  font-size: 0.95rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
}

.qi-cancel-btn {
  border: 1px solid #d8e2ef;
  background: #ffffff;
  color: #7388a5;
}

.qi-cancel-btn:hover {
  border-color: #c9d7e8;
  color: #5f7898;
}

.qi-primary-btn {
  border: 0;
  background: linear-gradient(135deg, #6d48ef, #4b45dd);
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(82, 74, 223, 0.22);
}

.qi-primary-btn:hover {
  filter: brightness(1.03);
}

@media (max-width: 900px) {
  .modal.qi-modal-shell {
    width: min(96vw, 540px) !important;
  }

  .qi-modal-head,
  .qi-tab-row,
  .qi-panel,
  .qi-hint-row,
  .qi-modal-foot {
    padding-left: 18px;
    padding-right: 18px;
  }

  .qi-preview-card {
    margin-left: 18px;
    margin-right: 18px;
  }

  .qi-modal-head-text h3 {
    font-size: 1.32rem;
  }
}

@media (max-width: 760px) {
  .qi-tab-row {
    grid-template-columns: 1fr;
  }

  .qi-template-grid {
    grid-template-columns: 1fr;
  }

  .qi-template-top {
    flex-direction: column;
    align-items: stretch;
  }

  .qi-template-add-btn {
    width: 100%;
  }

  .qi-template-row {
    flex-direction: column;
  }

  .qi-template-row-actions {
    justify-content: flex-end;
  }

  .qi-upload-actions {
    flex-direction: column;
    gap: 6px;
  }

  .qi-upload-name {
    max-width: none;
  }

  .qi-hint-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .qi-preview-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .qi-modal-foot {
    flex-direction: column-reverse;
  }

  .qi-cancel-btn,
  .qi-primary-btn {
    width: 100%;
  }
}

.dark .modal.qi-modal-shell {
  border-color: #40546e !important;
  background: #1e2d40 !important;
  box-shadow: 0 24px 54px rgba(0, 0, 0, 0.42) !important;
}

.dark .qi-modal-wrap {
  background: #1e2d40;
}

.dark .qi-modal-head-text h3 {
  color: #ebf3ff;
}

.dark .qi-modal-head-text p,
.dark .qi-upload-sub,
.dark .qi-upload-name,
.dark .qi-template-tip,
.dark .qi-hint-tip,
.dark .qi-preview-hint,
.dark .qi-preview-meta {
  color: #9eb2c8;
}

.dark .qi-modal-close:hover {
  background: #2a3a4f;
  color: #c9d8ea;
}

.dark .qi-tab-btn,
.dark .qi-template-btn,
.dark .qi-cancel-btn {
  border-color: #4c6079;
  background: #223246;
  color: #b6c9df;
}

.dark .qi-tab-btn:hover,
.dark .qi-template-btn:hover,
.dark .qi-cancel-btn:hover {
  border-color: #647d9c;
  color: #dbe7f6;
}

.dark .qi-tab-btn.is-active,
.dark .qi-template-btn.is-std {
  border-color: #8f78ef;
  background: #2b2948;
  color: #c8b8ff;
}

.dark .qi-template-row {
  border-color: #4c6079;
  background: #223246;
}

.dark .qi-template-row.is-editing {
  border-color: #8f78ef;
  background: #2b2948;
}

.dark .qi-template-row-title {
  color: #c2d5eb;
}

.dark .qi-template-row-sub {
  color: #93a8c0;
}

.dark .qi-template-add-btn,
.dark .qi-template-action-btn,
.dark .qi-template-ghost-btn {
  border-color: #4f647e;
  background: #24364b;
  color: #b6c9df;
}

.dark .qi-template-add-btn:hover,
.dark .qi-template-action-btn:hover,
.dark .qi-template-ghost-btn:hover {
  border-color: #677f9f;
  color: #dbe7f6;
}

.dark .qi-template-editor {
  border-top-color: #3f556f;
}

.dark .qi-template-editor-head strong {
  color: #bfd3ea;
}

.dark .qi-template-name,
.dark .qi-template-editor-input {
  border-color: #4f647e;
  background: #1f3044;
  color: #dbe7f6;
}

.dark .qi-template-name:focus,
.dark .qi-template-editor-input:focus {
  border-color: #8f78ef;
}

.dark .qi-upload-zone {
  border-color: #7360c1;
  background: #243145;
}

.dark .qi-upload-zone.is-dragover {
  background: #2a3550;
}

.dark .qi-textarea,
.dark .qi-template-box,
.dark .qi-preview-card {
  border-color: #475d76;
  background: #1f2f43;
  color: #dce8f7;
}

.dark .qi-textarea:focus {
  border-color: #8f78ef;
  box-shadow: 0 0 0 2px rgba(143, 120, 239, 0.23);
}

.dark .qi-preview-table-wrap {
  border-top-color: #344960;
}

.dark .qi-preview-table th,
.dark .qi-preview-table td {
  border-bottom-color: #30475e;
  color: #aec2d8;
}

.dark .qi-preview-table th {
  color: #bfd2e6;
  background: #25364b;
}

#taskMode .list-panel.task-main-scroll-host {
  position: relative;
}

#taskMode .list-panel .tasks,
.app.app--with-global-nav #taskMode .list-panel .tasks,
#taskMode .list-panel.task-main-scroll-host .tasks {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

#taskMode .list-panel .tasks::-webkit-scrollbar,
.app.app--with-global-nav #taskMode .list-panel .tasks::-webkit-scrollbar,
#taskMode .list-panel.task-main-scroll-host .tasks::-webkit-scrollbar {
  width: 0;
  height: 0;
  background: transparent;
}

/* 子任务标签：全部完成时，整颗标签（图标 + 数字）播放划线动画。 */
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline {
  position: relative !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill .stp-strike-line,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn .stp-strike-line,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill .stp-strike-line,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn .stp-strike-line {
  display: block !important;
  position: absolute !important;
  left: 1px !important;
  right: 1px !important;
  top: 50% !important;
  height: 1.5px !important;
  border-radius: 999px !important;
  background: currentColor !important;
  transform: translateY(-50%) scaleX(1);
  transform-origin: left center !important;
  opacity: .50;
  pointer-events: none !important;
  z-index: 2 !important;
  will-change: transform, opacity;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill .stp-strike-line[data-strike-animate="1"],
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn .stp-strike-line[data-strike-animate="1"],
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill .stp-strike-line[data-strike-animate="1"],
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn .stp-strike-line[data-strike-animate="1"] {
  transform: translateY(-50%) scaleX(0);
  opacity: .36;
}

/* Subtask pill + stable action area (single-source override) */
#taskMode .list-panel #tList .task-item:not(.archived-item) > .task-row > .task-strike-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item:not(.archived-item) > .task-row > .task-strike-wrap {
  flex: 1 1 auto;
  min-width: 0;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .task-row,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .task-row {
  padding-bottom: 6px !important;
}

#taskMode .list-panel #tList .task-item:not(.archived-item) > .task-row > .task-actions,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item:not(.archived-item) > .task-row > .task-actions {
  flex: 0 0 114px !important;
  width: 114px !important;
  min-width: 114px !important;
  margin-left: 12px !important;
  align-self: flex-start !important;
  justify-content: flex-end !important;
  contain: layout paint;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks .task-row-center > .task-time-col,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks .task-row-center > .task-time-col {
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  align-items: baseline !important;
  column-gap: 10px !important;
  row-gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

#taskMode .list-panel #tList,
.app.app--with-global-nav #taskMode .list-panel #tList {
  --task-guide-line-tone: #d8dde5 !important;
}

.dark #taskMode .list-panel #tList,
.dark .app.app--with-global-nav #taskMode .list-panel #tList {
  --task-guide-line-tone: #d8dde5 !important;
}

#taskMode .list-panel #tList .task-expand-area .exp-block.exp-block--sub,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .exp-block.exp-block--sub {
  --subtask-guide-line-faint: var(--task-guide-line-tone) !important;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks .task-row-center > .task-time-col .task-time-sep,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks .task-row-center > .task-time-col .task-time-sep {
  display: inline-flex !important;
  align-self: center !important;
  flex: 0 0 1px !important;
  width: 1px !important;
  height: 15px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  transform: scaleX(.32) !important;
  transform-origin: center !important;
  opacity: 1 !important;
  background: var(--task-guide-line-tone) !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline {
  display: inline-flex !important;
  align-items: center !important;
  align-self: baseline !important;
  gap: 4px !important;
  min-height: 22px !important;
  padding: 2px 0 !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  color: #4a90e4 !important;
  font-size: 12px !important;
  font-weight: 540 !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
  text-decoration: none !important;
  vertical-align: middle !important;
  position: relative !important;
  isolation: isolate !important;
  transition: color .2s ease, transform .16s ease !important;
  transform: translateZ(0) !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline > :not(.stp-strike-line),
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline > :not(.stp-strike-line),
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline > :not(.stp-strike-line),
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline > :not(.stp-strike-line) {
  position: relative !important;
  z-index: 1 !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline::before,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline::before {
  content: none !important;
  display: none !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline:hover,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline:hover {
  color: #4a90e4 !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline:hover::before,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline:hover::before {
  content: none !important;
  display: none !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline::after,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline::after,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline::after,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline::after {
  display: none !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-icon,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-icon,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-icon,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: center !important;
  position: relative !important;
  width: 10px !important;
  height: 14px !important;
  min-width: 10px !important;
  min-height: 14px !important;
  flex: 0 0 10px !important;
  color: currentColor !important;
  font-size: 0 !important;
  line-height: 0 !important;
  overflow: visible !important;
  transform: rotate(0deg) !important;
  transform-origin: 50% 50% !important;
  transition: transform .28s cubic-bezier(.4, 0, .2, 1) !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-icon svg,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-icon svg,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-icon svg,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-icon svg,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-icon svg,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-icon svg,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-icon svg,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-icon svg {
  display: none !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-icon::before,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-icon::before,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-icon::before,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-icon::before,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--done .stp-icon::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--done .stp-icon::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 7px !important;
  height: 9px !important;
  background: currentColor !important;
  clip-path: polygon(0 0, 100% 50%, 0 100%) !important;
  border: 0 !important;
  transform: translate(-42%, -50%) !important;
  -webkit-mask: none !important;
  mask: none !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-n,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-n,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-n,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-n,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline .stp-n,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline .stp-n,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline .stp-n,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline .stp-n {
  display: inline-flex !important;
  align-items: center !important;
  align-self: center !important;
  font-size: 12px !important;
  font-weight: 540 !important;
  line-height: 1.2 !important;
  font-variant-numeric: tabular-nums !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--open,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline[aria-expanded="true"],
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"],
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--open,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline[aria-expanded="true"],
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"] {
  color: #4a90e4 !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--open::before,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open::before,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline[aria-expanded="true"]::before,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"]::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--open::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline[aria-expanded="true"]::before,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"]::before {
  content: none !important;
  display: none !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline.sub-task-pill--open .stp-icon,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open .stp-icon,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
#taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--open .stp-icon,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open .stp-icon,
#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline.sub-task-pill--open .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline.sub-task-pill--open .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline.sub-task-pill--open .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline[aria-expanded="true"] .stp-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline[aria-expanded="true"] .stp-icon {
  transform: rotate(90deg) !important;
}

#taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline:active,
#taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline:active,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill.sub-task-pill--inline:active,
.app.app--with-global-nav #taskMode .list-panel #tList .sub-task-pill-btn.sub-task-pill--inline:active {
  transform: scale(.985) !important;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap {
  height: 0;
  opacity: 0 !important;
  transform: translateY(-4px) !important;
  transform-origin: top left !important;
  overflow: hidden !important;
  pointer-events: none !important;
  transition: height .28s cubic-bezier(.22, 1, .36, 1), opacity .22s ease, transform .28s cubic-bezier(.22, 1, .36, 1) !important;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap > .task-expand-area,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap > .task-expand-area {
  min-height: 0 !important;
  overflow: hidden !important;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-open,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-open {
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item {
  animation: subtask-row-reveal .28s cubic-bezier(.22, 1, .36, 1) both;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening {
  animation: subtask-wrap-reveal .28s cubic-bezier(.22, 1, .36, 1) both;
}

#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(1),
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(1) { animation-delay: .02s; }
#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(2),
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(2) { animation-delay: .05s; }
#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(3),
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(3) { animation-delay: .08s; }
#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(4),
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(4) { animation-delay: .11s; }
#taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(5),
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-item--has-subtasks > .exp-bg-wrap.is-subtask-opening .subtask-item:nth-child(5) { animation-delay: .14s; }

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint {
  position: relative !important;
  padding: var(--subtask-row-pad-y, 6px) 12px var(--subtask-row-pad-y, 6px) calc(var(--subtask-ring-center-x, 22px) - 8px) !important;
  border-radius: 12px !important;
  background: transparent !important;
  box-shadow: none !important;
  transition: color .22s ease, background-color .22s ease, transform .22s ease !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:hover {
  background: color-mix(in srgb, var(--acc) 7%, #ffffff) !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.dark #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:hover,
.dark .app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:hover {
  background: color-mix(in srgb, #ffffff 8%, transparent) !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:active,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:active {
  transform: translateY(1px) scale(.996) !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint:focus-visible {
  outline: 2px solid color-mix(in srgb, #2563eb 38%, transparent) !important;
  outline-offset: 1px !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-arrow,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-arrow {
  flex: 0 0 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: center !important;
  position: relative !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  margin-right: 4px !important;
  color: currentColor !important;
  transform: rotate(0deg) !important;
  transform-origin: 50% 50% !important;
  transition: transform .28s cubic-bezier(.4, 0, .2, 1) !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-action,
#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-target,
#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-sep,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-target,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-sep {
  display: inline-flex !important;
  align-items: center !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-arrow::before,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-arrow::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 0 !important;
  height: 0 !important;
  border-top: 4px solid transparent !important;
  border-bottom: 4px solid transparent !important;
  border-left: 6px solid currentColor !important;
  transform: translate(-50%, -50%) !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint.is-open .subtask-todo-expand-hint-arrow,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint.is-open .subtask-todo-expand-hint-arrow {
  transform: rotate(-90deg) !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-action,
#taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-target,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint-target {
  font-size: 13px !important;
  font-weight: 500 !important;
  line-height: 1.35 !important;
  letter-spacing: 0 !important;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening {
  animation: subtask-todo-wrap-reveal .26s cubic-bezier(.22, 1, .36, 1) both;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item,
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item {
  animation: subtask-todo-row-reveal .24s cubic-bezier(.22, 1, .36, 1) both;
}

#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(1),
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(1) { animation-delay: .02s; }
#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(2),
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(2) { animation-delay: .05s; }
#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(3),
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(3) { animation-delay: .08s; }
#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(4),
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(4) { animation-delay: .11s; }
#taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(5),
.app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item:nth-child(5) { animation-delay: .14s; }

@keyframes subtask-row-reveal {
  from { opacity: 0; transform: translateY(-3px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes subtask-wrap-reveal {
  from {
    opacity: 0;
    transform: translateY(-4px);
    clip-path: inset(0 0 100% 0);
    -webkit-clip-path: inset(0 0 100% 0);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    clip-path: inset(0 0 0 0);
    -webkit-clip-path: inset(0 0 0 0);
  }
}

@keyframes subtask-todo-wrap-reveal {
  from { opacity: 0; transform: translateY(-3px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes subtask-todo-row-reveal {
  from { opacity: 0; transform: translateY(-2px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap,
  #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint,
  #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening,
  #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item,
  .app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap,
  .app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-expand-hint,
  .app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening,
  .app.app--with-global-nav #taskMode .list-panel #tList .task-expand-area .subtask-todo-wrap.is-opening .subtask-item {
    transition: none !important;
    animation: none !important;
  }
}

/* 本周主视图：轻量 + 舒适。 */
#taskMode .list-panel #tList .week-view,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

#taskMode .list-panel #tList .week-view-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
  border: 1px solid color-mix(in srgb, var(--inp-bd) 72%, transparent);
  border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 96%, #f8fbff) 0%, var(--card) 100%);
  padding: 14px 16px;
  box-shadow: 0 6px 20px rgba(15, 23, 42, .04);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-rows: auto auto;
  align-items: center;
  row-gap: 10px;
  column-gap: 14px;
  transition: box-shadow .22s ease, border-color .22s ease, transform .18s ease;
}

#taskMode .list-panel #tList .week-view-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head:hover {
  border-color: color-mix(in srgb, var(--acc) 26%, var(--inp-bd));
  box-shadow: 0 9px 24px rgba(15, 23, 42, .06);
}

#taskMode .list-panel #tList .week-view-top,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-top {
  display: contents;
}

#taskMode .list-panel #tList .week-view-title-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title-group {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  grid-column: 1;
  grid-row: 1;
}

#taskMode .list-panel #tList .week-view-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--text);
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-range,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-range {
  font-size: 12px;
  font-weight: 600;
  color: #8ea0b7;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-progress,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress {
  min-width: 220px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  grid-column: 2;
  grid-row: 2;
  align-self: center;
}

#taskMode .list-panel #tList .week-view-progress-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label {
  white-space: nowrap;
  font-size: 12px;
  font-weight: 600;
  color: #9aacc3;
}

#taskMode .list-panel #tList .week-view-progress-label b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label b {
  font-size: 18px;
  font-weight: 700;
  color: #1f2a44;
}

#taskMode .list-panel #tList .week-view-progress-track,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-track {
  width: 132px;
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--inp-bd) 58%, #edf2f9);
}

#taskMode .list-panel #tList .week-view-progress-fill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-fill {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, color-mix(in srgb, var(--acc) 86%, #5b4ee8), color-mix(in srgb, var(--acc2) 88%, #8b5cf6));
  transition: width .34s cubic-bezier(.22, 1, .36, 1);
}

#taskMode .list-panel #tList .week-view-stats,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stats {
  margin-top: 0;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0;
  grid-column: 1;
  grid-row: 2;
  align-self: center;
}

#taskMode .list-panel #tList .week-view-stat,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 26px;
  padding: 0 16px 0 0;
  margin-right: 16px;
  color: #8a9bb2;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
}

#taskMode .list-panel #tList .week-view-stat b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat b {
  font-size: 14px;
  font-weight: 700;
  color: #1f2a44;
}

#taskMode .list-panel #tList .week-view-stat:not(:last-child)::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  width: 1px;
  height: 24px;
  background: color-mix(in srgb, var(--inp-bd) 84%, transparent);
}

#taskMode .list-panel #tList .week-day-grid,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
}

#taskMode .list-panel #tList .week-day-grid.is-split > .week-day-col,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid.is-split > .week-day-col {
  min-width: 0;
  display: grid;
  gap: 12px;
  align-content: start;
}

#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
  position: relative;
  border: 1px solid color-mix(in srgb, var(--inp-bd) 72%, transparent);
  border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 97%, #fff) 0%, color-mix(in srgb, var(--card) 94%, #f8fafc) 100%);
  overflow: hidden;
  align-self: start;
  animation: week-card-rise .28s cubic-bezier(.22, 1, .36, 1) both;
  animation-delay: var(--week-delay, 0ms);
  transition: border-color .22s ease, box-shadow .22s ease, transform .18s ease;
}

#taskMode .list-panel #tList .week-day-card::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  top: 0;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--inp-bd) 78%, #fff), transparent);
}

#taskMode .list-panel #tList .week-day-card.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today {
  border-color: color-mix(in srgb, var(--acc) 40%, var(--inp-bd));
}

#taskMode .list-panel #tList .week-day-card.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus {
  border-color: color-mix(in srgb, var(--acc) 30%, var(--inp-bd));
  box-shadow: 0 10px 26px color-mix(in srgb, var(--acc) 14%, transparent);
}

#taskMode .list-panel #tList .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 10px;
  row-gap: 4px;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
  padding: 12px 13px 10px;
  transition: background .22s ease, transform .16s ease;
}

#taskMode .list-panel #tList .week-day-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:hover {
  background: color-mix(in srgb, var(--hov) 52%, transparent);
}

#taskMode .list-panel #tList .week-day-head:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:active {
  transform: translateY(1px);
}

#taskMode .list-panel #tList .week-day-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-name {
  font-size: 14px;
  font-weight: 650;
  color: var(--text);
}

#taskMode .list-panel #tList .week-day-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-meta {
  grid-column: 1;
  font-size: 12px;
  color: var(--text2);
}

#taskMode .list-panel #tList .week-day-meta:empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-meta:empty {
  display: none;
}

#taskMode .list-panel .tasks,
.app.app--with-global-nav #taskMode .list-panel .tasks {
  scrollbar-gutter: stable;
}

#taskMode .list-panel #tList .week-day-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count {
  grid-column: 2;
  grid-row: 1 / span 2;
  justify-self: end;
  align-self: center;
  min-width: 22px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 7px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text2);
  background: color-mix(in srgb, var(--hov) 88%, #fff);
}

#taskMode .list-panel #tList .week-task-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list {
  display: grid;
  gap: 7px;
  padding: 2px 10px 11px;
  scrollbar-gutter: stable;
  transition: max-height .24s ease, opacity .2s ease;
}

#taskMode .list-panel #tList .week-task-list.is-scroll,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll {
  max-height: 404px;
  overflow-y: auto;
  scrollbar-gutter: stable;
  overscroll-behavior: contain;
  padding-right: 4px;
}

#taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar {
  width: 6px;
}

#taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar-thumb,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--inp-bd) 84%, transparent);
}

#taskMode .list-panel #tList .week-task-item,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item {
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--inp-bd) 74%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 97%, #fff) 0%, color-mix(in srgb, var(--card) 94%, #f8fafc) 100%);
  border-radius: 12px;
  padding: 10px 11px;
  display: grid;
  grid-template-columns: 8px 1fr auto;
  align-items: center;
  gap: 9px;
  cursor: pointer;
  text-align: left;
  transition: transform .16s ease, background .18s ease, box-shadow .18s ease, border-color .18s ease;
}

#taskMode .list-panel #tList .week-task-item:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover {
  border-color: color-mix(in srgb, var(--acc) 24%, var(--inp-bd));
  background: color-mix(in srgb, var(--card) 98%, #fff);
  box-shadow: 0 10px 20px rgba(15, 23, 42, .06);
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-task-item:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:active {
  transform: translateY(0) scale(.996);
}

#taskMode .list-panel #tList .week-task-marker,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--text3) 62%, transparent);
}

#taskMode .list-panel #tList .week-task-item.is-high .week-task-marker,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-high .week-task-marker {
  background: #fb7185;
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-marker,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-marker {
  background: #22c55e;
}

#taskMode .list-panel #tList .week-task-main,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-main {
  min-width: 0;
  display: grid;
  gap: 2px;
}

#taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title {
  font-size: 13px;
  font-weight: 620;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#taskMode .list-panel #tList .week-task-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta {
  display: flex;
  align-items: center;
  min-height: 18px;
  font-size: 11px;
  color: var(--text3);
}

#taskMode .list-panel #tList .week-task-meta-row,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  min-width: 0;
}

#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 16px;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 540;
  line-height: 1.2;
  white-space: nowrap;
  transition: color .18s ease, transform .14s ease;
}

#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp::before,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge-ico,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge-ico {
  width: 11px;
  height: 11px;
  flex: 0 0 11px;
  margin: 0;
  opacity: .72;
  transform: translateY(0);
}

#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp::before {
  content: "";
  display: block;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E") center / 11px 11px no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E") center / 11px 11px no-repeat;
}

#taskMode .list-panel #tList .week-overdue-copy,
#taskMode .list-panel #tList .week-task-overdue-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-copy,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-overdue-meta {
  --week-overdue-copy-font-size: 12px;
  --week-overdue-copy-font-weight: 720;
  --week-overdue-copy-line-height: 1.2;
  --week-overdue-copy-icon-wrap-size: 12px;
  --week-overdue-copy-icon-size: 11px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #ef4444;
  font-size: var(--week-overdue-copy-font-size);
  font-weight: var(--week-overdue-copy-font-weight);
  line-height: var(--week-overdue-copy-line-height);
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-overdue-copy-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-copy-text {
  display: block;
  line-height: inherit;
}

#taskMode .list-panel #tList .week-overdue-copy--meta .week-overdue-icon-wrap,
#taskMode .list-panel #tList .week-task-overdue-meta .week-overdue-icon-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-copy--meta .week-overdue-icon-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-overdue-meta .week-overdue-icon-wrap {
  width: var(--week-overdue-copy-icon-wrap-size);
  height: var(--week-overdue-copy-icon-wrap-size);
}

#taskMode .list-panel #tList .week-overdue-copy--meta .week-overdue-icon,
#taskMode .list-panel #tList .week-task-overdue-meta .week-overdue-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-copy--meta .week-overdue-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-overdue-meta .week-overdue-icon {
  width: var(--week-overdue-copy-icon-size);
  height: var(--week-overdue-copy-icon-size);
}

#taskMode .list-panel #tList .week-overdue-copy--count .week-overdue-icon-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-copy--count .week-overdue-icon-wrap {
  width: var(--week-overdue-copy-icon-wrap-size);
  height: var(--week-overdue-copy-icon-wrap-size);
}

#taskMode .list-panel #tList .week-overdue-copy--count .week-overdue-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-copy--count .week-overdue-icon {
  width: var(--week-overdue-copy-icon-size);
  height: var(--week-overdue-copy-icon-size);
}

#taskMode .list-panel #tList .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: color-mix(in srgb, var(--text3) 88%, #64748b);
  font-size: 11px;
  font-weight: 560;
  line-height: 1.25;
  white-space: nowrap;
  transition: color .18s ease, transform .14s ease;
}

#taskMode .list-panel #tList .week-task-sub-meta-dot,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
  opacity: .78;
}

#taskMode .list-panel #tList .week-task-sub-meta.is-done,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta.is-done {
  color: #1f7a43;
}

#taskMode .list-panel #tList .week-task-item:hover .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-item:hover .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-item:hover .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover .week-task-sub-meta {
  color: #3f4f66;
  transform: translateY(-.5px);
}

#taskMode .list-panel #tList .week-task-item:active .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-item:active .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-item:active .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:active .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:active .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:active .week-task-sub-meta {
  transform: translateY(0);
}

#taskMode .list-panel #tList .week-task-meta.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta.is-empty {
  color: color-mix(in srgb, var(--text3) 72%, transparent);
}

#taskMode .list-panel #tList .week-task-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-badge {
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 10px;
  font-weight: 700;
  color: #334155;
  background: color-mix(in srgb, #f59e0b 16%, #fff);
}

#taskMode .list-panel #tList .week-task-badge--frozen,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-badge--frozen {
  color: #1d4ed8;
  background: color-mix(in srgb, #3b82f6 16%, #fff);
}

#taskMode .list-panel #tList .week-task-badge--done,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-badge--done {
  color: #166534;
  background: color-mix(in srgb, #22c55e 16%, #fff);
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title {
  text-decoration: line-through;
  text-decoration-thickness: 1.2px;
  color: var(--text2);
}

#taskMode .list-panel #tList .week-day-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty {
  width: 100%;
  min-height: 52px;
  border: 1px solid color-mix(in srgb, var(--inp-bd) 80%, transparent);
  border-radius: 12px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: color-mix(in srgb, var(--text3) 84%, #90a2ba);
  background: color-mix(in srgb, var(--card) 97%, #fff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
  cursor: pointer;
  transition: border-color .18s ease, box-shadow .18s ease, transform .14s ease, background-color .18s ease;
}

#taskMode .list-panel #tList .week-day-empty-dot,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--acc) 38%, #9aa7bc);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--acc) 10%, transparent);
}

#taskMode .list-panel #tList .week-day-empty:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty:hover {
  border-color: color-mix(in srgb, var(--acc) 24%, var(--inp-bd));
  background: color-mix(in srgb, var(--card) 99%, #fff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .84), 0 8px 16px rgba(15, 23, 42, .05);
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-day-empty:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty:active {
  transform: translateY(0) scale(.997);
}

#taskMode .list-panel #tList .week-day-empty:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--acc) 40%, var(--inp-bd));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--acc) 18%, transparent);
}

#taskMode .list-panel #tList .week-task-expand,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand {
  width: calc(100% - 16px);
  margin: 0 8px 10px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: 10px;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 650;
  color: color-mix(in srgb, var(--acc) 78%, #334155);
  background: color-mix(in srgb, var(--card) 94%, #fff);
  border: 1px solid color-mix(in srgb, var(--inp-bd) 76%, transparent);
  box-shadow: 0 3px 10px rgba(15, 23, 42, .04);
  cursor: pointer;
  transition: filter .16s ease, transform .16s ease, box-shadow .2s ease, background .2s ease;
}

#taskMode .list-panel #tList .week-task-expand:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand:hover {
  filter: brightness(1.02);
  background: color-mix(in srgb, var(--card) 98%, #fff);
  border-color: color-mix(in srgb, var(--acc) 20%, var(--inp-bd));
  box-shadow: 0 7px 16px rgba(15, 23, 42, .07);
}

#taskMode .list-panel #tList .week-task-expand:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand:active {
  transform: translateY(1px) scale(.995);
}

#taskMode .list-panel #tList .week-task-expand-chevron,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand-chevron {
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transition: transform .2s ease;
}

#taskMode .list-panel #tList .week-task-expand.is-open .week-task-expand-chevron,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand.is-open .week-task-expand-chevron {
  transform: rotate(-135deg) translateY(-1px);
}

@keyframes week-card-rise {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 980px) {
  #taskMode .list-panel #tList .week-view-head,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    row-gap: 0;
    column-gap: 0;
  }

  #taskMode .list-panel #tList .week-view-top,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-top {
    display: block;
  }

  #taskMode .list-panel #tList .week-view-title-group,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-title-group {
    display: flex;
    flex-wrap: wrap;
    row-gap: 6px;
  }

  #taskMode .list-panel #tList .week-view-progress,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress {
    margin-top: 8px;
    width: 100%;
    min-width: 0;
    justify-content: space-between;
  }

  #taskMode .list-panel #tList .week-view-stats,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-stats {
    flex-wrap: wrap;
    gap: 6px 10px;
  }

  #taskMode .list-panel #tList .week-view-stat,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat {
    margin-right: 0;
    padding-right: 10px;
  }

  #taskMode .list-panel #tList .week-view-stat:not(:last-child)::after,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat:not(:last-child)::after {
    height: 16px;
  }

  #taskMode .list-panel #tList .week-day-grid,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid {
    grid-template-columns: 1fr;
  }

  #taskMode .list-panel #tList .week-day-grid.is-split > .week-day-col,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid.is-split > .week-day-col {
    display: contents;
  }
}

/* 本周视图轻量化：用分组流线代替层层卡片。 */
#taskMode .list-panel #tList .week-view,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view {
  --week-accent: color-mix(in srgb, var(--acc) 74%, #4f8fd8);
  --week-accent-soft: color-mix(in srgb, var(--week-accent) 12%, transparent);
  --week-ink: color-mix(in srgb, var(--text) 94%, #101828);
  --week-muted: color-mix(in srgb, var(--text3) 86%, #64748b);
  --week-line: color-mix(in srgb, var(--inp-bd) 58%, transparent);
  --week-surface: color-mix(in srgb, var(--card) 93%, #f8fafc);
  --week-row-hover: color-mix(in srgb, var(--acc) 6%, transparent);
  --week-ring: #c4d1e2;
  gap: 14px;
  padding: 0 4px 12px;
  font-family: "HarmonyOS Sans SC", "MiSans", "Source Han Sans SC", "Noto Sans SC", system-ui, sans-serif;
}

.dark #taskMode .list-panel #tList .week-view,
.dark .app.app--with-global-nav #taskMode .list-panel #tList .week-view {
  --week-accent: color-mix(in srgb, var(--acc2) 82%, #8dd7ff);
  --week-accent-soft: color-mix(in srgb, var(--week-accent) 18%, transparent);
  --week-ink: color-mix(in srgb, var(--text) 96%, #f8fafc);
  --week-muted: color-mix(in srgb, var(--text3) 78%, #94a3b8);
  --week-line: color-mix(in srgb, var(--task-bd) 82%, transparent);
  --week-surface: color-mix(in srgb, var(--card) 90%, #0f172a);
  --week-row-hover: color-mix(in srgb, var(--acc2) 12%, transparent);
  --week-ring: #607089;
}

#taskMode .list-panel #tList .week-view-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
  position: relative;
  overflow: hidden;
  border: 0;
  border-radius: 18px;
  padding: 14px 18px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--card) 96%, #fff), color-mix(in srgb, var(--week-surface) 92%, #eef3f8));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 70%, transparent),
    0 12px 26px -28px rgba(15, 23, 42, .32);
  row-gap: 10px;
  transition: box-shadow .24s ease, transform .2s ease, background .24s ease;
}

#taskMode .list-panel #tList .week-view-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head:hover {
  border-color: transparent;
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 18%, transparent),
    0 16px 30px -30px rgba(15, 23, 42, .38);
  transform: translateY(-.5px);
}

#taskMode .list-panel #tList .week-view-head > *,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head > * {
  position: relative;
  z-index: 1;
}

#taskMode .list-panel #tList .week-view-title-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title-group {
  gap: 0;
}

#taskMode .list-panel #tList .week-view-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title {
  font-size: 16px;
  font-weight: 760;
  letter-spacing: -.04em;
  color: var(--week-ink);
}

#taskMode .list-panel #tList .week-view-range,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-range {
  display: none;
}

#taskMode .list-panel #tList .week-view-progress,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress {
  gap: 14px;
}

#taskMode .list-panel #tList .week-view-progress-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label,
#taskMode .list-panel #tList .week-view-stat,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat {
  color: var(--week-muted);
}

#taskMode .list-panel #tList .week-view-progress-label b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label b,
#taskMode .list-panel #tList .week-view-stat b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat b {
  color: var(--week-ink);
}

#taskMode .list-panel #tList .week-view-stat,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat {
  gap: 4px;
  padding-right: 13px;
  margin-right: 13px;
  font-size: 11px;
  letter-spacing: .01em;
}

#taskMode .list-panel #tList .week-view-stat b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat b {
  font-size: 16px;
  font-weight: 780;
  letter-spacing: -.035em;
}

#taskMode .list-panel #tList .week-view-stat--done,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat--done {
  margin-right: 0;
  padding-right: 0;
}

#taskMode .list-panel #tList .week-done-inline-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-width: 42px;
  min-height: 20px;
  margin: 0 0 0 1px;
  border: 0;
  border-radius: 999px;
  padding: 0 6px;
  background: transparent;
  color: color-mix(in srgb, var(--week-accent) 66%, var(--week-muted));
  cursor: pointer;
  appearance: none;
  font: inherit;
  font-family: inherit;
  font-size: 10.5px;
  font-weight: 680;
  line-height: 1;
  white-space: nowrap;
  transition: background .18s ease, color .18s ease, box-shadow .18s ease;
}

#taskMode .list-panel #tList .week-done-inline-action:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action:hover {
  background: color-mix(in srgb, var(--week-accent-soft) 52%, transparent);
  color: color-mix(in srgb, var(--week-accent) 82%, var(--week-ink));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 14%, transparent);
}

#taskMode .list-panel #tList .week-done-inline-action:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action:active {
  background: color-mix(in srgb, var(--week-accent-soft) 74%, transparent);
}

#taskMode .list-panel #tList .week-done-inline-action:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--week-accent) 24%, transparent);
}

#taskMode .list-panel #tList .week-done-inline-chevron,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-chevron {
  content: "";
  width: 5px;
  height: 5px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transition: transform .18s ease;
}

#taskMode .list-panel #tList .week-done-inline-action.is-on .week-done-inline-chevron,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action.is-on .week-done-inline-chevron {
  transform: rotate(-135deg) translateY(-1px);
}

#taskMode .list-panel #tList .week-view-progress-track,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-track {
  height: 10px;
  width: 148px;
  background: color-mix(in srgb, var(--week-line) 82%, transparent);
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, .05);
}

#taskMode .list-panel #tList .week-view-progress-fill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-fill {
  background: linear-gradient(90deg, var(--week-accent), color-mix(in srgb, var(--week-accent) 58%, #8bd3ff));
  box-shadow: 0 0 16px color-mix(in srgb, var(--week-accent) 22%, transparent);
}

#taskMode .list-panel #tList .week-view-stat:not(:last-child)::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat:not(:last-child)::after {
  background: var(--week-line);
}

#taskMode .list-panel #tList .week-day-grid,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
}

#taskMode .list-panel #tList .week-day-grid.is-split > .week-day-col,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid.is-split > .week-day-col {
  gap: 16px;
}

#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
  position: relative;
  border: 0;
  border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 98%, #fff), color-mix(in srgb, var(--week-surface) 82%, #f8fafc));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 76%, transparent),
    0 12px 24px -22px rgba(15, 23, 42, .34);
  overflow: hidden;
  isolation: isolate;
  transition: background .22s ease, box-shadow .22s ease, transform .2s ease;
}

#taskMode .list-panel #tList .week-day-card::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before {
  left: 0;
  right: auto;
  top: 0;
  bottom: 0;
  width: 4px;
  height: auto;
  border-radius: 999px 0 0 999px;
  background: var(--week-accent);
  opacity: 0;
  transform: scaleY(.86);
  transform-origin: center;
  transition: opacity .22s ease, transform .22s ease, background .22s ease, box-shadow .22s ease;
}

#taskMode .list-panel #tList .week-day-card.is-today::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today::before,
#taskMode .list-panel #tList .week-day-card.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus::before {
  background: var(--week-accent);
  box-shadow: none;
  opacity: 1;
  transform: scaleY(1);
}

#taskMode .list-panel #tList .week-day-card.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today,
#taskMode .list-panel #tList .week-day-card.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus {
  border-color: transparent;
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 25%, transparent),
    0 16px 34px -28px color-mix(in srgb, var(--week-accent) 42%, transparent);
}

#taskMode .list-panel #tList .week-day-card:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card:hover {
  transform: translateY(-.5px);
}

#taskMode .list-panel #tList .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 12px;
  padding: 13px 22px 10px 26px;
  border-bottom: 1px solid var(--week-line);
  border-radius: 16px 16px 0 0;
  background: transparent;
  transition: background .18s ease, transform .16s ease;
}

#taskMode .list-panel #tList .week-day-title-btn,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-title-btn {
  display: grid;
  gap: 3px;
  min-width: 0;
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-align: left;
}

#taskMode .list-panel #tList .week-day-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:hover {
  background: var(--week-row-hover);
}

#taskMode .list-panel #tList .week-day-head:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:focus-visible,
#taskMode .list-panel #tList .week-day-title-btn:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-title-btn:focus-visible,
#taskMode .list-panel #tList .week-task-item:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:focus-visible,
#taskMode .list-panel #tList .week-task-expand:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand:focus-visible,
#taskMode .list-panel #tList .week-day-empty:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--week-accent) 36%, transparent);
}

#taskMode .list-panel #tList .week-day-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-name {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 760;
  letter-spacing: -.035em;
  color: var(--week-ink);
}

#taskMode .list-panel #tList .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-week {
  color: color-mix(in srgb, var(--week-accent) 76%, var(--week-ink));
  font-size: 16px;
  font-weight: 820;
  letter-spacing: -.045em;
  transition: color .18s ease, transform .18s ease;
}

#taskMode .list-panel #tList .week-day-card.is-focus .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-week,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-week {
  color: color-mix(in srgb, var(--week-accent) 94%, var(--week-ink));
}

#taskMode .list-panel #tList .week-day-sep,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-sep {
  display: none;
}

#taskMode .list-panel #tList .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date {
  position: relative;
  top: 0;
  padding: 2px 7px;
  border-radius: 999px;
  color: color-mix(in srgb, var(--week-accent) 52%, var(--week-muted));
  background: color-mix(in srgb, var(--week-accent) 8%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 8%, transparent);
  font-size: 14px;
  font-weight: 620;
  letter-spacing: -.01em;
  transition: background .18s ease, box-shadow .18s ease, color .18s ease;
}

#taskMode .list-panel #tList .week-day-card.is-focus .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-date,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-date {
  color: color-mix(in srgb, var(--week-accent) 80%, var(--week-ink));
  background: color-mix(in srgb, var(--week-accent) 13%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 14%, transparent);
}

#taskMode .list-panel #tList .week-day-head:hover .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:hover .week-day-week {
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-day-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-meta {
  color: var(--week-muted);
}

#taskMode .list-panel #tList .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  font-size: 12px;
  font-weight: 620;
  letter-spacing: -.01em;
  line-height: 1.2;
}

#taskMode .list-panel #tList .week-day-meta-dot,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-meta-dot {
  color: color-mix(in srgb, var(--week-muted) 55%, transparent);
  font-weight: 700;
}

#taskMode .list-panel #tList .week-day-date-text,
#taskMode .list-panel #tList .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-status-text {
  display: inline-flex;
  align-items: center;
}

#taskMode .list-panel #tList .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-text {
  flex: 0 0 46px;
  width: 46px;
  font-variant-numeric: tabular-nums;
}

#taskMode .list-panel #tList .week-day-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count {
  border: 0;
  min-width: 84px;
  min-height: 38px;
  height: auto;
  padding: 4px 10px;
  border-radius: 13px;
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
  background: transparent;
  box-shadow: none;
  font-size: 11px;
  font-weight: 620;
  gap: 8px;
  cursor: default;
  font-family: inherit;
  line-height: 1;
  transition: background .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

#taskMode .list-panel #tList .week-day-count.week-task-expand,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand {
  cursor: pointer;
}

#taskMode .list-panel #tList .week-task-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list {
  position: relative;
  display: grid;
  gap: 0;
  padding: 0;
}

#taskMode .list-panel #tList .week-task-list.has-more-collapsed::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.has-more-collapsed::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 42px;
  pointer-events: none;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--card) 94%, transparent));
}

#taskMode .list-panel #tList .week-task-list.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-empty {
  padding: 0;
}

#taskMode .list-panel #tList .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-head {
  padding-bottom: 8px;
}

#taskMode .list-panel #tList .week-task-list.is-scroll,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll {
  max-height: 386px;
  padding-right: 8px;
}

#taskMode .list-panel #tList .week-task-extra,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-extra {
  height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
}

#taskMode .list-panel #tList .week-task-extra.is-open,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-extra.is-open {
  height: var(--week-extra-h, 720px);
  opacity: 1;
  pointer-events: auto;
}

#taskMode .list-panel #tList .week-task-extra-inner,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-extra-inner {
  display: grid;
  min-height: 0;
}

#taskMode .list-panel #tList .week-done-slide,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-slide {
  height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  will-change: height, opacity, transform;
  transition: height .38s cubic-bezier(.22, 1, .36, 1), opacity .22s ease;
}

#taskMode .list-panel #tList .week-done-slide.is-open,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-slide.is-open {
  height: var(--week-done-slide-h, 320px);
  opacity: 1;
  pointer-events: auto;
}

#taskMode .list-panel #tList .week-done-slide-inner,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-slide-inner {
  display: grid;
  min-height: 0;
}

#taskMode .list-panel #tList .week-done-section-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-head {
  position: relative;
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  padding: 9px 28px 5px 54px;
  color: #7f8fa8;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1;
}

#taskMode .list-panel #tList .week-done-section-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-head::before {
  content: "";
  position: static;
  flex: 0 0 22px;
  width: 22px;
  height: 1px;
  background: color-mix(in srgb, currentColor 28%, transparent);
}

#taskMode .list-panel #tList .week-done-section-head::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-head::after {
  content: "";
  flex: 1 1 auto;
  min-width: 34px;
  height: 1px;
  background: linear-gradient(90deg, var(--week-line), rgba(226, 232, 240, .35));
}

#taskMode .list-panel #tList .week-done-section-label,
#taskMode .list-panel #tList .week-done-section-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-count {
  position: relative;
  z-index: 1;
  background: var(--card);
}

#taskMode .list-panel #tList .week-done-section-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-label {
  padding-left: 0;
}

#taskMode .list-panel #tList .week-done-section-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-section-count {
  padding-right: 0;
  color: #64748b;
}

#taskMode .list-panel #tList .week-done-slide-inner .week-task-item:first-child::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-slide-inner .week-task-item:first-child::before {
  content: "";
  position: absolute;
  left: 52px;
  right: 22px;
  top: 0;
  height: 1px;
  background: var(--week-line);
}

#taskMode .list-panel #tList .week-task-extra-inner .week-task-item:first-child::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-extra-inner .week-task-item:first-child::before {
  content: "";
  position: absolute;
  left: 52px;
  right: 22px;
  top: 0;
  height: 1px;
  background: var(--week-line);
}

#taskMode .list-panel #tList .week-task-item,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item {
  position: relative;
  display: grid;
  overflow: hidden;
  border: 0;
  border-radius: 10px;
  min-height: 50px;
  padding: 8px 22px 7px 26px;
  background: transparent;
  box-shadow: none;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: start;
  column-gap: 10px;
  transition: background .18s ease, transform .16s ease, color .18s ease;
}

#taskMode .list-panel #tList .week-task-open,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-open {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px;
  min-width: 0;
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-align: left;
}

#taskMode .list-panel #tList .week-task-item + .week-task-item::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item + .week-task-item::before {
  content: "";
  position: absolute;
  left: 52px;
  right: 22px;
  top: 0;
  height: 1px;
  background: var(--week-line);
}

#taskMode .list-panel #tList .week-task-item:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover {
  border-color: transparent;
  background: var(--week-row-hover);
  box-shadow: none;
  transform: translateY(-.5px);
}

#taskMode .list-panel #tList .week-task-item:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:active {
  transform: translateY(0) scale(.997);
}

#taskMode .list-panel #tList .week-task-marker,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker {
  display: flex;
  width: 18px;
  min-width: 18px;
  height: 22px;
  min-height: 22px;
  margin-top: 0;
  border: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  align-items: center;
  justify-content: center;
}

#taskMode .list-panel #tList .week-task-marker .tc-check,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker .tc-check {
  width: 18px;
  min-width: 18px;
  height: 22px;
  min-height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#taskMode .list-panel #tList .week-task-marker .chk-ring,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker .chk-ring {
  width: 18px;
  min-width: 18px;
  height: 18px;
  min-height: 18px;
  border-width: 1.5px;
  pointer-events: auto;
}

#taskMode .list-panel #tList .week-task-marker .chk-ring-ico,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker .chk-ring-ico {
  width: 12px;
  height: 12px;
}

#taskMode .list-panel #tList .week-task-marker:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:hover {
  transform: none;
}

#taskMode .list-panel #tList .week-task-item.is-high .week-task-marker,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-marker,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-high .week-task-marker,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-marker {
  border: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-open,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-open {
  opacity: .72;
  transition: opacity .18s ease;
}

#taskMode .list-panel #tList .week-task-item.is-done:hover .week-task-open,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done:hover .week-task-open {
  opacity: .88;
}

#taskMode .list-panel #tList .week-task-main,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-main {
  gap: 2px;
}

#taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title {
  font-size: 14px;
  font-weight: 620;
  letter-spacing: -.025em;
  color: color-mix(in srgb, var(--week-ink) 88%, var(--week-muted));
}

#taskMode .list-panel #tList .week-task-meta-row,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row {
  gap: 8px;
}

#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta {
  color: color-mix(in srgb, var(--week-muted) 72%, var(--week-ink));
  font-size: 11px;
  font-weight: 460;
}

#taskMode .list-panel #tList .week-task-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-badge {
  background: color-mix(in srgb, var(--week-line) 62%, transparent);
  color: color-mix(in srgb, var(--week-ink) 72%, var(--week-muted));
}

#taskMode .list-panel #tList .week-task-badge--done,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-badge--done {
  color: #166534;
  background: rgba(34, 197, 94, .12);
}

#taskMode .list-panel #tList .week-task-badge--frozen,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-badge--frozen {
  color: #1d4ed8;
  background: rgba(59, 130, 246, .12);
}

#taskMode .list-panel #tList .week-done-fold-hint,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 30px;
  margin: 2px 22px 7px 54px;
  border: 0;
  border-radius: 0;
  padding: 8px 0 0;
  background: transparent;
  color: color-mix(in srgb, var(--week-muted) 76%, var(--week-ink));
  font: inherit;
  font-size: 11px;
  font-weight: 560;
  letter-spacing: .01em;
  cursor: pointer;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--week-line) 76%, transparent);
  transition: color .18s ease, box-shadow .18s ease;
}

#taskMode .list-panel #tList .week-done-fold-hint:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover {
  color: color-mix(in srgb, var(--week-accent) 70%, var(--week-ink));
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--week-accent) 20%, transparent);
}

#taskMode .list-panel #tList .week-done-fold-hint:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:active {
  color: color-mix(in srgb, var(--week-accent) 84%, var(--week-ink));
}

#taskMode .list-panel #tList .week-done-fold-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-action {
  color: color-mix(in srgb, var(--week-accent) 76%, var(--week-ink));
  font-weight: 680;
}

#taskMode .list-panel #tList .week-day-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty {
  position: relative;
  display: flex;
  overflow: hidden;
  width: 100%;
  min-height: 44px;
  justify-content: center;
  align-items: center;
  border: 0;
  border-radius: 0 0 18px 18px;
  padding: 0 22px;
  margin: 0;
  background: transparent;
  box-shadow: none;
  color: color-mix(in srgb, var(--week-muted) 78%, #a7b3c2);
  font-size: 12px;
  font-weight: 560;
  letter-spacing: .02em;
  box-sizing: border-box;
  transition: background .18s ease, color .18s ease;
}

#taskMode .list-panel #tList .week-day-empty:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty:hover {
  background: var(--week-row-hover);
  box-shadow: none;
  transform: none;
}

#taskMode .list-panel #tList .week-day-empty-dot,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty-dot {
  display: none;
}

#taskMode .list-panel #tList .week-day-count.week-task-expand,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand {
  position: relative;
  overflow: hidden;
  width: auto;
  height: auto;
  min-height: 38px;
  margin: 0;
  justify-content: flex-end;
  border: 0;
  border-radius: 14px;
  padding: 4px 8px 4px 10px;
  color: color-mix(in srgb, var(--week-accent) 82%, var(--week-ink));
  background: transparent;
  box-shadow: none;
  gap: 6px;
  transition: background .2s ease, transform .18s ease, color .2s ease, box-shadow .2s ease;
}

#taskMode .list-panel #tList .week-day-count .week-task-expand-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count .week-task-expand-label {
  display: grid;
  gap: 4px;
  justify-items: end;
}

#taskMode .list-panel #tList .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line {
  display: inline-flex;
  align-items: baseline;
  justify-content: flex-end;
  gap: 4px;
  white-space: nowrap;
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-size: 11px;
  font-weight: 560;
  letter-spacing: -.01em;
}

#taskMode .list-panel #tList .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line b {
  color: color-mix(in srgb, var(--week-ink) 88%, var(--week-accent));
  font-size: 13px;
  font-weight: 780;
  letter-spacing: -.035em;
}

#taskMode .list-panel #tList .week-day-count-line--done,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--done {
  color: color-mix(in srgb, var(--week-muted) 76%, #94a3b8);
}

#taskMode .list-panel #tList .week-day-count-line--done b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--done b {
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
}

#taskMode .list-panel #tList .week-day-count.week-task-expand.is-open,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand.is-open {
  color: color-mix(in srgb, var(--week-accent) 92%, var(--week-ink));
  background: var(--week-accent-soft);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 13%, transparent);
}

#taskMode .list-panel #tList .week-day-count.week-task-expand:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand:hover {
  background: var(--week-accent-soft);
  border-color: transparent;
  box-shadow: none;
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-day-count.week-task-expand:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand:active {
  transform: translateY(0) scale(.995);
}

#taskMode .list-panel #tList .week-task-item::after,
#taskMode .list-panel #tList .week-day-head::after,
#taskMode .list-panel #tList .week-task-expand::after,
#taskMode .list-panel #tList .week-day-empty::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty::after {
  content: "";
  position: absolute;
  left: var(--press-x, 50%);
  top: var(--press-y, 50%);
  width: 0;
  height: 0;
  border-radius: 999px;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%);
  background: color-mix(in srgb, var(--week-accent) 18%, transparent);
}

#taskMode .list-panel #tList .week-task-item.is-pressing::after,
#taskMode .list-panel #tList .week-day-head.is-pressing::after,
#taskMode .list-panel #tList .week-task-expand.is-pressing::after,
#taskMode .list-panel #tList .week-day-empty.is-pressing::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-pressing::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head.is-pressing::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand.is-pressing::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty.is-pressing::after {
  animation: week-soft-press .42s cubic-bezier(.22, 1, .36, 1);
}

@keyframes week-soft-press {
  0% {
    width: 0;
    height: 0;
    opacity: .28;
  }
  100% {
    width: 260px;
    height: 260px;
    opacity: 0;
  }
}

@media (max-width: 980px) {
  #taskMode .list-panel #tList .week-view-head,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
    padding: 16px;
  }

  #taskMode .list-panel #tList .week-view-range,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-range {
    margin-left: 0;
  }
}

@media (max-width: 640px) {
  #taskMode .list-panel #tList .week-day-card,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
    border-radius: 18px;
  }

  #taskMode .list-panel #tList .week-day-head,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-head {
    padding: 13px 14px 8px 18px;
  }

  #taskMode .list-panel #tList .week-task-list,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-list {
    padding-left: 0;
    padding-right: 0;
  }

  #taskMode .list-panel #tList .week-task-list.is-empty,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-empty {
    padding-left: 0;
    padding-right: 0;
  }

  #taskMode .list-panel #tList .week-task-expand,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand {
    margin-left: 0;
  }

  #taskMode .list-panel #tList .week-done-fold-hint,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
    margin: 2px 14px 7px 46px;
  }
}

@media (prefers-reduced-motion: reduce) {
  #taskMode .list-panel #tList .week-task-item.is-pressing::after,
  #taskMode .list-panel #tList .week-day-head.is-pressing::after,
  #taskMode .list-panel #tList .week-task-expand.is-pressing::after,
  #taskMode .list-panel #tList .week-day-empty.is-pressing::after,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-pressing::after,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-head.is-pressing::after,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand.is-pressing::after,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty.is-pressing::after {
    animation: none !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #taskMode .list-panel #tList .week-day-card,
  #taskMode .list-panel #tList .week-day-head,
  #taskMode .list-panel #tList .week-task-item,
  #taskMode .list-panel #tList .week-task-expand,
  #taskMode .list-panel #tList .week-task-expand-chevron,
  #taskMode .list-panel #tList .week-day-empty,
  #taskMode .list-panel #tList .week-done-fold-hint,
  #taskMode .list-panel #tList .week-task-list,
  #taskMode .list-panel #tList .week-task-extra,
  #taskMode .list-panel #tList .week-done-slide,
  #taskMode .list-panel #tList .week-view-head,
  #taskMode .list-panel #tList .week-view-progress-fill,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-card,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-head,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-item,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-expand-chevron,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-list,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-extra,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-done-slide,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-head,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-fill {
    transition: none !important;
    animation: none !important;
  }
}

/* Weekly view refinement: flatter hierarchy, compact rows, and zero-jitter controls. */
#taskMode .list-panel #tList .week-view,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view {
  --week-row-hover: color-mix(in srgb, var(--week-accent) 5%, transparent);
  gap: 12px;
  padding-inline: 2px;
}

#taskMode .list-panel #tList .week-view-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
  padding: 13px 18px;
  border-radius: 17px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--card) 98%, #fff), color-mix(in srgb, var(--week-surface) 78%, #f8fafc));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 70%, transparent),
    0 10px 22px -26px rgba(15,23,42,.26);
  transform: none;
}

#taskMode .list-panel #tList .week-view-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head:hover {
  transform: none;
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 16%, transparent),
    0 12px 24px -27px rgba(15,23,42,.3);
}

#taskMode .list-panel #tList .week-view-stats,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stats {
  gap: 0;
}

#taskMode .list-panel #tList .week-done-inline-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action {
  min-width: 40px;
  min-height: 20px;
  padding: 0 2px;
  border-radius: 6px;
  background: transparent;
  box-shadow: none;
  transition: color .18s ease, text-decoration-color .18s ease;
}

#taskMode .list-panel #tList .week-done-inline-action:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-inline-action:hover {
  background: transparent;
  box-shadow: none;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

#taskMode .list-panel #tList .week-day-grid,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid {
  gap: 12px;
}

#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
  border-radius: 17px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 99%, #fff), color-mix(in srgb, var(--week-surface) 70%, #f9fbfd));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 72%, transparent),
    0 10px 22px -24px rgba(15,23,42,.28);
}

#taskMode .list-panel #tList .week-day-card:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card:hover {
  transform: none;
}

#taskMode .list-panel #tList .week-day-card.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today,
#taskMode .list-panel #tList .week-day-card.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 22%, transparent),
    0 12px 26px -26px color-mix(in srgb, var(--week-accent) 34%, transparent);
}

#taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-head {
  background: linear-gradient(90deg, color-mix(in srgb, var(--week-accent) 6%, transparent), transparent 72%);
}

#taskMode .list-panel #tList .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head {
  padding: 12px 24px 10px 26px;
}

#taskMode .list-panel #tList .week-day-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-name {
  gap: 8px;
}

#taskMode .list-panel #tList .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-week {
  font-size: 16px;
  color: color-mix(in srgb, var(--week-accent) 84%, var(--week-ink));
}

#taskMode .list-panel #tList .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date {
  padding: 1px 7px;
  font-size: 13px;
}

#taskMode .list-panel #tList .week-day-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count {
  min-width: 0;
  min-height: 24px;
  padding: 2px 0;
  border-radius: 8px;
  background: transparent;
  color: var(--week-muted);
}

#taskMode .list-panel #tList .week-day-count .week-task-expand-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count .week-task-expand-label {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-items: end;
}

#taskMode .list-panel #tList .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line {
  gap: 3px;
  font-size: 11px;
}

#taskMode .list-panel #tList .week-day-count.week-task-expand,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand {
  min-height: 26px;
  padding: 2px 4px;
  border-radius: 8px;
  background: transparent;
  box-shadow: none;
  transform: none;
}

#taskMode .list-panel #tList .week-day-count.week-task-expand:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-task-expand:hover {
  background: color-mix(in srgb, var(--week-accent) 7%, transparent);
  box-shadow: none;
  transform: none;
}

#taskMode .list-panel #tList .week-task-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list {
  padding: 0;
}

#taskMode .list-panel #tList .week-task-item,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item {
  min-height: 48px;
  padding: 7px 24px 6px 26px;
  border-radius: 0;
  grid-template-columns: 18px minmax(0, 1fr);
  column-gap: 10px;
}

#taskMode .list-panel #tList .week-task-item:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover {
  background: var(--week-row-hover);
  transform: none;
}

#taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title {
  font-size: 14.5px;
  font-weight: 650;
  color: color-mix(in srgb, var(--week-ink) 90%, var(--week-muted));
}

#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-weight: 430;
}

#taskMode .list-panel #tList .week-day-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty {
  min-height: 40px;
  border-radius: 0 0 17px 17px;
}

#taskMode .list-panel #tList .week-day-empty:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-empty:hover {
  background: var(--week-row-hover);
  transform: none;
}

#taskMode .list-panel #tList .week-done-fold-hint,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
  min-height: 28px;
  margin: 1px 24px 6px 54px;
  padding-top: 7px;
  background: transparent;
  border-radius: 0;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--week-line) 70%, transparent);
}

#taskMode .list-panel #tList .week-done-fold-hint:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover {
  background: transparent;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--week-accent) 20%, transparent);
}

/* Module polish: keep task rows calm while making completion controls readable. */
#taskMode .list-panel #tList .week-view,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view {
  --week-row-hover: color-mix(in srgb, var(--week-accent) 3.5%, transparent);
}

#taskMode .list-panel #tList .week-day-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:hover {
  background: color-mix(in srgb, var(--week-accent) 3%, transparent);
}

#taskMode .list-panel #tList .week-task-item:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item:hover {
  background: linear-gradient(90deg, color-mix(in srgb, var(--week-accent) 4%, transparent), transparent 84%);
}

#taskMode .list-panel #tList .week-done-fold-hint,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
  gap: 8px;
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
}

#taskMode .list-panel #tList .week-done-fold-hint-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-state {
  font-weight: 520;
}

#taskMode .list-panel #tList .week-done-fold-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-action {
  min-width: 28px;
  color: color-mix(in srgb, var(--week-accent) 82%, var(--week-ink));
  text-align: left;
  text-decoration-color: transparent;
  transition: color .18s ease, text-decoration-color .18s ease;
}

#taskMode .list-panel #tList .week-done-fold-hint:hover .week-done-fold-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover .week-done-fold-hint-action {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: currentColor;
}

/* Premium completed disclosure: a quiet tray that belongs to the task list. */
#taskMode .list-panel #tList .week-done-fold-hint,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
  --week-done-accent: #22c55e;
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) auto;
  align-items: center;
  gap: 9px;
  justify-content: stretch;
  width: calc(100% - 78px);
  min-height: 38px;
  margin: 4px 24px 10px 54px;
  padding: 7px 10px 7px 8px;
  border: 1px solid color-mix(in srgb, var(--week-line) 70%, transparent);
  border-radius: 13px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card) 96%, #fff), color-mix(in srgb, var(--week-surface) 76%, #f8fafc));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .72),
    0 8px 18px -18px rgba(15, 23, 42, .28);
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
  font-size: 11.5px;
  line-height: 1.2;
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease, color .18s ease;
}

#taskMode .list-panel #tList .week-done-fold-hint::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -6px;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--week-line) 74%, transparent), transparent);
  pointer-events: none;
}

#taskMode .list-panel #tList .week-done-fold-hint:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card) 99%, #fff), color-mix(in srgb, var(--week-accent) 4%, var(--week-surface)));
  border-color: color-mix(in srgb, var(--week-accent) 18%, var(--week-line));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .82),
    0 10px 20px -20px color-mix(in srgb, var(--week-accent) 32%, rgba(15, 23, 42, .2));
}

#taskMode .list-panel #tList .week-done-fold-hint-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  color: color-mix(in srgb, var(--week-done-accent) 78%, #64748b);
  background: color-mix(in srgb, var(--week-done-accent) 10%, transparent);
}

#taskMode .list-panel #tList .week-done-fold-hint-icon svg,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-icon svg {
  width: 14px;
  height: 14px;
}

#taskMode .list-panel #tList .week-done-fold-hint-copy,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-copy {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  min-width: 0;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-done-fold-hint-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-state {
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
  font-weight: 560;
}

#taskMode .list-panel #tList .week-done-fold-hint-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-count {
  color: color-mix(in srgb, var(--week-ink) 76%, var(--week-muted));
  font-weight: 720;
  letter-spacing: -.02em;
}

#taskMode .list-panel #tList .week-done-fold-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-action {
  display: inline-flex;
  align-items: center;
  justify-self: end;
  gap: 6px;
  min-width: auto;
  color: color-mix(in srgb, var(--week-accent) 82%, var(--week-ink));
  font-weight: 720;
  text-decoration: none;
  text-decoration-color: transparent;
}

#taskMode .list-panel #tList .week-done-fold-hint-action::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-action::after {
  content: "";
  width: 6.5px;
  height: 6.5px;
  border-right: 1.6px solid currentColor;
  border-bottom: 1.6px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transition: transform .2s cubic-bezier(.22, 1, .36, 1);
}

#taskMode .list-panel #tList .week-done-fold-hint.is-open .week-done-fold-hint-action::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint.is-open .week-done-fold-hint-action::after {
  transform: rotate(-135deg) translateY(-1px);
}

#taskMode .list-panel #tList .week-done-fold-hint:hover .week-done-fold-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover .week-done-fold-hint-action {
  text-decoration: none;
}

@media (max-width: 640px) {
  #taskMode .list-panel #tList .week-done-fold-hint,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
    width: calc(100% - 60px);
    margin-left: 46px;
    margin-right: 14px;
  }
}

/* Final completed disclosure: a list section row, not a secondary card. */
#taskMode .list-panel #tList .week-done-fold-hint,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
  --week-done-accent: color-mix(in srgb, var(--week-accent) 58%, var(--week-muted));
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  min-height: 42px;
  margin: 0;
  padding: 9px 24px 10px 26px;
  border: 0;
  border-radius: 0 0 17px 17px;
  background: transparent;
  box-shadow: none;
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  font-size: 12px;
  line-height: 1.2;
  transition: background .2s ease, color .18s ease;
}

#taskMode .list-panel #tList .week-done-fold-hint::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint::before {
  content: "";
  position: absolute;
  left: 54px;
  right: 24px;
  top: 0;
  height: 1px;
  background: color-mix(in srgb, var(--week-line) 72%, transparent);
  pointer-events: none;
}

#taskMode .list-panel #tList .week-done-fold-hint:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover {
  background: linear-gradient(90deg, color-mix(in srgb, var(--week-accent) 3.5%, transparent), transparent 86%);
  border-color: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-done-fold-hint:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:active {
  background: linear-gradient(90deg, color-mix(in srgb, var(--week-accent) 5.5%, transparent), transparent 86%);
}

#taskMode .list-panel #tList .week-done-fold-hint-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-icon {
  width: 16px;
  height: 16px;
  border-radius: 0;
  color: color-mix(in srgb, var(--week-done-accent) 78%, var(--week-muted));
  background: transparent;
  opacity: .86;
  transition: color .18s ease, opacity .18s ease;
}

#taskMode .list-panel #tList .week-done-fold-hint:hover .week-done-fold-hint-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint:hover .week-done-fold-hint-icon {
  color: var(--week-done-accent);
  opacity: 1;
}

#taskMode .list-panel #tList .week-done-fold-hint-icon svg,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-icon svg {
  width: 15px;
  height: 15px;
}

#taskMode .list-panel #tList .week-done-fold-hint-copy,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-copy {
  flex: 0 0 auto;
  gap: 6px;
  min-width: 0;
}

#taskMode .list-panel #tList .week-done-fold-hint-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-state {
  color: color-mix(in srgb, var(--week-muted) 92%, var(--week-ink));
  font-size: 12px;
  font-weight: 560;
}

#taskMode .list-panel #tList .week-done-fold-hint-state::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-state::after {
  content: "";
  display: inline-block;
  width: 3px;
  height: 3px;
  margin-left: 6px;
  border-radius: 50%;
  vertical-align: middle;
  background: color-mix(in srgb, var(--week-muted) 44%, transparent);
}

#taskMode .list-panel #tList .week-done-fold-hint-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-count {
  color: color-mix(in srgb, var(--week-ink) 82%, var(--week-muted));
  font-size: 12px;
  font-weight: 700;
  letter-spacing: -.02em;
}

#taskMode .list-panel #tList .week-done-fold-hint-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-action {
  flex: 0 0 auto;
  gap: 7px;
  color: color-mix(in srgb, var(--week-accent) 86%, var(--week-ink));
  font-size: 12px;
  font-weight: 740;
  letter-spacing: -.01em;
}

#taskMode .list-panel #tList .week-done-fold-hint-action::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint-action::after {
  width: 6px;
  height: 6px;
  border-width: 1.7px;
}

@media (max-width: 640px) {
  #taskMode .list-panel #tList .week-done-fold-hint,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint {
    width: 100%;
    margin: 0;
    padding-left: 18px;
    padding-right: 14px;
    justify-content: center;
  }

  #taskMode .list-panel #tList .week-done-fold-hint::before,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-done-fold-hint::before {
    left: 46px;
    right: 14px;
  }
}

/* Unified card shell: today is marked inside the header, not by a different outer frame. */
#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card,
#taskMode .list-panel #tList .week-day-card.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today,
#taskMode .list-panel #tList .week-day-card.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card) 99%, #fff), color-mix(in srgb, var(--week-surface) 70%, #f9fbfd));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 72%, transparent),
    0 10px 22px -24px rgba(15, 23, 42, .28);
}

#taskMode .list-panel #tList .week-day-card.is-today::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today::before,
#taskMode .list-panel #tList .week-day-card.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus::before,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus::before {
  opacity: 0;
  transform: none;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-head {
  background: transparent;
}

#taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-head {
  background: color-mix(in srgb, var(--week-accent) 3%, transparent);
}

#taskMode .list-panel #tList .week-day-card.is-today .week-day-name::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-name::after {
  content: none;
}

#taskMode .list-panel #tList .week-day-card.is-today .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-date-label {
  color: color-mix(in srgb, var(--week-accent) 78%, var(--week-muted));
  font-weight: 700;
}

#taskMode .list-panel #tList .week-day-card.is-today .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-date-text {
  color: color-mix(in srgb, var(--week-accent) 78%, var(--week-muted));
}

#taskMode .list-panel #tList .week-day-status-text,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-status-text,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-status-text {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-weight: 650;
}

#taskMode .list-panel #tList .week-day-card.is-empty .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-status-text {
  color: color-mix(in srgb, var(--week-muted) 70%, transparent);
}

#taskMode .list-panel #tList .week-day-card.is-today:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today:hover,
#taskMode .list-panel #tList .week-day-card.is-focus:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus:hover {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 78%, transparent),
    0 12px 24px -24px rgba(15, 23, 42, .3);
}

/* Header disclosure chips: keep todo overflow and completed reveal in one visual language. */
#taskMode .list-panel #tList .week-day-count.week-day-count-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group {
  display: grid;
  grid-template-columns: 68px 92px;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  width: 170px;
  min-width: 0;
  min-height: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
  color: var(--week-muted);
}

#taskMode .list-panel #tList .week-day-count.week-day-count-group.has-overdue-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group.has-overdue-count {
  grid-template-columns: 82px 92px;
  width: 184px;
}

#taskMode .list-panel #tList .week-day-count-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip {
  appearance: none;
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 12px;
  align-items: center;
  justify-items: end;
  gap: 4px;
  width: max-content;
  justify-self: end;
  min-width: 0;
  min-height: 26px;
  margin: 0;
  padding: 2px 3px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  box-shadow: none;
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
  font: inherit;
  line-height: 1;
  white-space: nowrap;
  cursor: default;
  transform: none;
  transition: color .18s ease;
}

#taskMode .list-panel #tList button.week-day-count-chip,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip {
  cursor: pointer;
  padding-right: 3px;
}

#taskMode .list-panel #tList button.week-day-count-chip::after,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip::after {
  content: "";
  position: absolute;
  left: 2px;
  right: 18px;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--week-accent) 58%, var(--week-muted));
  opacity: 0;
  transform: scaleX(.72);
  transform-origin: center;
  transition: opacity .18s ease, transform .22s cubic-bezier(.2, .8, .2, 1);
  pointer-events: none;
}

#taskMode .list-panel #tList button.week-day-count-chip:hover,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip:hover {
  background: transparent;
  color: color-mix(in srgb, var(--week-accent) 76%, var(--week-ink));
  transform: none;
}

#taskMode .list-panel #tList button.week-day-count-chip:hover::after,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip:hover::after,
#taskMode .list-panel #tList button.week-day-count-chip.is-open::after,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip.is-open::after {
  opacity: .34;
  transform: scaleX(1);
}

#taskMode .list-panel #tList button.week-day-count-chip:active,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip:active {
  transform: none;
}

#taskMode .list-panel #tList .week-day-count-chip .week-task-expand-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-task-expand-label {
  display: contents;
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line {
  display: grid;
  grid-template-columns: max-content max-content;
  align-items: center;
  justify-content: end;
  gap: 4px;
  width: max-content;
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line b {
  color: color-mix(in srgb, var(--week-ink) 88%, var(--week-accent));
  font-size: 13px;
  font-weight: 760;
  line-height: 1;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-label,
#taskMode .list-panel #tList .week-day-count-chip .week-day-count-value,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-value {
  line-height: 1;
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-overdue-copy,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-overdue-copy {
  transition: transform .2s cubic-bezier(.22, 1, .36, 1), opacity .18s ease;
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line--overdue {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: max-content;
  max-width: none;
  white-space: nowrap;
}

#taskMode .list-panel #tList button.week-day-count-chip--overdue:hover .week-day-count-overdue-copy,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip--overdue:hover .week-day-count-overdue-copy {
  transform: translateX(.5px);
}

#taskMode .list-panel #tList button.week-day-count-chip--overdue:active .week-day-count-overdue-copy,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip--overdue:active .week-day-count-overdue-copy {
  transform: none;
  opacity: .94;
}

@media (prefers-reduced-motion: reduce) {
  #taskMode .list-panel #tList .week-day-count-chip .week-day-count-overdue-copy,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-overdue-copy {
    transition: none;
  }
}

#taskMode .list-panel #tList .week-day-count-chip--overdue .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--overdue .week-day-count-line,
#taskMode .list-panel #tList .week-day-count-chip--overdue .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--overdue .week-day-count-line b {
  color: #ef4444;
}

#taskMode .list-panel #tList .week-day-count-chip--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--overdue {
  grid-template-columns: max-content;
  min-width: max-content;
  min-height: 24px;
  padding: 0 3px;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-day-count-chip--overdue.week-todo-count-toggle,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--overdue.week-todo-count-toggle {
  grid-template-columns: max-content 12px;
}

#taskMode .list-panel #tList .week-day-count-chip--overdue .week-day-count-caret.is-placeholder,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--overdue .week-day-count-caret.is-placeholder {
  display: none;
}

#taskMode .list-panel #tList .week-overdue-icon-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 15px;
  height: 15px;
  color: #ef4444;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-overdue-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-overdue-icon {
  display: block;
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  stroke: currentColor;
}

#taskMode .list-panel #tList .week-day-count-chip--done .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--done .week-day-count-line {
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line--done b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line--done b {
  color: color-mix(in srgb, var(--week-ink) 88%, var(--week-accent));
  font-weight: 760;
}

#taskMode .list-panel #tList button.week-day-count-chip:hover .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip:hover .week-day-count-line {
  color: color-mix(in srgb, var(--week-accent) 78%, var(--week-ink));
}

#taskMode .list-panel #tList button.week-day-count-chip:hover .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip:hover .week-day-count-line b {
  color: inherit;
}

#taskMode .list-panel #tList button.week-day-count-chip--overdue:hover .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip--overdue:hover .week-day-count-line,
#taskMode .list-panel #tList button.week-day-count-chip--overdue:hover .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip--overdue:hover .week-day-count-line b {
  color: #dc2626;
}

#taskMode .list-panel #tList .week-day-count-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-caret {
  position: relative;
  flex: 0 0 12px;
  width: 12px;
  height: 12px;
  margin-left: 1px;
  color: color-mix(in srgb, var(--week-accent) 66%, var(--week-muted));
  opacity: .92;
  transform: translateY(.5px);
  transform-origin: 50% 50%;
  transition: transform .22s cubic-bezier(.2, .8, .2, 1), color .18s ease, opacity .18s ease;
}

#taskMode .list-panel #tList .week-day-count-caret.is-placeholder,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-caret.is-placeholder {
  opacity: 0;
}

#taskMode .list-panel #tList .week-day-count-caret::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-caret::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  transform: translate(-50%, -34%);
}

#taskMode .list-panel #tList .week-day-count-chip--done .week-day-count-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip--done .week-day-count-caret {
  color: color-mix(in srgb, var(--week-accent) 66%, var(--week-muted));
}

#taskMode .list-panel #tList button.week-day-count-chip:hover .week-day-count-caret,
.app.app--with-global-nav #taskMode .list-panel #tList button.week-day-count-chip:hover .week-day-count-caret {
  color: color-mix(in srgb, var(--week-accent) 92%, var(--week-ink));
  opacity: 1;
}

#taskMode .list-panel #tList .week-day-count-chip.is-open .week-day-count-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip.is-open .week-day-count-caret {
  transform: translateY(.5px) rotate(180deg);
}

#taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title {
  position: relative;
  display: block;
  width: fit-content;
  max-width: 100%;
  text-decoration: none !important;
}

#taskMode .list-panel #tList .week-task-title::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 54%;
  height: 1.5px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left center;
  pointer-events: none;
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title {
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-title::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title::after {
  opacity: .7;
  transform: scaleX(1);
}

#taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title {
  animation: week-task-title-soften .42s cubic-bezier(.16, 1, .3, 1) forwards;
}

#taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title::after {
  animation: week-task-title-strike .38s cubic-bezier(.16, 1, .3, 1) forwards;
}

@keyframes week-task-title-strike {
  from {
    opacity: .28;
    transform: scaleX(0);
  }

  to {
    opacity: .7;
    transform: scaleX(1);
  }
}

@keyframes week-task-title-soften {
  from {
    color: color-mix(in srgb, var(--week-ink) 90%, var(--week-muted));
  }

  to {
    color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  }
}

#taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  overflow: visible;
  isolation: isolate;
}

#taskMode .list-panel #tList .week-task-title::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title::after {
  content: none !important;
}

#taskMode .list-panel #tList .week-task-title-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title-text {
  position: relative;
  z-index: 1;
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-decoration: none !important;
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-title-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title-text {
  text-decoration: none !important;
}

#taskMode .list-panel #tList .week-task-title-strike,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title-strike {
  position: absolute;
  left: 0;
  right: auto;
  top: 54%;
  z-index: 2;
  width: 0;
  height: 1.5px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0;
  transform: none;
  pointer-events: none;
  will-change: width, opacity;
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-title-strike,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title-strike {
  opacity: .7;
  width: 100%;
  transform: none;
}

#taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title-strike,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title-strike {
  animation: none !important;
}

/* 周视图顶部批量按钮：无可展开内容时降低操作暗示，避免误解为下拉入口。 */
#taskMode .add-split-main.is-week-bulk-idle,
.app.app--with-global-nav #taskMode .add-split-main.is-week-bulk-idle,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle {
  cursor: default !important;
  color: #5f6f8a !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(248, 250, 252, .92)) !important;
  border: 1px solid rgba(203, 213, 225, .88) !important;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .06), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
  filter: none !important;
  transform: none !important;
}

#taskMode .add-split-main.is-week-bulk-idle:hover,
.app.app--with-global-nav #taskMode .add-split-main.is-week-bulk-idle:hover,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle:hover,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle:hover {
  color: #5f6f8a !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(248, 250, 252, .92)) !important;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .06), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
  filter: none !important;
  transform: none !important;
}

#taskMode .add-split-main.is-week-bulk-idle:active,
.app.app--with-global-nav #taskMode .add-split-main.is-week-bulk-idle:active,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle:active,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle:active {
  transform: none !important;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .06), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
}

#taskMode .add-split-main.is-week-bulk-idle svg,
.app.app--with-global-nav #taskMode .add-split-main.is-week-bulk-idle svg,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle svg,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main.is-week-bulk-idle svg {
  color: #64748b !important;
  stroke-width: 2.35 !important;
}

@media (max-width: 640px) {
  #taskMode .list-panel #tList .week-day-count.week-day-count-group,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group {
    gap: 6px;
  }
}

/* 周视图概览条：用轻量导航展示每日待办，并提供平滑定位反馈。 */
#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  grid-column: 1 / -1;
  grid-row: 3;
  min-width: 0;
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid color-mix(in srgb, var(--week-line) 68%, transparent);
}

#taskMode .list-panel #tList .week-view-day-pills,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 3px;
  min-width: 0;
  padding: 4px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(248, 250, 252, .78));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 70%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, .9);
}

#taskMode .list-panel #tList .week-view-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
  appearance: none;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 0;
  height: 36px;
  padding: 0 8px 0 10px;
  border: 0;
  border-radius: 14px;
  color: color-mix(in srgb, var(--week-muted) 92%, var(--week-ink));
  background: transparent;
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  overflow: hidden;
  transition: color .18s ease;
}

#taskMode .list-panel #tList .week-view-day-pill::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill::before {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 12px;
  background: transparent;
  opacity: 0;
  pointer-events: none;
  transform: scale(.96);
  transition: opacity .18s ease, transform .18s ease, background .18s ease, box-shadow .18s ease;
}

#taskMode .list-panel #tList .week-view-day-pill > *,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill > * {
  position: relative;
  z-index: 1;
}

#taskMode .list-panel #tList .week-view-day-pill:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover {
  color: color-mix(in srgb, var(--week-accent) 72%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover::before {
  opacity: 1;
  transform: scale(1);
  background: rgba(255, 255, 255, .86);
  box-shadow:
    0 4px 12px -10px rgba(15, 23, 42, .28),
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 58%, transparent);
}

#taskMode .list-panel #tList .week-view-day-pill.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today {
  color: color-mix(in srgb, var(--week-accent) 88%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill.is-today::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today::before {
  opacity: 1;
  transform: scale(1);
  background: color-mix(in srgb, var(--week-accent) 6%, #fff);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 16%, transparent),
    0 4px 14px -14px color-mix(in srgb, var(--week-accent) 30%, transparent);
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty {
  color: color-mix(in srgb, var(--week-muted) 66%, transparent);
}

#taskMode .list-panel #tList .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-name {
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  color: color-mix(in srgb, var(--week-ink) 94%, var(--week-accent));
  background: rgba(255, 255, 255, .84);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 78%, transparent),
    0 4px 10px -12px rgba(15, 23, 42, .3);
  font-size: 13px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

#taskMode .list-panel #tList .week-view-day-pill-alert,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-alert {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: inherit;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-count {
  color: color-mix(in srgb, var(--week-accent) 82%, var(--week-ink));
  background: color-mix(in srgb, var(--week-accent) 9%, #fff);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 15%, transparent),
    0 4px 12px -12px color-mix(in srgb, var(--week-accent) 36%, transparent);
}

/* 逾期只保留局部风险标识，避免整块变色破坏页面的轻量统一感。 */
#taskMode .list-panel #tList .week-day-overdue-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-overdue-text {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
  font-weight: 760;
}

#taskMode .list-panel #tList .week-day-card.is-overdue .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-overdue .week-day-head {
  background: transparent;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue {
  color: color-mix(in srgb, var(--week-muted) 92%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue::before {
  opacity: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue:hover::before {
  opacity: 1;
  transform: scale(1);
  background: rgba(255, 255, 255, .86);
  box-shadow:
    0 4px 12px -10px rgba(15, 23, 42, .28),
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 58%, transparent);
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-count {
  color: color-mix(in srgb, var(--week-ink) 94%, var(--week-accent));
  background: rgba(255, 255, 255, .84);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 78%, transparent),
    0 4px 10px -12px rgba(15, 23, 42, .3);
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-count {
  color: color-mix(in srgb, var(--week-muted) 58%, transparent);
  background: transparent;
  box-shadow: none;
}

/* 无待办日期瘦身：减少已完成/空状态卡片的视觉占用，突出真正需要处理的日期。 */
#taskMode .list-panel #tList .week-day-card.is-clear .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear .week-day-head {
  min-height: 68px;
  padding-top: 14px;
  padding-bottom: 14px;
  transition:
    background .18s ease,
    transform .16s ease,
    border-color .18s ease,
    border-radius .22s ease,
    min-height .22s ease,
    padding .22s ease;
}

#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head {
  border-bottom-color: transparent;
  border-radius: 18px;
}

/* 已完成列表折叠时保留 0 高度展开轨道，避免点击后白底先整体替换再下拉。 */
#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-task-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-task-list {
  display: grid;
  height: 0;
  min-height: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

#taskMode .list-panel #tList .week-day-card.is-clear.is-done-open .week-task-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear.is-done-open .week-task-list {
  opacity: 1;
  pointer-events: auto;
}

#taskMode .list-panel #tList .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-head {
  padding-top: 14px;
  padding-bottom: 9px;
}

#taskMode .list-panel #tList .week-day-card.is-empty .week-day-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-empty {
  min-height: 36px;
  color: color-mix(in srgb, var(--week-muted) 72%, transparent);
}

#taskMode .list-panel #tList .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-head {
  min-height: 68px;
  padding-top: 14px;
  padding-bottom: 14px;
  border-bottom: 0;
  border-radius: 18px;
}

#taskMode .list-panel #tList .week-day-card.is-empty .week-task-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-task-list {
  display: none;
}

@media (max-width: 640px) {
  #taskMode .list-panel #tList .week-view-day-pills,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
    width: 100%;
    grid-template-columns: repeat(7, minmax(42px, 1fr));
    gap: 2px;
    padding: 3px;
  }

  #taskMode .list-panel #tList .week-view-day-pill,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
    height: 32px;
    gap: 4px;
    padding-left: 5px;
    padding-right: 5px;
    font-size: 11px;
  }

  #taskMode .list-panel #tList .week-view-day-pill-count,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-count {
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 11px;
  }
}

/* 周日期导航最终轻量版：一行只读周几和数字，降低认知负担。 */
#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  margin-top: 6px;
  padding-top: 10px;
}

#taskMode .list-panel #tList .week-view-day-pills,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 34px;
  height: 34px;
  padding: 0 4px 8px;
  border-radius: 0;
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  background: transparent;
  box-shadow: none;
  font-size: 12px;
  font-weight: 700;
  overflow: visible;
}

#taskMode .list-panel #tList .week-view-day-pill:not(:first-child),
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:not(:first-child) {
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill::before {
  left: 50%;
  right: auto;
  bottom: 0;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0;
  transform: translateX(-50%) scaleX(.55);
  transform-origin: center;
}

#taskMode .list-panel #tList .week-view-day-pill:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover {
  color: color-mix(in srgb, var(--week-ink) 78%, var(--week-muted));
  background: transparent;
}

#taskMode .list-panel #tList .week-view-day-pill:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover::before {
  opacity: .18;
  transform: translateX(-50%) scaleX(1);
  background: currentColor;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus {
  color: color-mix(in srgb, var(--week-accent) 66%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus::before {
  opacity: .5;
  transform: translateX(-50%) scaleX(1);
  background: currentColor;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus):not(.is-overdue),
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus):not(.is-overdue) {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus)::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus)::before {
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-name {
  color: inherit;
  font-size: 12px;
  font-weight: 730;
}

#taskMode .list-panel #tList .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue {
  display: inline-flex;
  align-items: center;
  justify-self: auto;
  gap: 3px;
  color: inherit;
  font-size: 12px;
  font-weight: 760;
}

#taskMode .list-panel #tList .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-count,
#taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-count,
#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-count {
  min-width: 0;
  height: auto;
  padding: 0;
  color: inherit;
  background: transparent;
  box-shadow: none;
  font-size: 15px;
  font-weight: 820;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue,
#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state {
  color: color-mix(in srgb, #ef4444 78%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue::before {
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue:hover::before {
  opacity: .18;
  transform: translateX(-50%) scaleX(1);
  background: currentColor;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue.is-focus::before {
  opacity: .48;
}

@media (prefers-reduced-motion: reduce) {
  #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title,
  #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title::after,
  #taskMode .list-panel #tList .week-day-count.week-done-count-toggle,
  #taskMode .list-panel #tList .week-day-count-chip,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.task-toggle-anim .week-task-title::after,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-done-count-toggle,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip {
    transition: none !important;
    animation: none !important;
  }
}

/* 周视图轻量扫视：无待办日期只做状态行，减少和待处理日期抢注意力。 */
#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open),
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open),
#taskMode .list-panel #tList .week-day-card.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty {
  background: color-mix(in srgb, var(--card) 98%, transparent);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 64%, transparent),
    0 8px 18px -24px rgba(15, 23, 42, .24);
}

#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-head {
  min-height: 56px;
  padding-top: 10px;
  padding-bottom: 10px;
}

#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open):not(.is-focus):not(.is-today) .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open):not(.is-focus):not(.is-today) .week-day-week,
#taskMode .list-panel #tList .week-day-card.is-empty:not(.is-focus):not(.is-today) .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty:not(.is-focus):not(.is-today) .week-day-week {
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
}

#taskMode .list-panel #tList .week-day-count.week-day-count-group.is-single-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group.is-single-action {
  grid-template-columns: minmax(0, 92px);
  width: 92px;
}

#taskMode .list-panel #tList .week-day-count.week-day-count-group.is-single-action.has-overdue-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group.is-single-action.has-overdue-count {
  grid-template-columns: max-content;
  width: max-content;
}

#taskMode .list-panel #tList .week-day-count.week-day-count-group.is-single-action .week-day-count-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group.is-single-action .week-day-count-chip {
  justify-items: end;
}

/* 待处理日期优先：把真正需要处理的日期放在前面，已清空日期收成轻量区。 */
#taskMode .list-panel #tList .week-day-grid.is-focus-first,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-grid.is-focus-first {
  gap: 14px;
}

/* 待办折叠提示放回卡片内部：让用户扫到底部时也能知道还有未展示任务。 */
#taskMode .list-panel #tList .week-task-list.has-more-collapsed::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.has-more-collapsed::after {
  z-index: 1;
}

#taskMode .list-panel #tList .week-task-more-inline,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-inline {
  position: relative;
  z-index: 2;
  width: auto;
  min-height: 34px;
  margin: 0 24px 11px 22px;
  padding: 8px 0 2px 0;
  border: 0;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 96%, transparent), color-mix(in srgb, var(--card) 100%, #fff));
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  font: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
  text-align: left;
  cursor: pointer;
  transition: color .18s ease, border-color .18s ease, transform .18s ease;
}

#taskMode .list-panel #tList .week-task-more-inline::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-inline::before {
  content: none;
}

#taskMode .list-panel #tList .week-task-more-inline:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-inline:hover {
  color: color-mix(in srgb, var(--week-accent) 72%, var(--week-ink));
}

#taskMode .list-panel #tList .week-task-more-inline:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-inline:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--week-accent) 34%, transparent);
  outline-offset: 2px;
}

#taskMode .list-panel #tList .week-task-more-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-line {
  display: block;
  flex: 0 0 22px;
  width: 22px;
  height: 1.5px;
  margin: 0;
  background: color-mix(in srgb, currentColor 56%, transparent);
  border-radius: 999px;
  opacity: .96;
  align-self: center;
  pointer-events: none;
}

#taskMode .list-panel #tList .week-task-more-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-action {
  color: color-mix(in srgb, var(--week-accent) 78%, var(--week-ink));
  font-weight: 500;
}

#taskMode .list-panel #tList .week-task-more-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-caret {
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  opacity: .68;
  transform: rotate(45deg) translateY(-1px);
  transition: transform .18s ease, opacity .18s ease;
}

#taskMode .list-panel #tList .week-task-more-inline.is-open .week-task-more-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-more-inline.is-open .week-task-more-caret {
  opacity: .86;
  transform: rotate(225deg) translate(-2px, -1px);
}

/* 周视图批量展开是辅助操作，降低按钮重量，避免和卡片内展开入口争抢注意力。 */
#taskMode .add-split.add-split--quick-shortcut.is-week-bulk-hidden,
.app.app--with-global-nav #taskMode .add-split.add-split--quick-shortcut.is-week-bulk-hidden {
  display: none !important;
}

#taskMode .add-split.add-split--quick-shortcut.is-week-bulk-booting .add-split-main,
.app.app--with-global-nav #taskMode .add-split.add-split--quick-shortcut.is-week-bulk-booting .add-split-main {
  transition: none !important;
}

#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"],
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"] {
  min-height: 38px !important;
  height: 38px !important;
  padding: 8px 15px !important;
  border: 1px solid color-mix(in srgb, var(--week-accent) 18%, var(--week-line)) !important;
  background: color-mix(in srgb, var(--card) 96%, #eef2ff) !important;
  color: color-mix(in srgb, var(--week-accent) 72%, var(--week-ink)) !important;
  box-shadow: 0 10px 24px -28px color-mix(in srgb, var(--week-accent) 42%, transparent) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
}

#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"]:hover,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"]:hover {
  background: color-mix(in srgb, var(--week-accent) 8%, var(--card)) !important;
  color: color-mix(in srgb, var(--week-accent) 84%, var(--week-ink)) !important;
  box-shadow: 0 12px 26px -26px color-mix(in srgb, var(--week-accent) 34%, transparent) !important;
}

#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"].is-week-bulk-idle,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"].is-week-bulk-idle {
  opacity: .62;
  cursor: default;
  transform: none !important;
  box-shadow: none !important;
}

#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"] svg,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut .add-split-main[data-week-bulk-toggle="1"] svg {
  width: 15px !important;
  height: 15px !important;
  stroke-width: 2.4 !important;
}

#taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"],
.app.app--with-global-nav #taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"] {
  min-height: 38px !important;
  height: 38px !important;
  padding: 8px 15px !important;
  border: 1px solid color-mix(in srgb, var(--week-accent) 18%, var(--week-line)) !important;
  background: color-mix(in srgb, var(--card) 96%, #eef2ff) !important;
  color: color-mix(in srgb, var(--week-accent) 72%, var(--week-ink)) !important;
  box-shadow: 0 10px 24px -28px color-mix(in srgb, var(--week-accent) 42%, transparent) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
}

#taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"]:hover,
.app.app--with-global-nav #taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"]:hover {
  background: color-mix(in srgb, var(--week-accent) 8%, var(--card)) !important;
  color: color-mix(in srgb, var(--week-accent) 84%, var(--week-ink)) !important;
  box-shadow: 0 12px 26px -26px color-mix(in srgb, var(--week-accent) 34%, transparent) !important;
}

#taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"].is-week-bulk-idle,
.app.app--with-global-nav #taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"].is-week-bulk-idle {
  opacity: .62;
  cursor: default;
  transform: none !important;
  box-shadow: none !important;
}

#taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"] svg,
.app.app--with-global-nav #taskMode #btnAddTaskBar.add-split-main[data-week-bulk-toggle="1"] svg {
  width: 15px !important;
  height: 15px !important;
  stroke-width: 2.4 !important;
}

#taskMode .add-split.add-split--instant-restore,
.app.app--with-global-nav #taskMode .add-split.add-split--instant-restore,
#taskMode .add-split.add-split--instant-restore .add-split-main,
.app.app--with-global-nav #taskMode .add-split.add-split--instant-restore .add-split-main,
#taskMode .add-split.add-split--instant-restore .add-split-quick,
.app.app--with-global-nav #taskMode .add-split.add-split--instant-restore .add-split-quick,
#taskMode .add-split.add-split--instant-restore svg,
.app.app--with-global-nav #taskMode .add-split.add-split--instant-restore svg {
  transition: none !important;
  animation: none !important;
}

#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore .add-split-main,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore .add-split-main,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore .add-split-quick,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore .add-split-quick,
#taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore svg,
.app.app--with-global-nav #taskMode .task-main-col > .task-card > .date-nav .date-nav-actions .add-split.add-split--quick-shortcut.add-split--instant-restore svg {
  transition: none !important;
  animation: none !important;
}

#taskMode .list-panel #tList .week-quiet-days,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days {
  display: grid;
  gap: 8px;
  padding-top: 2px;
}

#taskMode .list-panel #tList .week-quiet-days-toggle,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-toggle {
  width: 100%;
  min-height: 46px;
  display: grid;
  grid-template-columns: minmax(170px, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 9px 16px;
  border: 1px solid color-mix(in srgb, var(--week-line) 64%, transparent);
  border-radius: 16px;
  background: color-mix(in srgb, var(--card) 96%, transparent);
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
  text-align: left;
  cursor: pointer;
  transition:
    background .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .18s ease;
}

#taskMode .list-panel #tList .week-quiet-days-toggle:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-toggle:hover {
  border-color: color-mix(in srgb, var(--accent) 24%, var(--week-line));
  background: color-mix(in srgb, var(--card) 99%, var(--accent) 1%);
  box-shadow: 0 12px 26px -26px color-mix(in srgb, var(--accent) 44%, transparent);
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-quiet-days-toggle:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-toggle:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 38%, transparent);
  outline-offset: 3px;
}

#taskMode .list-panel #tList .week-quiet-days-main,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-main {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
}

#taskMode .list-panel #tList .week-quiet-days-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-label {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-quiet-days-summary,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-summary {
  min-width: 0;
  color: color-mix(in srgb, var(--week-muted) 72%, transparent);
  font-size: 12px;
  font-weight: 650;
  letter-spacing: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-quiet-days-pills,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-pills {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

#taskMode .list-panel #tList .week-quiet-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-day-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 22px;
  padding: 2px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--week-line) 42%, transparent);
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-quiet-day-pill b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-day-pill b {
  color: color-mix(in srgb, var(--week-ink) 72%, var(--week-muted));
  font-size: 12px;
  font-weight: 800;
}

#taskMode .list-panel #tList .week-quiet-day-pill.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-day-pill.is-empty {
  opacity: .64;
}

#taskMode .list-panel #tList .week-quiet-days-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-caret {
  width: 8px;
  height: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  opacity: .66;
  transform: rotate(45deg) translateY(-1px);
  transition: transform .18s ease, opacity .18s ease;
}

#taskMode .list-panel #tList .week-quiet-days.is-open .week-quiet-days-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days.is-open .week-quiet-days-caret {
  opacity: .86;
  transform: rotate(225deg) translate(-2px, -1px);
}

#taskMode .list-panel #tList .week-quiet-days-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-list {
  display: grid;
  gap: 8px;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition:
    max-height .28s cubic-bezier(.22, 1, .36, 1),
    opacity .2s ease,
    transform .2s ease;
}

#taskMode .list-panel #tList .week-quiet-days.is-open .week-quiet-days-list,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days.is-open .week-quiet-days-list {
  max-height: 1400px;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

#taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-clear:not(.is-done-open) .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-clear:not(.is-done-open) .week-day-head,
#taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-empty .week-day-head {
  min-height: 48px;
  padding-top: 8px;
  padding-bottom: 8px;
}

#taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-clear:not(.is-done-open),
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-clear:not(.is-done-open),
#taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-list .week-day-card.is-empty {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--week-line) 58%, transparent);
}

@media (max-width: 720px) {
  #taskMode .list-panel #tList .week-quiet-days-toggle,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-toggle {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 8px 12px;
  }

  #taskMode .list-panel #tList .week-quiet-days-main,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-main {
    flex-wrap: wrap;
    gap: 4px 8px;
  }

  #taskMode .list-panel #tList .week-quiet-days-pills,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-pills {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

/* 周概览日期条底部收紧：减少日期导航下方的空白。 */
#taskMode .list-panel #tList .week-view-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
  padding-bottom: 8px;
}

#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  margin-top: 4px;
  padding-top: 8px;
}

#taskMode .list-panel #tList .week-view-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
  min-height: 30px;
  height: 30px;
  padding-bottom: 5px;
}

/* 周概览日期条轻量版：中性色为主，只把逾期和当前定位作为必要强调。 */
#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px solid color-mix(in srgb, var(--week-line) 54%, transparent);
  overflow-x: visible;
  scrollbar-width: auto;
}

#taskMode .list-panel #tList .week-view-day-pills,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0;
  width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
  appearance: none;
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-content: start;
  justify-items: center;
  gap: 6px;
  min-width: 0;
  min-height: 52px;
  height: 52px;
  padding: 15px 6px 6px;
  border: 0;
  border-radius: 6px;
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  background: transparent;
  box-shadow: none;
  font: inherit;
  text-align: center;
  overflow: visible;
  cursor: pointer;
  transition: color .16s ease, background .16s ease;
}

#taskMode .list-panel #tList .week-view-day-pill::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill::before {
  content: "";
  position: absolute;
  left: 50%;
  right: auto;
  top: 5px;
  bottom: auto;
  width: min(34px, calc(100% - 22px));
  height: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--week-accent) 78%, var(--week-ink));
  opacity: 0;
  transform: translateX(-50%);
  box-shadow: none;
  pointer-events: none;
  transition: opacity .16s ease, width .16s ease, background .16s ease;
}

#taskMode .list-panel #tList .week-view-day-pill:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover {
  color: color-mix(in srgb, var(--week-ink) 82%, var(--week-muted));
  background: transparent;
  box-shadow: none;
  transform: none;
}

#taskMode .list-panel #tList .week-view-day-pill:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover::before {
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus {
  color: color-mix(in srgb, var(--week-ink) 88%, var(--week-muted));
  background: transparent;
  box-shadow: none;
  border-color: transparent;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus::before {
  left: 50%;
  right: auto;
  width: min(36px, calc(100% - 18px));
  opacity: .78;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus):not(.is-overdue),
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus):not(.is-overdue),
#taskMode .list-panel #tList .week-view-day-pill.is-clear,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-clear {
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  border-color: transparent;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus)::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:not(.is-focus)::before {
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty {
  color: color-mix(in srgb, var(--week-muted) 62%, transparent);
  background: transparent;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue,
#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state {
  color: color-mix(in srgb, #dc2626 82%, var(--week-ink));
  border-color: transparent;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue::before {
  background: currentColor;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue:hover::before {
  opacity: 0;
  transform: translateX(-50%);
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue.is-focus::before {
  opacity: .55;
  transform: translateX(-50%);
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill > *,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill > * {
  position: relative;
  z-index: 1;
}

#taskMode .list-panel #tList .week-view-day-pill-main,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-main {
  min-width: 0;
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 5px;
  line-height: 1;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-name {
  color: inherit;
  font-size: 12px;
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-date {
  color: color-mix(in srgb, currentColor 58%, var(--week-muted));
  font-size: 11px;
  font-weight: 650;
  line-height: 1;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  justify-self: center;
  gap: 3px;
  min-width: 0;
  max-width: 100%;
  min-height: 0;
  padding: 0;
  border-radius: 0;
  color: inherit;
  background: transparent;
  box-shadow: none;
  font-size: 10px;
  font-weight: 680;
  line-height: 1;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-count,
#taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-count,
#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-count {
  min-width: 0;
  height: auto;
  padding: 0;
  color: inherit;
  background: transparent;
  box-shadow: none;
  font-size: 14px;
  font-weight: 820;
  font-variant-numeric: tabular-nums;
  line-height: .95;
}

#taskMode .list-panel #tList .week-view-day-pill-state-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state-text {
  color: color-mix(in srgb, currentColor 76%, var(--week-muted));
  font-size: 10px;
  font-weight: 680;
}

#taskMode .list-panel #tList .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue {
  align-items: center;
  gap: 4px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill-state--overdue .week-overdue-icon-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue .week-overdue-icon-wrap {
  width: 13px;
  height: 13px;
}

#taskMode .list-panel #tList .week-view-day-pill-state--overdue .week-overdue-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue .week-overdue-icon {
  width: 12px;
  height: 12px;
}

#taskMode .list-panel #tList .week-view-day-pill-bar,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-bar {
  display: none;
}

#taskMode .list-panel #tList .week-view-day-pill:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--week-accent) 34%, transparent);
  outline-offset: 2px;
}

@media (max-width: 720px) {
  #taskMode .list-panel #tList .week-view-day-strip,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
    overflow-x: auto;
    padding-bottom: 2px;
  }

  #taskMode .list-panel #tList .week-view-day-pills,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
    grid-template-columns: repeat(7, minmax(56px, 1fr));
    gap: 2px;
    width: max-content;
    min-width: 100%;
  }

  #taskMode .list-panel #tList .week-view-day-pill,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
    min-height: 50px;
    height: 50px;
    padding: 14px 5px 6px;
  }

  #taskMode .list-panel #tList .week-view-day-pill-main,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-main {
    display: grid;
    gap: 3px;
  }

  #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state-text,
  #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state-text,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state-text,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state-text {
    display: none;
  }
}

/* 周概览汇总行：使用明确容器承载标题、数据和进度，避免旧网格规则干扰。 */
#taskMode .list-panel #tList .week-view-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 8px;
  padding: 12px 18px 8px;
}

#taskMode .list-panel #tList .week-view-top.week-view-summary-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-top.week-view-summary-line {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  min-width: 0;
}

#taskMode .list-panel #tList .week-view-summary-line .week-view-title-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-title-group,
#taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
#taskMode .list-panel #tList .week-view-summary-line .week-view-progress,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress {
  order: initial;
  grid-column: auto;
  grid-row: auto;
}

#taskMode .list-panel #tList .week-view-summary-line .week-view-title-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-title-group {
  flex: 0 0 auto;
}

#taskMode .list-panel #tList .week-view-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title {
  font-size: 15px;
  line-height: 1.2;
}

#taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-stats {
  flex: 0 0 auto;
  min-width: 0;
}

#taskMode .list-panel #tList .week-view-inline-action,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 24px;
  padding: 2px 8px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: color-mix(in srgb, var(--week-muted) 78%, var(--week-ink));
  font: inherit;
  font-size: 12px;
  font-weight: 720;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: color .16s ease, background .16s ease, border-color .16s ease;
}

#taskMode .list-panel #tList .week-view-inline-action svg,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  stroke-width: 2.35;
}

#taskMode .list-panel #tList .week-view-inline-action:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action:hover {
  color: color-mix(in srgb, var(--week-ink) 84%, var(--week-accent));
  background: color-mix(in srgb, var(--week-accent) 6%, transparent);
  border-color: color-mix(in srgb, var(--week-accent) 14%, transparent);
}

#taskMode .list-panel #tList .week-view-stat,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat {
  min-height: 22px;
  padding-right: 12px;
  margin-right: 12px;
}

#taskMode .list-panel #tList .week-view-stat:not(:last-child)::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat:not(:last-child)::after {
  height: 18px;
}

#taskMode .list-panel #tList .week-view-summary-line .week-view-progress,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress {
  flex: 0 1 210px;
  min-width: 160px;
  margin-left: auto;
  justify-content: flex-end;
  gap: 10px;
}

#taskMode .list-panel #tList .week-view-progress-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  line-height: 1;
}

#taskMode .list-panel #tList .week-view-progress-label b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label b {
  font-size: 17px;
}

#taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track {
  flex: 1 1 100px;
  width: auto;
  max-width: 128px;
  height: 8px;
}

#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  order: initial;
  flex: none;
  width: 100%;
}

@media (max-width: 760px) {
  #taskMode .list-panel #tList .week-view-top.week-view-summary-line,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-top.week-view-summary-line {
    flex-wrap: wrap;
    gap: 8px 12px;
  }

  #taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-stats {
    flex: 1 1 180px;
  }

  #taskMode .list-panel #tList .week-view-summary-line .week-view-progress,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress {
    flex: 1 0 100%;
    min-width: 0;
    width: 100%;
    margin-left: 0;
  }

  #taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track,
  .app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track {
    max-width: none;
  }
}

/* 周概览空状态：普通无任务日期保持浅色，但“今天”仍应保留当前日期样式。 */
#taskMode .list-panel #tList .week-view-day-pill.is-empty,
#taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus {
  color: color-mix(in srgb, var(--week-muted) 58%, transparent);
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty::before,
#taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus::before {
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state-text {
  color: color-mix(in srgb, var(--week-muted) 62%, transparent);
}

/* 周概览日期指示条固定在今天，避免 hover 或当前定位时跟随其他日期移动。 */
#taskMode .list-panel #tList .week-view-day-pill::before,
#taskMode .list-panel #tList .week-view-day-pill:hover::before,
#taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
#taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus::before {
  left: 50%;
  right: auto;
  width: clamp(32px, calc(100% - 32px), 56px);
  opacity: 0;
  transform: translateX(-50%);
}

#taskMode .list-panel #tList .week-view-day-pill.is-today::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today:hover::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus::before {
  left: 50%;
  right: auto;
  top: 5px;
  bottom: auto;
  width: clamp(32px, calc(100% - 32px), 56px);
  height: 2px;
  opacity: .72;
  background: color-mix(in srgb, var(--week-ink) 56%, var(--week-muted));
  border-radius: 999px;
  box-shadow: none;
  transform: translateX(-50%);
  transform-origin: center;
}

/* 周视图视觉校准：降低框感和噪音，保留轻量层级。 */
.app.app--with-global-nav #taskMode:not(.task-mode--overdue-view):not(.task-mode--priority-view):not(.task-mode--repeat-view):not(.task-mode--frozen-view) .task-main-col > .task-card > .date-nav,
#taskMode:not(.task-mode--overdue-view):not(.task-mode--priority-view):not(.task-mode--repeat-view):not(.task-mode--frozen-view) .task-main-col > .task-card > .date-nav {
  padding-top: 16px !important;
  margin-bottom: 12px !important;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view,
#taskMode .list-panel #tList .week-view {
  gap: 12px;
  padding-bottom: 10px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head,
#taskMode .list-panel #tList .week-view-head {
  padding: 11px 18px 7px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--card) 98%, #f8fafc);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 46%, transparent),
    0 8px 20px -26px rgba(15, 23, 42, 0.28);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head:hover,
#taskMode .list-panel #tList .week-view-head:hover {
  transform: none;
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-line) 54%, transparent),
    0 8px 20px -26px rgba(15, 23, 42, 0.28);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-top.week-view-summary-line,
#taskMode .list-panel #tList .week-view-top.week-view-summary-line {
  gap: 12px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title,
#taskMode .list-panel #tList .week-view-title {
  font-size: 14px;
  font-weight: 720;
  letter-spacing: 0;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat,
#taskMode .list-panel #tList .week-view-stat {
  min-height: 20px;
  margin-right: 10px;
  padding-right: 10px;
  font-size: 11px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat b,
#taskMode .list-panel #tList .week-view-stat b {
  font-size: 15px;
  font-weight: 720;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action,
#taskMode .list-panel #tList .week-view-inline-action {
  margin-left: auto;
  min-height: 22px;
  padding: 0 8px;
  border-color: color-mix(in srgb, var(--week-line) 42%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--week-line) 24%, transparent);
  box-shadow: none;
  color: color-mix(in srgb, var(--week-muted) 84%, var(--week-ink));
  font-size: 11px;
  font-weight: 650;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action:hover,
#taskMode .list-panel #tList .week-view-inline-action:hover {
  border-color: color-mix(in srgb, var(--week-line) 58%, transparent);
  background: color-mix(in srgb, var(--week-line) 32%, transparent);
  color: color-mix(in srgb, var(--week-ink) 72%, var(--week-muted));
  transform: none;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action + .week-view-progress,
#taskMode .list-panel #tList .week-view-inline-action + .week-view-progress {
  margin-left: 8px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-stats + .week-view-progress,
#taskMode .list-panel #tList .week-view-summary-line .week-view-stats + .week-view-progress {
  margin-left: auto;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress,
#taskMode .list-panel #tList .week-view-summary-line .week-view-progress {
  flex: 0 1 200px;
  min-width: 150px;
  gap: 8px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label,
#taskMode .list-panel #tList .week-view-progress-label {
  font-size: 11px;
  font-weight: 650;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label b,
#taskMode .list-panel #tList .week-view-progress-label b {
  font-size: 16px;
  font-weight: 720;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-track,
#taskMode .list-panel #tList .week-view-progress-track {
  height: 7px;
  max-width: 124px;
  background: color-mix(in srgb, var(--week-line) 58%, transparent);
  box-shadow: none;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card,
#taskMode .list-panel #tList .week-day-card {
  box-sizing: border-box;
  border-radius: 16px;
  border: 1px solid #d6daf8;
  background: color-mix(in srgb, var(--card) 98%, #f8fafc);
  box-shadow:
    0 8px 18px -24px rgba(15, 23, 42, 0.28);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card:hover,
#taskMode .list-panel #tList .week-day-card:hover {
  transform: none;
  border-color: #d6daf8;
  box-shadow:
    0 8px 18px -24px rgba(15, 23, 42, 0.28);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today,
#taskMode .list-panel #tList .week-day-card.is-focus,
#taskMode .list-panel #tList .week-day-card.is-today {
  border-color: #d6daf8;
  box-shadow:
    0 10px 22px -28px color-mix(in srgb, var(--week-accent) 28%, transparent);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before,
#taskMode .list-panel #tList .week-day-card::before {
  top: 18px;
  bottom: auto;
  left: 14px;
  width: 3px;
  height: 26px;
  border-radius: 999px;
  opacity: 0;
  transform: none;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today::before,
#taskMode .list-panel #tList .week-day-card.is-focus::before,
#taskMode .list-panel #tList .week-day-card.is-today::before {
  opacity: 0.62;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head,
#taskMode .list-panel #tList .week-day-head {
  padding: 13px 22px 10px 28px;
  border-bottom-color: color-mix(in srgb, var(--week-line) 46%, transparent);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-week,
#taskMode .list-panel #tList .week-day-week,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-week,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-week {
  color: color-mix(in srgb, var(--week-ink) 92%, var(--week-muted));
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-date,
#taskMode .list-panel #tList .week-day-date,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-date,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-date {
  padding: 0;
  background: transparent;
  box-shadow: none;
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-size: 13px;
  font-weight: 600;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-date-label,
#taskMode .list-panel #tList .week-day-date-label,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-date-label,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-date-label {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-weight: 600;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item,
#taskMode .list-panel #tList .week-task-item {
  min-height: 48px;
  padding: 8px 28px 7px 28px;
  border-radius: 8px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item + .week-task-item::before,
#taskMode .list-panel #tList .week-task-item + .week-task-item::before {
  left: 62px;
  right: 34px;
  background: color-mix(in srgb, var(--week-line) 45%, transparent);
  opacity: 0.78;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title-text,
#taskMode .list-panel #tList .week-task-title,
#taskMode .list-panel #tList .week-task-title-text {
  color: color-mix(in srgb, var(--week-ink) 92%, #111827);
  font-size: var(--task-title-size-week);
  font-weight: 640;
  letter-spacing: 0;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-time,
#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-time {
  color: color-mix(in srgb, var(--week-muted) 78%, var(--week-ink));
  font-size: 12px;
  font-weight: 500;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days,
#taskMode .list-panel #tList .week-quiet-days {
  gap: 6px;
  padding-top: 0;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-toggle,
#taskMode .list-panel #tList .week-quiet-days-toggle {
  min-height: 34px;
  grid-template-columns: minmax(150px, auto) minmax(0, 1fr) auto;
  padding: 6px 12px;
  border-color: color-mix(in srgb, var(--week-line) 38%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--card) 99%, transparent);
  box-shadow: none;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-toggle:hover,
#taskMode .list-panel #tList .week-quiet-days-toggle:hover {
  border-color: color-mix(in srgb, var(--week-line) 50%, transparent);
  background: color-mix(in srgb, var(--week-line) 13%, var(--card));
  box-shadow: none;
  transform: none;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-label,
#taskMode .list-panel #tList .week-quiet-days-label {
  font-size: 11px;
  font-weight: 680;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-days-summary,
#taskMode .list-panel #tList .week-quiet-days-summary {
  font-size: 11px;
  font-weight: 600;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-quiet-day-pill,
#taskMode .list-panel #tList .week-quiet-day-pill {
  min-height: 20px;
  padding: 1px 7px;
  background: color-mix(in srgb, var(--week-line) 26%, transparent);
  font-size: 10.5px;
  font-weight: 650;
}

.app.app--with-global-nav > #taskMode:not(.hidden) > .task-main-col,
#taskMode .task-main-col,
.app.app--with-global-nav #taskMode .list-panel .tasks,
#taskMode .list-panel .tasks,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll,
#taskMode .list-panel #tList .week-task-list.is-scroll {
  scrollbar-color: color-mix(in srgb, var(--week-line, var(--inp-bd)) 42%, transparent) transparent;
  scrollbar-width: thin;
}

.app.app--with-global-nav > #taskMode:not(.hidden) > .task-main-col::-webkit-scrollbar,
#taskMode .task-main-col::-webkit-scrollbar,
.app.app--with-global-nav #taskMode .list-panel .tasks::-webkit-scrollbar,
#taskMode .list-panel .tasks::-webkit-scrollbar,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar,
#taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.app.app--with-global-nav > #taskMode:not(.hidden) > .task-main-col::-webkit-scrollbar-track,
#taskMode .task-main-col::-webkit-scrollbar-track,
.app.app--with-global-nav #taskMode .list-panel .tasks::-webkit-scrollbar-track,
#taskMode .list-panel .tasks::-webkit-scrollbar-track,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar-track,
#taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar-track {
  background: transparent;
}

.app.app--with-global-nav > #taskMode:not(.hidden) > .task-main-col::-webkit-scrollbar-thumb,
#taskMode .task-main-col::-webkit-scrollbar-thumb,
.app.app--with-global-nav #taskMode .list-panel .tasks::-webkit-scrollbar-thumb,
#taskMode .list-panel .tasks::-webkit-scrollbar-thumb,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar-thumb,
#taskMode .list-panel #tList .week-task-list.is-scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--week-line, var(--inp-bd)) 34%, transparent);
}

.app.app--with-global-nav > #taskMode:not(.hidden) > .task-main-col:hover::-webkit-scrollbar-thumb,
#taskMode .task-main-col:hover::-webkit-scrollbar-thumb,
.app.app--with-global-nav #taskMode .list-panel .tasks:hover::-webkit-scrollbar-thumb,
#taskMode .list-panel .tasks:hover::-webkit-scrollbar-thumb,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-list.is-scroll:hover::-webkit-scrollbar-thumb,
#taskMode .list-panel #tList .week-task-list.is-scroll:hover::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--week-line, var(--inp-bd)) 56%, transparent);
}

/* 今天与当前定位重合时，也保持低饱和层级。 */
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus::before,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus::before {
  opacity: 0.62;
  transform: none;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-head {
  background: transparent;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-date-text,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-date-text,
#taskMode .list-panel #tList .week-day-card.is-focus .week-day-date-text,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-date-label,
#taskMode .list-panel #tList .week-day-card.is-today.is-focus .week-day-date-text {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-weight: 600;
}

/* 概览行二次校准：把操作和进度降为辅助信息。 */
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-top.week-view-summary-line,
#taskMode .list-panel #tList .week-view-top.week-view-summary-line {
  gap: 11px;
  min-height: 30px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-title-group,
#taskMode .list-panel #tList .week-view-summary-line .week-view-title-group {
  margin-right: 2px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
#taskMode .list-panel #tList .week-view-summary-line .week-view-stats {
  gap: 0;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat,
#taskMode .list-panel #tList .week-view-stat {
  min-height: 18px;
  margin-right: 9px;
  padding-right: 9px;
  color: color-mix(in srgb, var(--week-muted) 80%, var(--week-ink));
  font-size: 11px;
  font-weight: 620;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat b,
#taskMode .list-panel #tList .week-view-stat b {
  margin-right: 3px;
  color: color-mix(in srgb, var(--week-ink) 94%, #111827);
  font-size: 15px;
  font-weight: 700;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat:not(:last-child)::after,
#taskMode .list-panel #tList .week-view-stat:not(:last-child)::after {
  height: 13px;
  background: color-mix(in srgb, var(--week-line) 46%, transparent);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action,
#taskMode .list-panel #tList .week-view-inline-action {
  min-height: 20px;
  padding: 0 2px;
  border-color: transparent;
  background: transparent;
  color: color-mix(in srgb, var(--week-muted) 86%, var(--week-ink));
  font-size: 11px;
  font-weight: 650;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action svg,
#taskMode .list-panel #tList .week-view-inline-action svg {
  width: 12px;
  height: 12px;
  opacity: 0.58;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action:hover,
#taskMode .list-panel #tList .week-view-inline-action:hover {
  border-color: transparent;
  background: color-mix(in srgb, var(--week-line) 24%, transparent);
  color: color-mix(in srgb, var(--week-ink) 76%, var(--week-muted));
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action + .week-view-progress,
#taskMode .list-panel #tList .week-view-inline-action + .week-view-progress {
  margin-left: 6px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress,
#taskMode .list-panel #tList .week-view-summary-line .week-view-progress {
  flex: 0 0 auto;
  min-width: 0;
  gap: 7px;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label,
#taskMode .list-panel #tList .week-view-progress-label {
  color: color-mix(in srgb, var(--week-muted) 82%, var(--week-ink));
  font-size: 11px;
  font-weight: 650;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label b,
#taskMode .list-panel #tList .week-view-progress-label b {
  margin-left: 4px;
  color: color-mix(in srgb, var(--week-ink) 92%, #111827);
  font-size: 15px;
  font-weight: 700;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track,
#taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track {
  flex: 0 0 112px;
  width: 112px;
  max-width: 112px;
  height: 6px;
  background: color-mix(in srgb, var(--week-line) 46%, transparent);
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-fill,
#taskMode .list-panel #tList .week-view-progress-fill {
  background: color-mix(in srgb, var(--week-accent) 76%, var(--week-ink));
  box-shadow: none;
}

/* 概览行垂直对齐修正：所有子块共享同一条视觉中线。 */
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-top.week-view-summary-line,
#taskMode .list-panel #tList .week-view-top.week-view-summary-line {
  align-items: center;
  min-height: 32px;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line > *,
#taskMode .list-panel #tList .week-view-summary-line > * {
  align-self: center;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-title-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress,
#taskMode .list-panel #tList .week-view-summary-line .week-view-title-group,
#taskMode .list-panel #tList .week-view-summary-line .week-view-stats,
#taskMode .list-panel #tList .week-view-summary-line .week-view-progress {
  display: flex;
  align-items: center;
  height: 24px;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-title,
#taskMode .list-panel #tList .week-view-title {
  display: flex;
  align-items: center;
  min-height: 24px;
  margin: 0;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat,
#taskMode .list-panel #tList .week-view-stat {
  display: inline-flex;
  align-items: center;
  height: 22px;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-stat b,
#taskMode .list-panel #tList .week-view-stat b {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action,
#taskMode .list-panel #tList .week-view-inline-action {
  display: inline-flex;
  align-items: center;
  height: 22px;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-inline-action svg,
#taskMode .list-panel #tList .week-view-inline-action svg {
  display: block;
  flex: 0 0 auto;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label,
#taskMode .list-panel #tList .week-view-progress-label {
  display: inline-flex;
  align-items: center;
  height: 22px;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-progress-label b,
#taskMode .list-panel #tList .week-view-progress-label b {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.app.app--with-global-nav #taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track,
#taskMode .list-panel #tList .week-view-summary-line .week-view-progress-track {
  align-self: center;
}

/* 日程三栏壳层滚动修正：去掉浏览器双侧 gutter 与外层滚动条。 */
/* Shared root viewport and scrollbar behavior now lives in css/01-base.css. */
#appMain.show:has(.app.app--with-global-nav > #taskMode:not(.hidden)) {
  width: 100%;
  min-width: 0;
  height: 100dvh;
  min-height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  background: var(--bg);
}

#appMain.show:has(.app.app--with-global-nav > #taskMode:not(.hidden)) .site-header {
  flex: 0 0 auto;
}

#appMain.show:has(.app.app--with-global-nav > #taskMode:not(.hidden)) .app {
  width: 100%;
  max-width: var(--layout-shell-app-max-width, 1604px);
  margin: 0 auto;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: var(--bg);
}

#appMain.show:has(.app.app--with-global-nav > #taskMode:not(.hidden)) .app.app--with-global-nav {
  height: auto;
  min-height: 0;
  overflow: hidden;
}

/* 本周已完成任务：后置覆盖最终标题色，保持和普通任务完成态一致的灰蓝弱化。 */
#taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-title-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title-text {
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
}

#taskMode .list-panel #tList .week-task-item.is-done .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-sub-meta {
  color: color-mix(in srgb, var(--week-muted) 72%, transparent);
}

/* 本周任务圆环：补齐和主任务列表一致的普通/高优先级视觉参数。 */
#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done) .chk-ring:not(.checked):not(.chk-ring--archived),
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done) .chk-ring:not(.checked):not(.chk-ring--archived) {
  border-color: var(--task-check-accent) !important;
  background: var(--task-check-accent-bg) !important;
  box-shadow: none !important;
}

#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done) .chk-ring:not(.checked):not(.chk-ring--archived):hover,
#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done) .chk-ring:not(.checked):not(.chk-ring--archived).hover-check,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done) .chk-ring:not(.checked):not(.chk-ring--archived):hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done) .chk-ring:not(.checked):not(.chk-ring--archived).hover-check {
  border-color: var(--task-check-accent) !important;
  background: var(--task-check-accent-bg) !important;
  box-shadow: none !important;
}

#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done):not(.task-ck-ring--prio-high) .chk-ring:not(.checked):not(.chk-ring--archived),
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done):not(.task-ck-ring--prio-high) .chk-ring:not(.checked):not(.chk-ring--archived) {
  border-width: 1.5px !important;
  border-color: var(--ck-prio, #94a3b8) !important;
  background: color-mix(in srgb, var(--ck-prio, #94a3b8) 9%, var(--card)) !important;
}

#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done):not(.task-ck-ring--prio-high) .chk-ring:not(.checked):not(.chk-ring--archived):hover,
#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done):not(.task-ck-ring--prio-high) .chk-ring:not(.checked):not(.chk-ring--archived).hover-check,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done):not(.task-ck-ring--prio-high) .chk-ring:not(.checked):not(.chk-ring--archived):hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--done):not(.task-ck-ring--prio-high) .chk-ring:not(.checked):not(.chk-ring--archived).hover-check {
  border-color: color-mix(in srgb, var(--ck-prio, #94a3b8) 86%, #475569) !important;
  background: color-mix(in srgb, var(--ck-prio, #94a3b8) 13%, var(--card)) !important;
}

#taskMode .list-panel #tList .week-task-marker.task-ck-ring--prio-high:not(.task-ck-ring--done):not(.task-ck-ring--archived) .chk-ring:not(.checked),
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker.task-ck-ring--prio-high:not(.task-ck-ring--done):not(.task-ck-ring--archived) .chk-ring:not(.checked) {
  border-width: 1.75px !important;
}

#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--archived) .chk-ring.checked,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--archived) .chk-ring.checked {
  background: var(--task-check-accent) !important;
  border-color: var(--task-check-accent) !important;
  box-shadow: 0 2px 6px var(--task-check-accent-shadow) !important;
}

#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--archived) .chk-ring.checked .chk-ring-ico,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--archived) .chk-ring.checked .chk-ring-ico {
  color: #fff !important;
  opacity: 1 !important;
}

#taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--archived):not(.task-ck-ring--prio-high) .chk-ring.checked,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-marker:not(.task-ck-ring--archived):not(.task-ck-ring--prio-high) .chk-ring.checked {
  background: var(--ck-prio, #94a3b8) !important;
  border-color: var(--ck-prio, #94a3b8) !important;
  box-shadow: 0 2px 6px color-mix(in srgb, var(--ck-prio, #94a3b8) 32%, transparent) !important;
}

/* 本周日期头部：日期状态和星期同排展示，数字预留宽度避免跳动。 */
#taskMode .list-panel #tList .week-day-title-btn,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-title-btn {
  display: grid;
  grid-template-columns: 3.25em minmax(0, 1fr);
  align-items: center;
  column-gap: 10px;
  row-gap: 0;
}

#taskMode .list-panel #tList .week-day-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-name {
  min-width: 0;
  gap: 0;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-week {
  display: inline-block;
  min-width: 3.25em;
  white-space: nowrap;
}

#taskMode .list-panel #tList .week-day-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-meta {
  display: flex;
  align-items: center;
  grid-column: auto;
  min-width: 0;
}

#taskMode .list-panel #tList .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-label {
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

#taskMode .list-panel #tList .week-day-date-text,
#taskMode .list-panel #tList .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-status-text {
  flex: 0 0 auto;
}

#taskMode .list-panel #tList .week-day-overdue-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-overdue-text {
  flex: 0 0 auto;
}

#taskMode .list-panel #tList .week-day-overdue-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-overdue-count {
  display: inline-block;
  min-width: 2ch;
  color: inherit;
  font: inherit;
  font-variant-numeric: tabular-nums;
  text-align: left;
}

/* 本周日期指示条：跟随头部自身居中，避免单行标题下出现上下偏移。 */
#taskMode .list-panel #tList .week-day-card::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before {
  opacity: 0 !important;
}

#taskMode .list-panel #tList .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  width: 3px;
  height: 26px;
  border-radius: 999px;
  background: var(--week-accent);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-50%);
  transform-origin: center;
  transition: opacity .22s ease, background .22s ease;
}

#taskMode .list-panel #tList .week-day-card.is-focus .week-day-head::before,
#taskMode .list-panel #tList .week-day-card.is-today .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today .week-day-head::before {
  opacity: 0.62;
}

/* 本周任务框架指示条：淡底轨负责结构，短色轨负责状态。 */
#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
  --week-frame-rail: color-mix(in srgb, var(--week-line) 42%, transparent);
  --week-frame-accent: color-mix(in srgb, var(--week-accent) 62%, transparent);
  position: relative;
}

#taskMode .list-panel #tList .week-day-card.is-overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-overdue {
  --week-frame-accent: color-mix(in srgb, #ef4444 68%, transparent);
}

#taskMode .list-panel #tList .week-day-card.is-clear,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear {
  --week-frame-accent: color-mix(in srgb, #22c55e 46%, transparent);
}

#taskMode .list-panel #tList .week-day-card.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty {
  --week-frame-accent: color-mix(in srgb, var(--text3) 36%, transparent);
}

#taskMode .list-panel #tList .week-day-card::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 14px;
  bottom: 14px;
  width: 1px;
  height: auto;
  border-radius: 999px;
  background: var(--week-frame-rail);
  opacity: 1 !important;
  pointer-events: none;
  transform: none;
}

#taskMode .list-panel #tList .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head {
  position: relative;
}

#taskMode .list-panel #tList .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 50%;
  width: 3px;
  height: 30px;
  border-radius: 999px;
  background: var(--week-frame-accent);
  opacity: .7 !important;
  pointer-events: none;
  transform: translateY(-50%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--card) 82%, transparent);
}

#taskMode .list-panel #tList .week-day-card:not(.is-overdue):not(.is-focus):not(.is-today) .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card:not(.is-overdue):not(.is-focus):not(.is-today) .week-day-head::before {
  opacity: .48 !important;
}

/* 本周框架指示条优化：改为左侧内嵌柔性色带，避免双竖线的突兀感。 */
#taskMode .list-panel #tList .week-day-card::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  height: auto;
  border-radius: 18px 0 0 18px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--week-frame-accent) 82%, transparent) 0%,
    color-mix(in srgb, var(--week-frame-accent) 32%, transparent) 56%,
    color-mix(in srgb, var(--week-frame-accent) 10%, transparent) 100%
  );
  opacity: .34 !important;
  pointer-events: none;
  transform: none;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-day-card.is-overdue::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-overdue::before {
  opacity: .46 !important;
}

#taskMode .list-panel #tList .week-day-card.is-focus::before,
#taskMode .list-panel #tList .week-day-card.is-today::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today::before {
  opacity: .42 !important;
}

#taskMode .list-panel #tList .week-day-card.is-clear::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear::before {
  opacity: .28 !important;
}

#taskMode .list-panel #tList .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head::before {
  display: none !important;
}

/* 本周状态栏：改为日历刻度样式，状态压缩为小圆点。 */
#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  margin: 18px 0 18px;
  padding: 0 8px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pills,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  align-items: center;
  min-height: 104px;
  gap: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
  position: relative;
  justify-self: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  width: 64px;
  min-width: 0;
  height: 86px;
  min-height: 86px;
  padding: 11px 0 10px;
  border: 0;
  border-radius: 16px;
  background: transparent;
  box-shadow: none;
  color: color-mix(in srgb, var(--week-ink) 84%, var(--week-muted));
  transition: background .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

#taskMode .list-panel #tList .week-view-day-pill::before,
#taskMode .list-panel #tList .week-view-day-pill:hover::before,
#taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today::before {
  display: none !important;
}

#taskMode .list-panel #tList .week-view-day-pill:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill:hover {
  background: color-mix(in srgb, var(--week-line) 18%, transparent);
  box-shadow: none;
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-view-day-pill.is-today,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus {
  width: 56px;
  height: 96px;
  min-height: 96px;
  padding: 13px 0 12px;
  border-radius: 16px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--week-accent) 12%, #fff) 0%,
    color-mix(in srgb, var(--week-accent) 8%, #fff) 100%
  );
  color: color-mix(in srgb, var(--week-accent) 68%, var(--week-ink));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--week-accent) 16%, transparent),
    0 12px 24px -20px color-mix(in srgb, var(--week-accent) 34%, rgba(15, 23, 42, .18));
  transform: none;
}

#taskMode .list-panel #tList .week-view-day-pill-main,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-main {
  display: grid;
  justify-items: center;
  gap: 8px;
  min-width: 0;
}

#taskMode .list-panel #tList .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-name {
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
  font-size: 13px;
  font-weight: 560;
  line-height: 1;
  letter-spacing: 0;
}

#taskMode .list-panel #tList .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-date {
  color: var(--week-ink);
  font-size: 28px;
  font-weight: 760;
  line-height: .95;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-name,
#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-date {
  color: color-mix(in srgb, var(--week-accent) 78%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill-state--overdue,
#taskMode .list-panel #tList .week-view-day-pill-state--quiet,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--quiet {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 8px;
  height: 8px;
  min-height: 0;
  margin-top: 12px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
  color: #818cf8;
}

#taskMode .list-panel #tList .week-view-day-pill-state > *,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state > * {
  display: none !important;
}

#taskMode .list-panel #tList .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state::before {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
}

#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state {
  color: #fb7185;
}

#taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state {
  color: #34d399;
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state {
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state {
  color: #818cf8;
  opacity: 1;
}

/* 本周状态栏最终收紧：去掉外层背景框，保留轻量日期刻度。 */
#taskMode .list-panel #tList .week-view-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head,
#taskMode .list-panel #tList .week-view-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-head:hover {
  padding: 0 12px 2px;
  border: 0 !important;
  border-radius: 0;
  outline: 0;
  background: transparent !important;
  box-shadow: none !important;
  transform: none;
}

#taskMode .list-panel #tList .week-view-day-strip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-strip {
  margin: 4px 0 10px;
}

#taskMode .list-panel #tList .week-view-day-pills,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pills {
  --week-day-pill-track-height: 14px;
  --week-day-pill-circle-size: 32px;
  --week-day-pill-gap: 4px;
  --week-day-pill-height: 52px;
  min-height: 68px;
  padding: 0 4px;
}

#taskMode .list-panel #tList .week-view-day-pill,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill {
  width: 42px;
  height: var(--week-day-pill-height);
  min-height: var(--week-day-pill-height);
  padding: 4px 0 4px;
  border-radius: 12px;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus {
  width: 42px;
  height: var(--week-day-pill-height);
  min-height: var(--week-day-pill-height);
  padding: 4px 0 4px;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:hover,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus:hover {
  background: transparent;
  box-shadow: none;
  transform: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:active,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:active,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-focus:active {
  transform: none;
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today),
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) {
  width: 42px;
  height: var(--week-day-pill-height);
  min-height: var(--week-day-pill-height);
  padding: 4px 0 4px;
  border-radius: 12px;
  background: transparent;
  color: color-mix(in srgb, var(--week-ink) 84%, var(--week-muted));
  box-shadow: none;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today):hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today):hover {
  background: color-mix(in srgb, var(--week-line) 18%, transparent);
  box-shadow: none;
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .week-view-day-pill-main,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-main {
  gap: var(--week-day-pill-gap);
  grid-template-rows: var(--week-day-pill-track-height) var(--week-day-pill-circle-size);
  align-content: start;
  justify-items: center;
}

#taskMode .list-panel #tList .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-name {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--week-day-pill-track-height);
  min-height: var(--week-day-pill-track-height);
  font-size: 11px;
  line-height: 1;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-name {
  color: color-mix(in srgb, var(--week-accent) 88%, #6d7a95 12%);
  font-weight: 700;
  letter-spacing: 0.01em;
}

#taskMode .list-panel #tList .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-date {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--week-day-pill-circle-size);
  height: var(--week-day-pill-circle-size);
  margin: 0 auto;
  font-size: 20px;
  line-height: 1;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-date {
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--week-accent) 92%, #7b72ff 8%) 0%,
    color-mix(in srgb, var(--week-accent) 97%, #3f35d9 3%) 100%
  );
  color: #ffffff;
  box-shadow: 0 14px 22px -18px color-mix(in srgb, var(--week-accent) 52%, transparent);
  transition: transform .22s ease, box-shadow .22s ease;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today:hover .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today:hover .week-view-day-pill-date {
  transform: translateY(-1px);
  box-shadow: 0 18px 26px -20px color-mix(in srgb, var(--week-accent) 58%, transparent);
}

#taskMode .list-panel #tList .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill-state--overdue,
#taskMode .list-panel #tList .week-view-day-pill-state--quiet,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state--quiet {
  width: 5px;
  height: 5px;
  margin-top: 6px;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state--overdue,
#taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state--quiet,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today .week-view-day-pill-state--quiet {
  margin-top: 5px;
  color: color-mix(in srgb, var(--week-accent) 34%, #c7cfe0 66%);
}

#taskMode .list-panel #tList .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill-state::before {
  width: 5px;
  height: 5px;
}

/* 本周状态栏圆点只表达是否有任务，避免用颜色承载过多状态。 */
#taskMode .list-panel #tList .week-view-day-pill .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill .week-view-day-pill-state--overdue,
#taskMode .list-panel #tList .week-view-day-pill .week-view-day-pill-state--quiet,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill .week-view-day-pill-state--quiet {
  color: #aeb8c8;
  opacity: 0;
}

#taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state {
  opacity: 1;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today.has-pending .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-clear .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.has-pending .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-clear .week-view-day-pill-state {
  color: #818cf8;
  opacity: 1;
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus .week-view-day-pill-state {
  opacity: 0 !important;
}

/* 本周状态栏圆点最终覆盖：同等优先级压掉逾期红、完成绿，只保留有无任务。 */
#taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state {
  color: #aeb8c8 !important;
  opacity: 1 !important;
}

#taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state::before,
#taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state::before,
#taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.has-pending .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-overdue .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-clear .week-view-day-pill-state::before {
  background: #aeb8c8 !important;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today.has-pending .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-overdue .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-clear .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.has-pending .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-overdue .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-clear .week-view-day-pill-state {
  color: #818cf8 !important;
  opacity: 1 !important;
}

#taskMode .list-panel #tList .week-view-day-pill.is-today.has-pending .week-view-day-pill-state::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-overdue .week-view-day-pill-state::before,
#taskMode .list-panel #tList .week-view-day-pill.is-today.is-clear .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.has-pending .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-overdue .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-today.is-clear .week-view-day-pill-state::before {
  background: #818cf8 !important;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-name {
  color: color-mix(in srgb, var(--week-muted) 88%, var(--week-ink));
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-date {
  color: var(--week-ink);
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state,
#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state--overdue,
#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state--quiet,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state--quiet {
  color: #aeb8c8 !important;
  opacity: 1 !important;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today).is-empty .week-view-day-pill-state,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today).is-empty .week-view-day-pill-state {
  opacity: 0 !important;
}

#taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-focus:not(.is-today) .week-view-day-pill-state::before {
  background: currentColor !important;
}

#taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state::before,
#taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty .week-view-day-pill-state::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-view-day-pill.is-empty.is-focus .week-view-day-pill-state::before {
  background: transparent !important;
}

/* 任务卡片标题统一常规字重，降低列表视觉压力。 */
#taskMode .list-panel #tList .task-item .task-row-center > .txt-line,
#taskMode .list-panel #tList .task-item .task-row-center > .txt-line .txt,
#taskMode .list-panel #tList .task-item .task-row-center > .txt-line .txt-edit,
#taskMode .list-panel #tList .task-item.task-toggle-anim .task-row-center > .txt-line .txt,
#taskMode .list-panel #tList .task-item.task-main-checked .task-row-center > .txt-line .txt,
#taskMode .list-panel #tList .task-item.task-main-checked .task-row-center > .txt-line .txt-edit,
#taskMode .list-panel #tList .week-task-title,
#taskMode .list-panel #tList .week-task-title-text,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
#taskMode .list-panel #tList .week-task-item.is-done .week-task-title-text,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-row-center > .txt-line,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-row-center > .txt-line .txt,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-row-center > .txt-line .txt-edit,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-toggle-anim .task-row-center > .txt-line .txt,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-main-checked .task-row-center > .txt-line .txt,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item.task-main-checked .task-row-center > .txt-line .txt-edit,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-title-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item.is-done .week-task-title-text {
  font-weight: 400 !important;
}

/* 任务卡片下方元信息统一为清晰的蓝灰色。 */
#taskMode .list-panel #tList,
.app.app--with-global-nav #taskMode .list-panel #tList {
  --task-title-size-week: 15px;
  --task-meta-fg: #94a3b8;
  --task-time-muted: #94a3b8;
}

#taskMode .list-panel #tList .task-item .task-time-col,
#taskMode .list-panel #tList .task-item .task-time-col .time-plain,
#taskMode .list-panel #tList .task-item .task-time-col .time-disp,
#taskMode .list-panel #tList .task-item .task-time-col .task-time-sep,
#taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge,
#taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge *,
#taskMode .list-panel #tList .task-item .task-time-col svg,
#taskMode .list-panel #tList .week-task-meta,
#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge *,
#taskMode .list-panel #tList .week-task-sub-meta,
#taskMode .list-panel #tList .week-task-sub-meta *,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .time-plain,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .task-time-sep,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge *,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col svg,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge *,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta * {
  color: var(--task-meta-fg) !important;
}

#taskMode .list-panel #tList .task-item .task-time-col,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col {
  --task-time-rail: var(--task-meta-fg) !important;
}

#taskMode .list-panel #tList .task-item .task-time-col svg,
#taskMode .list-panel #tList .week-task-meta-row svg,
#taskMode .list-panel #tList .week-task-sub-meta svg,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col svg,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row svg,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta svg {
  stroke: var(--task-meta-fg) !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .time-plain.time-disp::before,
#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp::before,
#taskMode .list-panel #tList .week-task-sub-meta-dot,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .time-plain.time-disp::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta-dot {
  background: var(--task-meta-fg) !important;
  color: var(--task-meta-fg) !important;
  opacity: 1 !important;
}

#taskMode .list-panel #tList .task-row-center > .task-time-col .task-recur-badge-ico,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge-ico,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .task-recur-badge-ico,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge-ico {
  background: transparent !important;
  color: var(--task-meta-fg) !important;
  opacity: 1 !important;
}

/* 任务卡片下方的时间/重复/子任务信息统一字号与字重，避免同层级信息观感不一致。 */
#taskMode .list-panel #tList .task-item .task-time-col .time-plain.time-disp,
#taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge,
#taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge-txt,
#taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
#taskMode .list-panel #tList .week-task-meta-row .task-recur-badge-txt,
#taskMode .list-panel #tList .week-task-sub-meta,
#taskMode .list-panel #tList .week-task-sub-meta span,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .task-item .task-time-col .task-recur-badge-txt,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .time-plain.time-disp,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-meta-row .task-recur-badge-txt,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-sub-meta span {
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.25 !important;
  letter-spacing: 0 !important;
}

/* 周视图次级信息统一取消加粗，只保留主标题层级。 */
#taskMode .list-panel #tList .week-day-date,
#taskMode .list-panel #tList .week-day-date-label,
#taskMode .list-panel #tList .week-day-date-text,
#taskMode .list-panel #tList .week-day-status-text,
#taskMode .list-panel #tList .week-task-overdue-meta,
#taskMode .list-panel #tList .week-task-overdue-meta > span,
#taskMode .list-panel #tList .week-day-count-chip,
#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line,
#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line span,
#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-overdue-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-overdue-meta > span,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line span,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line b {
  font-weight: 400 !important;
}

/* 去掉本周卡片左侧指示条，并收回对应留白。 */
#taskMode .list-panel #tList .task-row-center > .task-time-col .week-task-overdue-meta,
#taskMode .list-panel #tList .task-row-center > .task-time-col .week-task-overdue-meta > span,
#taskMode .list-panel #tList .task-row-center > .task-time-col .week-task-overdue-meta svg,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .week-task-overdue-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .week-task-overdue-meta > span,
.app.app--with-global-nav #taskMode .list-panel #tList .task-row-center > .task-time-col .week-task-overdue-meta svg {
  color: #ef4444 !important;
  stroke: #ef4444 !important;
}

#taskMode .list-panel #tList .week-day-card::before,
#taskMode .list-panel #tList .week-day-head::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head::before {
  content: none !important;
  display: none !important;
  opacity: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#taskMode .list-panel #tList .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head {
  padding-left: 22px !important;
}

#taskMode .list-panel #tList .week-task-item,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item {
  padding-left: 22px !important;
}

#taskMode .list-panel #tList .week-task-item + .week-task-item::before,
.app.app--with-global-nav #taskMode .list-panel #tList .week-task-item + .week-task-item::before {
  left: 56px !important;
}

/* 本周卡片头部星期名称略微放大，增强日期组的第一视觉锚点。 */
#taskMode .list-panel #tList .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-week {
  font-size: 17px !important;
  line-height: 1.2 !important;
}

#taskMode .list-panel #tList .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  min-height: var(--week-day-shell-min-height, 56px) !important;
  padding-top: var(--week-day-shell-pad-y, 10px) !important;
  padding-bottom: var(--week-day-shell-pad-y, 10px) !important;
  box-sizing: border-box !important;
}

#taskMode .list-panel #tList .week-day-title-btn,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-title-btn {
  display: inline-flex !important;
  align-items: center !important;
  flex: 1 1 auto !important;
  gap: 10px !important;
  min-width: 0 !important;
  height: 24px !important;
  min-height: 24px !important;
  line-height: 1 !important;
  align-self: center !important;
}

#taskMode .list-panel #tList .week-day-name,
#taskMode .list-panel #tList .week-day-meta,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-name,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-meta {
  display: inline-flex !important;
  align-items: center !important;
  height: 24px !important;
  min-height: 24px !important;
  line-height: 1 !important;
}

#taskMode .list-panel #tList .week-day-week,
#taskMode .list-panel #tList .week-day-date-label,
#taskMode .list-panel #tList .week-day-date-text,
#taskMode .list-panel #tList .week-day-status-text,
#taskMode .list-panel #tList .week-day-overdue-text,
#taskMode .list-panel #tList .week-day-overdue-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-week,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-label,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-date-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-status-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-overdue-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-overdue-count {
  display: inline-flex !important;
  align-items: center !important;
  height: 24px !important;
  line-height: 1 !important;
}

#taskMode .list-panel #tList .week-day-count,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count,
#taskMode .list-panel #tList .week-day-count.week-day-count-group,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count.week-day-count-group {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex: 0 0 auto !important;
  gap: 10px !important;
  width: auto !important;
  min-width: 0 !important;
  height: 24px !important;
  min-height: 24px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1 !important;
  align-self: center !important;
}

#taskMode .list-panel #tList .week-day-count-chip,
#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 4px !important;
  width: auto !important;
  height: 24px !important;
  min-height: 24px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1 !important;
}

#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line span,
#taskMode .list-panel #tList .week-day-count-chip .week-day-count-line b,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line span,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip .week-day-count-line b {
  display: inline-flex !important;
  align-items: center !important;
  height: 24px !important;
  line-height: 1 !important;
}

#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy,
#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-copy-text,
#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-icon-wrap,
#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-icon,
#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-value,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-copy-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-icon-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-value {
  height: auto !important;
  min-height: 0 !important;
  align-self: center !important;
}

#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  line-height: 1.2 !important;
  align-self: center !important;
}

#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-copy-text,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-overdue-copy .week-overdue-copy-text {
  display: block !important;
  line-height: 1.2 !important;
}

#taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-value,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-line--overdue .week-day-count-value {
  display: inline-flex !important;
  align-items: center !important;
  line-height: 1.2 !important;
  transform: translateY(-0.5px);
}

#taskMode .list-panel #tList .week-day-count-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-caret {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transform: none !important;
}

#taskMode .list-panel #tList .week-day-count-chip.is-open .week-day-count-caret,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-count-chip.is-open .week-day-count-caret {
  transform: rotate(180deg) !important;
}

/* 本周卡片外框最终收口：
   1. 普通卡片统一使用真实 border，保证所有日期都稳定可见；
   2. 折叠态卡片只让 ::after 承担外框，避免与本体边框叠成双线。 */
#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
  border: 1px solid #d6daf8 !important;
  box-sizing: border-box;
  box-shadow: 0 8px 18px -24px rgba(15, 23, 42, .28) !important;
}

#taskMode .list-panel #tList .week-day-card:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card:hover {
  border-color: #d6daf8 !important;
  box-shadow: 0 8px 18px -24px rgba(15, 23, 42, .28) !important;
}

#taskMode .list-panel #tList .week-day-card.is-focus,
#taskMode .list-panel #tList .week-day-card.is-today,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-focus,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-today {
  border-color: #d6daf8 !important;
  box-shadow: 0 10px 22px -28px color-mix(in srgb, var(--week-accent) 28%, transparent) !important;
}

/* 本周折叠状态：只收窄可见背景层，不移动内部文字和右侧状态。 */
#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open),
#taskMode .list-panel #tList .week-day-card.is-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open),
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty {
  /* 折叠态的卡片外框统一交给 ::after 负责，避免本体框线和伪层框线叠成双线。 */
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open)::after,
#taskMode .list-panel #tList .week-day-card.is-empty::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open)::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: var(--week-day-shell-radius, 16px);
  border: 1px solid #d6daf8 !important;
  background: color-mix(in srgb, var(--card) 98%, #f8fafc);
  box-shadow: 0 8px 18px -24px rgba(15, 23, 42, .28);
  pointer-events: none;
  box-sizing: border-box;
}

#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
#taskMode .list-panel #tList .week-day-card.is-empty .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open) .week-day-head,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty .week-day-head {
  position: relative !important;
  z-index: 1;
}

#taskMode .list-panel #tList .week-day-card,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card {
  --week-day-head-attention-bg: #eef4ff;
  /* 统一展开头部与折叠行的可见框体尺寸，避免已完成折叠行被单独缩小。 */
  --week-day-shell-radius: 16px;
  --week-day-shell-min-height: 56px;
  --week-day-shell-pad-y: 10px;
}

/* 本周日期头部的悬浮与点击高亮共用同一层浅蓝底，保持内容尺寸和位置不变。 */
#taskMode .list-panel #tList .week-day-head:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head:hover {
  background: var(--week-day-head-attention-bg) !important;
}

#taskMode .list-panel #tList .week-day-head > :not(.week-day-head-breath),
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head > :not(.week-day-head-breath) {
  position: relative;
  z-index: 1;
}

#taskMode .list-panel #tList .week-day-head-breath,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-head-breath {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  border-radius: inherit;
  background: var(--week-day-head-attention-bg);
  opacity: 0;
  will-change: opacity;
}

#taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open):hover::after,
#taskMode .list-panel #tList .week-day-card.is-empty:hover::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-clear:not(.is-done-open):hover::after,
.app.app--with-global-nav #taskMode .list-panel #tList .week-day-card.is-empty:hover::after {
  background: var(--week-day-head-attention-bg) !important;
}

/* Overdue scene */
#taskMode .list-panel #tList .overdue-scene,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-scene {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 2px 0 0;
}

#taskMode .list-panel #tList .overdue-task-table-wrap,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-table-wrap {
  --overdue-head-size: 14px;
  --overdue-head-color: color-mix(in srgb, var(--text) 78%, #27324a);
  --overdue-head-accent: #f43f5e;
  --overdue-head-tracking: .012em;
  --overdue-detail-size: 12px;
  --overdue-sort-icon-size: 14px;
  --overdue-sort-icon-block-size: calc(var(--overdue-head-size) - 1px);
  --overdue-sort-optical-offset-y: -.5px;
  --overdue-sort-group-shift: calc((var(--overdue-sort-icon-size) + .02rem) / 2);
  --overdue-sort-hover-bg: #fef2f2;
  --overdue-sort-hover-radius: 6px;
  --overdue-sort-hover-shadow:
    inset 0 0 0 1px color-mix(in srgb, #f43f5e 8%, transparent),
    0 10px 22px color-mix(in srgb, #f43f5e 6%, transparent);
  --overdue-meta-slot-width: 4.6rem;
  --overdue-title-row-pad-inline-end: 14px;
  --overdue-head-border: color-mix(in srgb, var(--task-bd) 82%, #dce4ef);
  --overdue-title-indent: calc(2.35rem + 2px);
  --overdue-action-col-width: 7.4rem;
  --overdue-action-pad-inline: 1rem;
  --overdue-action-reveal-offset: 6px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--task-bd) 62%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--card) 99%, #ffffff);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #ffffff 72%, transparent),
    0 14px 28px color-mix(in srgb, var(--task-bd) 8%, transparent);
}

#taskMode .list-panel #tList .overdue-task-table-wrap--single,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-table-wrap--single {
  animation: overdueSoftRise .32s cubic-bezier(.22, 1, .36, 1);
}

#taskMode .list-panel #tList .overdue-task-table,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-table {
  width: 100%;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

#taskMode .list-panel #tList .overdue-task-head,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head {
  position: relative;
  padding: 13px 18px;
  border-bottom: 1px solid var(--overdue-head-border);
  background: transparent;
  color: var(--overdue-head-color);
  font-size: var(--overdue-head-size);
  line-height: 1.22;
  font-weight: 620;
  letter-spacing: var(--overdue-head-tracking);
  text-align: left;
  text-shadow: none;
  vertical-align: middle;
}

#taskMode .list-panel #tList .overdue-task-head--status,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head--status {
  width: 14.5rem;
  text-align: left;
}

#taskMode .list-panel #tList .overdue-task-cell--status,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-cell--status {
  text-align: left;
}

#taskMode .list-panel #tList .overdue-task-head--action,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head--action {
  width: var(--overdue-action-col-width);
  padding-inline: var(--overdue-action-pad-inline);
  text-align: center;
}

#taskMode .list-panel #tList .overdue-task-head-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip {
  display: inline-flex;
  align-items: center;
  gap: .34rem;
  max-width: 100%;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  transition:
    color .18s ease,
    opacity .22s ease,
    transform .18s ease;
  white-space: nowrap;
  overflow: hidden;
}

#taskMode .list-panel #tList .overdue-task-head-chip::before,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip::before {
  content: none;
}

#taskMode .list-panel #tList .overdue-task-head-group,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-group {
  display: grid;
  align-items: center;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .9rem;
  width: 100%;
  min-width: 0;
}

#taskMode .list-panel #tList .overdue-task-head-group--title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-group--title {
  grid-template-columns: minmax(0, 1fr) var(--overdue-meta-slot-width);
}

#taskMode .list-panel #tList .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip-label {
  display: inline-block;
  min-width: 0;
  color: var(--overdue-head-color);
  font-size: inherit;
  line-height: 1.08;
  font-weight: 600;
  letter-spacing: .012em;
}

#taskMode .list-panel #tList .overdue-task-head-chip--title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--title {
  margin-inline-end: auto;
  padding-inline-start: var(--overdue-title-indent);
}

#taskMode .list-panel #tList .overdue-task-head-chip--title .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--title .overdue-task-head-chip-label {
  font-size: inherit;
  font-weight: 640;
  letter-spacing: .008em;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue {
  position: relative;
  justify-self: end;
  inline-size: var(--overdue-meta-slot-width);
  inset-inline-end: var(--overdue-title-row-pad-inline-end);
  justify-content: center;
  gap: .08rem;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue .overdue-task-head-chip-label {
  color: var(--overdue-head-accent);
}

#taskMode .list-panel #tList .overdue-task-head-anchor,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-anchor {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

#taskMode .list-panel #tList .overdue-task-head-chip--status,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--status {
  justify-self: start;
}

#taskMode .list-panel #tList .overdue-task-head-chip--action,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--action {
  margin-inline-start: auto;
  padding-inline: 0;
}

#taskMode .list-panel #tList .overdue-task-head-chip--interactive,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive {
  position: relative;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  margin-inline: -.34rem;
  padding: .22rem .34rem;
  border-radius: 999px;
  font: inherit;
  transition:
    background-color .18s ease,
    box-shadow .18s ease,
    transform .14s ease;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive {
  margin-inline: 0;
  padding: .4rem .56rem;
  border-radius: var(--overdue-sort-hover-radius);
  isolation: isolate;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive::after,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: var(--overdue-sort-hover-radius);
  background: var(--overdue-sort-hover-bg);
  box-shadow: var(--overdue-sort-hover-shadow);
  opacity: 0;
  pointer-events: none;
  transform: translateX(var(--overdue-sort-group-shift));
  transition:
    opacity .18s ease,
    box-shadow .18s ease;
}

#taskMode .list-panel #tList .overdue-task-head-spacer,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-spacer {
  display: block;
  width: 100%;
  min-height: .95rem;
}

#taskMode .list-panel #tList .overdue-task-head-sort,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-sort {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: var(--overdue-sort-icon-size);
  height: var(--overdue-sort-icon-block-size);
  color: color-mix(in srgb, var(--text2) 72%, #6f7d96);
  opacity: 1;
}

#taskMode .list-panel #tList .overdue-task-head-sort svg,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-sort svg {
  display: block;
  width: var(--overdue-sort-icon-size);
  height: var(--overdue-sort-icon-block-size);
  stroke-width: 1.42;
  transform-origin: 50% 50%;
  transform-box: view-box;
  transition: transform .22s cubic-bezier(.22, 1, .36, 1);
}

#taskMode .list-panel #tList .overdue-task-head-sort--desc svg,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-sort--desc svg {
  transform: rotate(180deg);
}

#taskMode .list-panel #tList .overdue-task-head-sort--anim-to-desc svg,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-sort--anim-to-desc svg {
  animation: overdueHeadSortSpinToDesc .22s cubic-bezier(.22, 1, .36, 1) both;
}

#taskMode .list-panel #tList .overdue-task-head-sort--anim-to-asc svg,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-sort--anim-to-asc svg {
  animation: overdueHeadSortSpinToAsc .22s cubic-bezier(.22, 1, .36, 1) both;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue .overdue-task-head-sort,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue .overdue-task-head-sort {
  position: absolute;
  inset-inline-start: calc(100% + .02rem);
  inset-block-start: auto;
  inset-block-end: 0;
  color: var(--overdue-head-accent);
  margin-inline-start: 0;
  opacity: .92;
  pointer-events: none;
  transform: translateY(var(--overdue-sort-optical-offset-y));
  transition:
    color .18s ease,
    opacity .18s ease;
}

#taskMode .list-panel #tList .overdue-task-head:hover .overdue-task-head-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head:hover .overdue-task-head-chip,
#taskMode .list-panel #tList .overdue-task-head:focus-within .overdue-task-head-chip,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head:focus-within .overdue-task-head-chip {
  opacity: 1;
}

#taskMode .list-panel #tList .overdue-task-head-chip--interactive:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:hover,
#taskMode .list-panel #tList .overdue-task-head-chip--interactive:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

#taskMode .list-panel #tList .overdue-task-head-chip--interactive:hover .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:hover .overdue-task-head-chip-label,
#taskMode .list-panel #tList .overdue-task-head-chip--interactive:focus-visible .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:focus-visible .overdue-task-head-chip-label {
  color: color-mix(in srgb, var(--overdue-head-color) 84%, #49566c);
}

#taskMode .list-panel #tList .overdue-task-head-chip--interactive:hover .overdue-task-head-sort,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:hover .overdue-task-head-sort,
#taskMode .list-panel #tList .overdue-task-head-chip--interactive:focus-visible .overdue-task-head-sort,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:focus-visible .overdue-task-head-sort {
  color: color-mix(in srgb, var(--overdue-head-color) 86%, #4b5568);
  opacity: 1;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover,
#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible {
  background: transparent;
  border-radius: var(--overdue-sort-hover-radius);
  box-shadow: none;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover::after,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover::after,
#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible::after,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible::after {
  opacity: 1;
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover .overdue-task-head-chip-label,
#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible .overdue-task-head-chip-label,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible .overdue-task-head-chip-label {
  color: var(--overdue-head-accent);
}

#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover .overdue-task-head-sort,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:hover .overdue-task-head-sort,
#taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible .overdue-task-head-sort,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--overdue.overdue-task-head-chip--interactive:focus-visible .overdue-task-head-sort {
  color: var(--overdue-head-accent);
  opacity: .92;
}

#taskMode .list-panel #tList .overdue-task-head-chip--interactive:active,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive:active {
  transform: translateY(.5px);
}

@keyframes overdueHeadSortSpinToDesc {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(180deg);
  }
}

@keyframes overdueHeadSortSpinToAsc {
  from {
    transform: rotate(180deg);
  }

  to {
    transform: rotate(0deg);
  }
}

#taskMode .list-panel #tList .overdue-task-row,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row {
  transition: background .18s ease;
}

#taskMode .list-panel #tList .overdue-task-cell,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-cell {
  min-width: 0;
  padding: 12px 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--task-bd) 42%, transparent);
  background: color-mix(in srgb, var(--card) 99%, #ffffff);
  vertical-align: middle;
  transition:
    background .18s ease,
    border-color .18s ease;
}

#taskMode .list-panel #tList .overdue-task-row:hover .overdue-task-cell,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:hover .overdue-task-cell {
  background: #f9fafb;
  border-bottom-color: color-mix(in srgb, var(--task-bd) 42%, transparent);
}

#taskMode .list-panel #tList .overdue-task-row:last-child .overdue-task-cell,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:last-child .overdue-task-cell {
  border-bottom: 0;
}

#taskMode .list-panel #tList .overdue-task-row:last-child .overdue-task-cell--title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:last-child .overdue-task-cell--title {
  border-bottom-left-radius: 18px;
}

#taskMode .list-panel #tList .overdue-task-row:last-child .overdue-task-cell--action,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:last-child .overdue-task-cell--action {
  border-bottom-right-radius: 18px;
}

#taskMode .list-panel #tList .overdue-task-cell--action,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-cell--action {
  width: var(--overdue-action-col-width);
  padding-inline: var(--overdue-action-pad-inline);
  text-align: center;
  white-space: nowrap;
}

#taskMode .list-panel #tList .overdue-task-title-row,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-title-row {
  display: grid;
  align-items: center;
  grid-template-columns: minmax(0, 1fr) var(--overdue-meta-slot-width);
  gap: 0;
  min-width: 0;
  width: 100%;
  padding: 6px var(--overdue-title-row-pad-inline-end) 6px 6px;
}

#taskMode .list-panel #tList .overdue-task-open,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open {
  width: auto;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  justify-self: start;
  gap: 9px;
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform .2s cubic-bezier(.22, 1, .36, 1);
}

#taskMode .list-panel #tList .overdue-task-open:focus-visible,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:focus-visible {
  outline: none;
}

#taskMode .list-panel #tList .overdue-task-open:active,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:active {
  transform: translateY(.5px);
}

#taskMode .list-panel #tList .overdue-task-copy-stack,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-copy-stack {
  min-width: 0;
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-self: center;
  justify-content: center;
  gap: 0;
}

#taskMode .list-panel #tList .overdue-task-priority-ring,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-priority-ring {
  position: relative;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  min-width: 20px;
  inset-block-start: -.5px;
  pointer-events: none;
}

#taskMode .list-panel #tList .overdue-task-priority-ring .tc-check,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-priority-ring .tc-check {
  width: 20px;
  min-width: 20px;
  height: 20px;
  min-height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#taskMode .list-panel #tList .overdue-task-priority-ring .chk-ring,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-priority-ring .chk-ring {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  border-width: 1.35px;
  pointer-events: none;
  transition:
    transform .18s ease,
    border-color .18s ease,
    background .18s ease,
    box-shadow .18s ease;
}

#taskMode .list-panel #tList .overdue-task-priority-ring.task-ck-ring--prio-high .chk-ring,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-priority-ring.task-ck-ring--prio-high .chk-ring {
  border-width: 1.55px;
}

#taskMode .list-panel #tList .overdue-task-priority-ring .chk-ring-ico,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-priority-ring .chk-ring-ico {
  display: none;
}

#taskMode .list-panel #tList .overdue-task-row:hover .overdue-task-priority-ring .chk-ring,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:hover .overdue-task-priority-ring .chk-ring {
  transform: scale(1.04);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--ck-prio, #94a3b8) 8%, transparent);
}

#taskMode .list-panel #tList .overdue-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-title {
  display: -webkit-box;
  min-width: 0;
  color: #191a2d;
  font-size: var(--task-title-size-week);
  line-height: 1.3;
  font-weight: 430;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  transition:
    color .18s ease,
    opacity .18s ease;
}

#taskMode .list-panel #tList .overdue-task-open:hover .overdue-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:hover .overdue-task-title,
#taskMode .list-panel #tList .overdue-task-open:focus-visible .overdue-task-title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:focus-visible .overdue-task-title {
  color: color-mix(in srgb, #191a2d 88%, #0f172a);
}

#taskMode .list-panel #tList .overdue-task-age,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-age {
  --overdue-age-pill-pad-inline: .52rem;
  --overdue-age-pill-pad-block: .14rem;
  --overdue-age-pill-radius: 999px;
  --overdue-age-pill-bg:
    linear-gradient(180deg, color-mix(in srgb, #ffffff 82%, var(--overdue-text-color) 5%) 0%, color-mix(in srgb, #fff5f7 84%, var(--overdue-text-color) 11%) 100%);
  --overdue-age-pill-border: color-mix(in srgb, var(--overdue-text-color) 14%, rgba(255, 255, 255, 0));
  --overdue-age-pill-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .82),
    0 8px 18px color-mix(in srgb, var(--overdue-text-color) 9%, transparent);
  --overdue-age-pill-hover-bg:
    linear-gradient(180deg, color-mix(in srgb, #ffffff 78%, var(--overdue-text-color) 8%) 0%, color-mix(in srgb, #fff3f6 78%, var(--overdue-text-color) 15%) 100%);
  --overdue-age-pill-hover-border: color-mix(in srgb, var(--overdue-text-color) 20%, rgba(255, 255, 255, 0));
  --overdue-age-pill-hover-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .88),
    0 10px 22px color-mix(in srgb, var(--overdue-text-color) 12%, transparent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  min-width: 0;
  flex-shrink: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--overdue-text-color);
  font-size: var(--overdue-detail-size);
  line-height: 1;
  font-weight: 500;
  letter-spacing: .005em;
  white-space: nowrap;
  box-shadow: none;
  pointer-events: none;
}

#taskMode .list-panel #tList .overdue-task-age--title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-age--title {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: var(--overdue-meta-slot-width);
  justify-self: center;
  margin-inline-start: 0;
}

#taskMode .list-panel #tList .overdue-task-age-kicker,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-age-kicker {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

#taskMode .list-panel #tList .overdue-task-age-value,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-age-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 1.3rem;
  padding: var(--overdue-age-pill-pad-block) var(--overdue-age-pill-pad-inline);
  border: 1px solid var(--overdue-age-pill-border);
  border-radius: var(--overdue-age-pill-radius);
  background: var(--overdue-age-pill-bg);
  box-shadow: var(--overdue-age-pill-shadow);
  color: color-mix(in srgb, var(--overdue-text-color) 88%, var(--text));
  font-size: inherit;
  line-height: 1;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
  transition:
    color .18s ease,
    background-color .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    opacity .18s ease,
    transform .18s ease;
}

#taskMode .list-panel #tList .overdue-task-open:hover .overdue-task-age-value,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:hover .overdue-task-age-value,
#taskMode .list-panel #tList .overdue-task-open:focus-visible .overdue-task-age-value,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:focus-visible .overdue-task-age-value {
  background: var(--overdue-age-pill-hover-bg);
  border-color: var(--overdue-age-pill-hover-border);
  box-shadow: var(--overdue-age-pill-hover-shadow);
  color: color-mix(in srgb, var(--overdue-text-color) 94%, var(--text));
  opacity: .96;
  transform: translateY(-1px);
}

#taskMode .list-panel #tList .overdue-task-open:active .overdue-task-age-value,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open:active .overdue-task-age-value {
  transform: scale(.972);
}

#taskMode .list-panel #tList .overdue-task-status-stack,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  min-width: 0;
  padding-block: 3px;
  text-align: left;
}

#taskMode .list-panel #tList .overdue-task-status-stack,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-stack,
#taskMode .list-panel #tList .overdue-task-status-meta-row,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-meta-row {
  width: 100%;
  margin-inline: 0;
}

#taskMode .list-panel #tList .overdue-task-status-date,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-date {
  color: var(--text2);
  font-size: var(--overdue-detail-size);
  line-height: 1.32;
  font-weight: 430;
  font-variant-numeric: tabular-nums;
  text-align: left;
  white-space: nowrap;
}

#taskMode .list-panel #tList .overdue-task-status-meta-row,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-meta-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 5px;
  min-width: 0;
  flex-wrap: wrap;
  width: 100%;
}

#taskMode .list-panel #tList .overdue-task-time-main,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-time-main {
  color: color-mix(in srgb, var(--text2) 70%, var(--text3));
  font-size: var(--overdue-detail-size);
  line-height: 1.32;
  font-weight: 430;
  font-variant-numeric: tabular-nums;
  text-align: left;
  white-space: nowrap;
}

#taskMode .list-panel #tList .overdue-task-status-sub-sep,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-sub-sep {
  width: 2px;
  height: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text2) 28%, transparent);
  opacity: .9;
  flex-shrink: 0;
}

#taskMode .list-panel #tList .overdue-task-time-sub,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-time-sub {
  color: color-mix(in srgb, var(--text2) 60%, var(--text3));
  font-size: var(--overdue-detail-size);
  line-height: 1.25;
  font-weight: 430;
}

#taskMode .list-panel #tList .overdue-task-dismiss,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-dismiss {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  min-width: 64px;
  height: 31px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--task-bd) 74%, transparent);
  background: color-mix(in srgb, var(--card) 96%, #fff7f8);
  color: var(--text2);
  font-size: .76rem;
  font-weight: 650;
  cursor: pointer;
  box-shadow: none;
  transition:
    color .18s ease,
    background .18s ease,
    border-color .18s ease,
    transform .14s ease;
}

#taskMode .list-panel #tList .overdue-task-dismiss:hover,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-dismiss:hover {
  color: var(--overdue-text-color);
  border-color: color-mix(in srgb, var(--overdue-text-color) 16%, #ffd7df);
  background: color-mix(in srgb, var(--overdue-text-color) 5%, var(--card));
  transform: translateY(-1px);
  box-shadow: 0 8px 14px color-mix(in srgb, var(--task-bd) 9%, transparent);
}

#taskMode .list-panel #tList .overdue-task-dismiss:active,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-dismiss:active {
  transform: scale(.985);
}

@media (hover:hover) and (pointer:fine) {
  #taskMode .list-panel #tList .overdue-task-row .overdue-task-dismiss,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row .overdue-task-dismiss {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateX(var(--overdue-action-reveal-offset)) scale(.98);
  }

  #taskMode .list-panel #tList .overdue-task-row:hover .overdue-task-dismiss,
  #taskMode .list-panel #tList .overdue-task-row:focus-within .overdue-task-dismiss,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:hover .overdue-task-dismiss,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row:focus-within .overdue-task-dismiss {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(0) scale(1);
  }
}

#taskMode .list-panel #tList .overdue-empty,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 320px;
  padding: 24px 16px;
  border: 1px dashed color-mix(in srgb, var(--task-bd) 70%, transparent);
  border-radius: 16px;
  background: transparent;
  text-align: center;
}

#taskMode .list-panel #tList .overdue-empty-icon,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-empty-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: color-mix(in srgb, #22c55e 10%, #fff);
  color: #16a34a;
  font-size: 1rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .08em;
}

#taskMode .list-panel #tList .overdue-empty-icon--soft,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-empty-icon--soft {
  background: color-mix(in srgb, var(--task-bd) 34%, #fff);
  color: var(--text2);
}

#taskMode .list-panel #tList .overdue-empty-title,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-empty-title {
  margin: 16px 0 0;
  color: var(--text);
  font-size: 1.02rem;
  line-height: 1.35;
  font-weight: 700;
}

#taskMode .list-panel #tList .overdue-empty-sub,
.app.app--with-global-nav #taskMode .list-panel #tList .overdue-empty-sub {
  margin: 8px 0 0;
  color: var(--text3);
  font-size: .86rem;
  line-height: 1.65;
}

@keyframes overdueSoftRise {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  #taskMode .list-panel #tList .overdue-task-table-wrap--single,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-table-wrap--single {
    animation: none;
  }

  #taskMode .list-panel #tList .overdue-task-status-stack,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-status-stack,
  #taskMode .list-panel #tList .overdue-task-row,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-row,
  #taskMode .list-panel #tList .overdue-task-open,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-open,
  #taskMode .list-panel #tList .overdue-task-title-row,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-title-row,
  #taskMode .list-panel #tList .overdue-task-head-chip,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip,
  #taskMode .list-panel #tList .overdue-task-head-chip::before,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip::before,
  #taskMode .list-panel #tList .overdue-task-title,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-title,
  #taskMode .list-panel #tList .overdue-task-age-value,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-age-value,
  #taskMode .list-panel #tList .overdue-task-priority-ring .chk-ring,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-priority-ring .chk-ring,
  #taskMode .list-panel #tList .overdue-task-dismiss,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-dismiss {
    transition: none;
  }
}

@media (max-width: 860px) {
  #taskMode .list-panel #tList .overdue-task-table-wrap,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-table-wrap {
    --overdue-action-col-width: 6.7rem;
    --overdue-action-pad-inline: .75rem;
    border-radius: 18px;
    overflow-x: auto;
  }

  #taskMode .list-panel #tList .overdue-task-table,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-table {
    min-width: 31rem;
  }

  #taskMode .list-panel #tList .overdue-task-head,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head,
  #taskMode .list-panel #tList .overdue-task-cell,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-cell {
    padding: 11px 14px;
  }

  #taskMode .list-panel #tList .overdue-task-head-chip,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip {
    gap: .28rem;
    padding: 0;
  }

  #taskMode .list-panel #tList .overdue-task-head-group,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-group {
    gap: .46rem;
  }

  #taskMode .list-panel #tList .overdue-task-head-chip-label,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip-label {
    font-size: inherit;
    letter-spacing: .015em;
  }

  #taskMode .list-panel #tList .overdue-task-head-chip--title,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--title {
    padding-inline-start: 2rem;
  }

  #taskMode .list-panel #tList .overdue-task-head-chip--title .overdue-task-head-chip-label,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--title .overdue-task-head-chip-label {
    font-size: inherit;
  }

  #taskMode .list-panel #tList .overdue-task-head-chip--interactive,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head-chip--interactive {
    margin-inline: -.26rem;
    padding: .18rem .26rem;
  }

  #taskMode .list-panel #tList .overdue-task-head--status,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-head--status {
    width: 13.5rem;
  }

  #taskMode .list-panel #tList .overdue-task-dismiss,
  .app.app--with-global-nav #taskMode .list-panel #tList .overdue-task-dismiss {
    min-width: 66px;
  }
}
