/* ============================================
   tasks.css — 할일 탭 전용 스타일
   (색·간격 등은 variables.css 의 var() 만 사용)
   ============================================ */

#panel-tasks {
  padding-top: calc(var(--safe-top) + var(--tab-title-pad-before));
  padding-bottom: calc(
    var(--tab-bar-height) + var(--safe-bottom) + var(--space-8) + 56px
  );
  overflow-x: hidden;
  max-width: 100%;
}

/* 할일 완료: 취소선 없음 (쇼핑 구매완료 취소선은 components.css 유지) */
#panel-tasks .task-item.is-completed .list-item__title,
#panel-tasks .task-item.is-completed .list-item__title-text {
  text-decoration: none;
}

.tasks-view[hidden] {
  display: none !important;
}

/* ---------- 오늘 할 일 카드 (브랜드 #C96442) ---------- */
.tasks-today.card {
  margin-bottom: var(--space-4);
  padding: 0;
  overflow: hidden;
  background: var(--color-today-bg);
  color: var(--color-today-text);
  border-color: var(--color-today-border);
}

.tasks-today__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-4);
  font-weight: var(--font-bold);
  font-size: var(--text-lg);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  color: var(--color-today-text);
}

.tasks-today__label {
  color: var(--color-today-text);
}

.tasks-today__label .lucide-icon {
  color: var(--color-today-text);
}

.tasks-today__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.tasks-today .icon-chevron-pair {
  color: var(--color-today-text-muted);
}

.tasks-today__body {
  padding: 0 var(--space-4) var(--space-4);
}

.tasks-today__body .list-group {
  margin-top: var(--space-1);
  gap: 0;
}

.tasks-today:not(.is-open) .tasks-today__body {
  display: none;
}

.tasks-today .tasks-empty--inline {
  color: var(--color-today-text-muted);
}

.tasks-today .swipe-wrapper,
.tasks-today .subscription-list-item {
  margin-bottom: var(--space-2);
  border-radius: 8px;
}

.tasks-today .swipe-wrapper:last-child,
.tasks-today .subscription-list-item:last-child {
  margin-bottom: 0;
}

.tasks-today .swipe-content > .list-item,
.tasks-today .task-item--subscription {
  background: rgba(255, 255, 255, 0.14);
  border-color: transparent;
  border-radius: 8px;
  padding: 12px 14px;
  color: var(--color-today-text);
}

.tasks-today .task-item--subscription:active {
  background: rgba(255, 255, 255, 0.2);
}

.tasks-today .list-item__title,
.tasks-today .list-item__title-text,
.tasks-today .task-item__title-text {
  color: var(--color-today-text);
}

.tasks-today .list-item__title:focus,
.tasks-today .list-item__title:focus-visible {
  outline: none;
  border-color: var(--color-today-text);
  background: color-mix(in srgb, var(--color-today-text) 14%, transparent);
}

.tasks-today .list-item.is-completed .list-item__title,
.tasks-today .list-item.is-completed .list-item__title-text {
  color: var(--color-today-text-muted);
}

.tasks-today .list-item__dday,
.tasks-today .task-item__dday,
.tasks-today .list-item__dday--urgent,
.tasks-today .list-item__dday--warning,
.tasks-today .list-item__dday--neutral {
  display: inline-flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: var(--text-13);
  font-weight: var(--font-medium);
}

.tasks-today .task-item__chevron {
  color: var(--color-today-text-muted);
}

.tasks-today .task-item__sub-brand-label {
  color: var(--color-today-text);
}

.tasks-today .task-item__sub-desc {
  color: var(--color-today-text-muted);
}

.tasks-today .task-item__sub-brand-icon,
.tasks-today .task-item__sub-brand-icon .lucide-icon {
  color: var(--color-today-text);
}

.tasks-today .task-item__star {
  color: color-mix(in srgb, var(--color-today-text) 38%, transparent);
}

.tasks-today .task-item__star.is-filled,
.tasks-today .task-item__star.is-filled svg {
  color: #ffe08a;
  fill: #ffe08a;
  stroke: #ffe08a;
}

.tasks-today .checkbox--square {
  background-color: color-mix(in srgb, var(--color-today-text) 12%, transparent);
  border-color: color-mix(in srgb, var(--color-today-text) 55%, transparent);
}

.tasks-today .checkbox--square:checked {
  background-color: var(--color-today-text);
  border-color: var(--color-today-text);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.25 6.1 4.65 8.5 9.75 3.4' fill='none' stroke='%23c96442' stroke-width='1.85' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* ---------- 상단 인사 ---------- */
.tasks-greeting {
  margin: 0 0 var(--space-5);
  padding-top: var(--tab-title-pad-after);
  font-size: var(--text-greeting);
  font-weight: var(--font-bold);
  line-height: var(--line-height-relaxed);
  color: var(--color-text);
  word-break: keep-all;
  overflow-wrap: break-word;
}

.tasks-greeting:has(.tasks-greeting__lead) {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 0;
  row-gap: 0.15em;
}

.tasks-greeting__lead {
  flex-shrink: 0;
}

.tasks-greeting__phrase {
  flex: 1 1 auto;
  min-width: min(100%, 8em);
}

/* ---------- D-7 / D-30 / 30+ 아코디언 ---------- */
.tasks-sections {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: var(--space-2);
}

.tasks-section {
  --tasks-acc-active: #c96442;
}

.tasks-section[data-section="urgent"] {
  --tasks-acc-active: #c96442;
}

.tasks-section[data-section="later"] {
  --tasks-acc-active: #378add;
}

.tasks-section[data-section="none"] {
  --tasks-acc-active: #5f5e5a;
}

.tasks-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: calc(14px + var(--space-2)) var(--space-3);
  border: none;
  background: transparent;
  font: inherit;
  text-align: left;
  cursor: pointer;
  color: var(--tasks-acc-muted);
  -webkit-tap-highlight-color: transparent;
  transition: color 0.2s ease;
}

.tasks-section__label.label-with-icon {
  flex: 1;
  min-width: 0;
  gap: 10px;
  color: inherit;
}

.tasks-section__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: inherit;
}

.tasks-section__icon .lucide-icon,
.tasks-section__icon .lucide-icon svg {
  color: inherit;
  stroke: currentColor;
}

.tasks-section__head .label-with-icon__text {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.2;
  color: inherit;
}

.tasks-section__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: inherit;
  transition:
    transform 0.25s ease,
    color 0.2s ease;
}

.tasks-section__chevron .lucide-icon,
.tasks-section__chevron .lucide-icon svg {
  width: 22px;
  height: 22px;
  color: inherit;
  stroke: currentColor;
}

.tasks-section[data-open="true"] .tasks-section__head {
  color: var(--tasks-acc-active);
}

.tasks-section[data-open="true"] .tasks-section__chevron {
  transform: rotate(180deg);
}

.tasks-section__body {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.25s ease;
}

.tasks-section__body > .list-group {
  margin: 0;
  padding: 0;
  gap: 0;
}

/* 쇼핑 .shop-group__title 하단선과 동일: 전체 너비 + --color-border */
.tasks-section__divider {
  box-sizing: border-box;
  width: calc(100% + 2 * var(--space-4));
  margin-left: calc(-1 * var(--space-4));
  margin-right: calc(-1 * var(--space-4));
  margin-top: 0;
  margin-bottom: 0;
  height: 0;
  border: none;
  border-bottom: var(--border-width) solid var(--color-border);
  background: transparent;
}

/* 열림: row 카드 + D-day 칩 */
.tasks-section[data-open="true"] .swipe-wrapper,
.tasks-section[data-open="true"] .subscription-list-item {
  margin-bottom: 6px;
}

.tasks-section[data-open="true"] .swipe-wrapper:last-child,
.tasks-section[data-open="true"] .subscription-list-item:last-child {
  margin-bottom: 0;
}

.tasks-section[data-open="true"] .swipe-content > .list-item,
.tasks-section[data-open="true"] .task-item--subscription {
  background: var(--tasks-acc-row-bg);
  border: 0.5px solid var(--tasks-acc-row-border);
  border-radius: 8px;
  padding: 12px 14px;
  min-height: 0;
  box-shadow: none;
}

.tasks-section[data-section="urgent"][data-open="true"] .list-item__dday,
.tasks-section[data-section="urgent"][data-open="true"] .task-item__dday {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 4px;
  color: #c96442;
  background: rgba(201, 100, 66, 0.12);
}

.tasks-section[data-section="later"][data-open="true"] .list-item__dday,
.tasks-section[data-section="later"][data-open="true"] .task-item__dday {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 4px;
  color: #378add;
  background: rgba(55, 138, 221, 0.12);
}

.tasks-section[data-section="none"][data-open="true"] .list-item__dday,
.tasks-section[data-section="none"][data-open="true"] .task-item__dday {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 4px;
  color: #5f5e5a;
  background: rgba(95, 94, 90, 0.12);
}

/* 섹션 항목: 별 · 제목 · D-day · 체크 (한 줄) */
.tasks-section .list-item {
  align-items: center;
}

.tasks-section .list-item__main {
  flex: 1;
  min-width: 0;
  align-items: center;
}

.tasks-section .list-item__title-row {
  flex: 1;
  flex-wrap: nowrap;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.tasks-section .list-item__title {
  flex: 1;
  min-width: 0;
  font-size: var(--text-list-title);
}

.tasks-section .list-item__actions {
  flex-shrink: 0;
  margin-left: auto;
}

/* 청약 연동 행 (홈) — 체크박스 없음, 기존 카드형 유지 */
.task-item--subscription {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-4);
  background: var(--color-bg-elevated);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  min-height: var(--touch-target-min);
  cursor: pointer;
}

.task-item--subscription:active {
  background: var(--color-accent-bg);
}

.task-item__sub-brand {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 36px;
  line-height: var(--line-height-tight);
}

.task-item__sub-brand-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
}

.task-item__sub-brand-icon .lucide-icon {
  width: 18px;
  height: 18px;
  color: var(--color-accent);
}

.task-item__sub-brand-label {
  font-size: 12px;
  font-weight: var(--font-semibold);
  color: var(--color-accent);
  letter-spacing: -0.02em;
}

.task-item--subscription .task-item__title-text {
  flex: 0 1 auto;
  max-width: 38%;
  margin: 0;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
  word-break: break-word;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.task-item__sub-desc {
  flex: 1 1 0;
  min-width: 0;
  margin: 0;
  font-size: var(--text-sm);
  font-weight: var(--font-regular);
  color: var(--color-text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.task-item--subscription .task-item__dday {
  flex-shrink: 0;
  margin-left: auto;
}

.task-item--subscription .task-item__chevron {
  flex-shrink: 0;
  margin-left: var(--space-2);
}

.task-item__title-text {
  margin: 0;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
  word-break: break-word;
}

.tasks-empty,
.tasks-empty--inline,
.tasks-trash-hint {
  font-weight: var(--font-light);
}

.tasks-empty--inset {
  padding: var(--space-4);
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  border-bottom: var(--border-width) solid var(--color-border);
}

/* ---------- 할일 행 (.list-item 기반, components.css) ---------- */
.task-item__body {
  flex: 1;
  min-width: 0;
}

.task-item__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-1);
  flex-wrap: wrap;
}

.task-item__dday {
  font-size: var(--text-dday);
  font-weight: var(--font-bold);
}

.task-item__star {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 1;
  min-width: 0;
  min-height: 0;
  color: var(--color-star-empty);
}

.task-item__star.is-filled {
  color: var(--color-star);
}

.task-item__chevron {
  flex-shrink: 0;
  align-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  font-size: 0.875rem;
  font-weight: var(--font-semibold);
  line-height: 1;
  color: var(--color-text-muted);
  opacity: 0.85;
}

/* ---------- 빈 목록·휴지통 ---------- */
.tasks-empty {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  padding: var(--space-6);
}

.tasks-empty--inline {
  padding: var(--space-4);
}

.tasks-trash-hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
  line-height: var(--line-height-relaxed);
}

.tasks-back-btn {
  width: 100%;
  margin-top: var(--space-6);
}

.task-trash-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--color-bg-elevated);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-2);
}

.task-trash-item__info {
  flex: 1;
  min-width: 0;
}

.task-trash-item__title {
  font-weight: var(--font-medium);
  word-break: break-word;
}

.task-trash-item__date {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}

/* ---------- 하단 시트(추가·상세) ---------- */
.task-sheet {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: 100%;
  max-width: min(100%, var(--app-max-width));
  margin: 0 auto;
  left: 0;
  right: 0;
}

.task-sheet[hidden] {
  display: none !important;
}

.task-sheet__backdrop {
  position: absolute;
  inset: 0;
  background: var(--color-overlay);
}

.task-sheet__panel {
  position: relative;
  z-index: var(--z-modal);
  width: 100%;
  max-height: 90dvh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--color-bg-elevated);
  border-radius: 0;
  box-shadow: var(--shadow-lg);
}

.task-sheet__panel .task-sheet__header {
  flex-shrink: 0;
  padding: var(--space-4);
  margin-bottom: 0;
}

.task-sheet__panel .task-form {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
  gap: 0;
}

.task-sheet__panel .task-form__scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0 var(--space-4);
}

.task-sheet__panel .task-form__actions.sheet-footer {
  flex-shrink: 0;
  margin-top: 0;
  padding: var(--space-4);
  padding-bottom: calc(var(--space-4) + var(--safe-bottom));
  background: var(--color-bg-elevated);
  border-top: var(--border-width) solid var(--color-border-subtle);
}

.task-sheet__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.task-sheet__title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
}

.task-sheet__close {
  min-width: var(--touch-target-min);
  min-height: var(--touch-target-min);
  font-size: var(--text-lg);
  color: var(--color-text-muted);
}

.task-form__field {
  display: block;
  margin-bottom: var(--space-6);
}

.task-form__field:last-of-type {
  margin-bottom: var(--space-8);
}

.task-form__label {
  display: block;
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}

.task-form__label em {
  font-style: normal;
  font-weight: var(--font-regular);
  color: var(--color-text-muted);
}

.task-form__radio {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-1);
  font-size: var(--text-base);
}

.task-form__stars {
  display: flex;
  gap: var(--space-1);
}

.task-form__star-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2);
  line-height: 1;
  min-width: calc(var(--touch-target-min) + 8px);
  min-height: calc(var(--touch-target-min) + 8px);
  color: var(--color-star-empty);
}

.task-form__stars .lucide-icon,
.task-form__star-btn .lucide-icon {
  width: calc(var(--icon-star-size) * 2);
  height: calc(var(--icon-star-size) * 2);
}

.task-form__star-btn.is-filled {
  color: var(--color-star);
}

.task-form__actions.sheet-footer {
  margin-top: var(--space-6);
}
