/**
 * 番茄钟应用样式表
 *
 * 结构：变量定义 → 基础重置 → 布局 → 组件 → 响应式
 */

/* ===========================================
   CSS 变量：设计令牌
   =========================================== */

:root {
  /* 页面与卡片背景 */
  --color-page: #f8f4ef;
  --color-surface: #fffdf9;

  /* 文字颜色 */
  --color-text: #241f1c;
  --color-muted: #706761;

  /* 边框 */
  --color-border: #e6dcd2;

  /* 主色调：番茄红 */
  --color-primary: #d44835;
  --color-primary-dark: #a93225;
  --color-primary-soft: #f7d8d2;

  /* 完成状态：绿色 */
  --color-green: #2f7d56;
  --color-green-soft: #dceee5;

  /* 阴影 */
  --color-shadow: rgba(71, 45, 28, 0.14);

  /* 圆角 */
  --radius-small: 8px;

  /* 间距系统（8px 基准） */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
}

/* ===========================================
   基础重置
   =========================================== */

* {
  box-sizing: border-box;
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--color-text);
  background:
    linear-gradient(135deg, rgba(212, 72, 53, 0.08), transparent 34%),
    var(--color-page);
  font-family:
    "Avenir Next",
    "PingFang SC",
    "Microsoft YaHei",
    sans-serif;
}

button,
input {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

/* 键盘导航焦点样式 */
button:focus-visible,
input:focus-visible {
  outline: 3px solid rgba(212, 72, 53, 0.35);
  outline-offset: 2px;
}

/* ===========================================
   主布局：双栏应用外壳
   =========================================== */

.app-shell {
  display: grid;
  grid-template-columns: minmax(320px, 0.95fr) minmax(320px, 1.05fr);
  gap: var(--space-6);
  width: min(1120px, calc(100% - 32px));
  min-height: 100vh;
  margin: 0 auto;
  padding: var(--space-7) 0;
  align-items: center;
}

/* ===========================================
   面板卡片样式
   =========================================== */

.timer-panel,
.task-panel {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-small);
  background: rgba(255, 253, 249, 0.9);
  box-shadow: 0 18px 55px var(--color-shadow);
}

.timer-panel {
  padding: var(--space-6);
}

.task-panel {
  padding: var(--space-5);
}

/* ===========================================
   标题和段落
   =========================================== */

.section-heading,
.task-header {
  margin-bottom: var(--space-5);
}

.eyebrow {
  margin: 0 0 var(--space-2);
  color: var(--color-primary);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

h1,
h2,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: var(--space-3);
  font-size: clamp(2.1rem, 5vw, 4.5rem);
  line-height: 1.02;
  letter-spacing: 0;
}

h2 {
  margin-bottom: 0;
  font-size: 1.65rem;
}

.intro {
  max-width: 36rem;
  margin-bottom: 0;
  color: var(--color-muted);
  line-height: 1.7;
}

/* ===========================================
   模式切换标签栏
   =========================================== */

.mode-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}

/* ===========================================
   按钮通用样式
   =========================================== */

.mode-button,
.secondary-button,
.ghost-button,
.task-form button,
.task-filter-button,
.task-action {
  min-height: 44px;
  border-radius: var(--radius-small);
  transition:
    transform 160ms ease,
    background 160ms ease,
    color 160ms ease,
    box-shadow 160ms ease;
}

/* ===========================================
   模式按钮
   =========================================== */

.mode-button {
  padding: var(--space-3);
  color: var(--color-muted);
  background: #f2ebe3;
  font-weight: 700;
}

.mode-button.is-active {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
}

/* ===========================================
   计时器显示区
   =========================================== */

.timer-display {
  display: grid;
  gap: var(--space-2);
  justify-items: center;
  container-type: inline-size;
  margin-bottom: var(--space-6);
  padding: var(--space-6);
  border-radius: var(--radius-small);
  background: #2d2723;
  color: #fffaf3;
}

.timer-mode {
  color: #f3c5bc;
  font-weight: 700;
}

.timer-time {
  max-width: 100%;
  font-size: clamp(3.2rem, 24cqw, 7rem);
  line-height: 0.95;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ===========================================
   计时器控制按钮
   =========================================== */

.timer-actions {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

/* ===========================================
   按钮类型
   =========================================== */

.primary-button,
.secondary-button,
.ghost-button,
.task-form button {
  padding: 0 var(--space-4);
  font-weight: 800;
}

.primary-button {
  min-height: 50px;
  color: white;
  background: var(--color-primary);
  box-shadow: 0 10px 24px rgba(212, 72, 53, 0.26);
}

.secondary-button {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
}

.ghost-button {
  color: var(--color-muted);
  background: #f2ebe3;
}

/* ===========================================
   计时结束提示
   =========================================== */

.timer-message {
  margin: 0 0 var(--space-4);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-primary-soft);
  border-radius: var(--radius-small);
  color: var(--color-primary-dark);
  background: #fff0ec;
  font-weight: 800;
  line-height: 1.5;
}

/* ===========================================
   当前任务显示
   =========================================== */

.current-task {
  margin-bottom: 0;
  padding: var(--space-3) var(--space-4);
  border: 1px dashed #d6c5b7;
  border-radius: var(--radius-small);
  color: var(--color-muted);
  line-height: 1.5;
}

/* ===========================================
   任务统计
   =========================================== */

.task-summary {
  margin: 0;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-small);
  color: var(--color-green);
  background: var(--color-green-soft);
  font-size: 0.95rem;
  font-weight: 800;
  white-space: nowrap;
}

/* ===========================================
   任务管理工具（筛选+排序）
   =========================================== */

.task-management {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-3);
  align-items: center;
  margin-bottom: var(--space-4);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-small);
  background: #fbf7f1;
}

.task-filters {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}

.task-filter-button {
  padding: 0 var(--space-3);
  color: var(--color-muted);
  background: #f2ebe3;
  font-weight: 800;
}

.task-filter-button.is-active {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
}

.task-sort-label {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  color: var(--color-muted);
  font-size: 0.95rem;
  font-weight: 800;
  white-space: nowrap;
}

.task-sort-label select {
  min-height: 44px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-small);
  padding: 0 var(--space-3);
  color: var(--color-text);
  background: white;
  font-weight: 700;
}

/* ===========================================
   任务添加表单
   =========================================== */

.task-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.task-form input {
  min-width: 0;
  min-height: 48px;
  border: 1px solid var(--color-border);
  border-radius: var(--space-2);
  padding: 0 var(--space-4);
  color: var(--color-text);
  background: white;
}

.task-edit-area {
  display: grid;
  gap: var(--space-1);
}

.task-edit-input {
  width: 100%;
  min-width: 0;
  min-height: 44px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-small);
  padding: 0 var(--space-3);
  color: var(--color-text);
  background: white;
  font-weight: 800;
}

/* ===========================================
   任务列表
   =========================================== */

.task-list {
  display: grid;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

/* ===========================================
   单个任务项
   =========================================== */

.task-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: var(--space-3);
  align-items: center;
  min-height: 72px;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-small);
  background: white;
}

.task-item.is-selected {
  border-color: var(--color-primary);
  box-shadow: inset 4px 0 0 var(--color-primary);
}

.task-item.is-completed {
  color: var(--color-muted);
  background: #f6f0e9;
}

/* ===========================================
   复选框
   =========================================== */

.task-check {
  width: 22px;
  height: 22px;
  accent-color: var(--color-green);
}

/* ===========================================
   任务标题和元信息
   =========================================== */

.task-title {
  display: block;
  margin-bottom: var(--space-1);
  overflow-wrap: anywhere;
  font-weight: 800;
  line-height: 1.35;
}

.task-item.is-completed .task-title {
  text-decoration: line-through;
}

.task-meta {
  color: var(--color-muted);
  font-size: 0.9rem;
}

/* ===========================================
   任务操作按钮
   =========================================== */

.task-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  justify-content: flex-end;
}

.task-action {
  min-width: 64px;
  padding: 0 var(--space-3);
  color: var(--color-muted);
  background: #f2ebe3;
  font-weight: 700;
}

.task-action.is-selected {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
}

/* ===========================================
   空状态
   =========================================== */

.empty-state {
  margin: 0;
  padding: var(--space-5);
  border: 1px dashed #d6c5b7;
  border-radius: var(--radius-small);
  color: var(--color-muted);
  text-align: center;
}

/* ===========================================
   工具类
   =========================================== */

.is-hidden {
  display: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ===========================================
   按钮交互状态
   =========================================== */

button:hover {
  transform: translateY(-1px);
}

button:active {
  transform: translateY(1px);
}

/* ===========================================
   响应式：中等屏幕（<= 1040px）
   =========================================== */

@media (max-width: 1040px) {
  .app-shell {
    grid-template-columns: 1fr;
    align-items: stretch;
    padding: var(--space-5) 0;
  }

  .task-filter-button {
    padding: 0 var(--space-2);
    font-size: 0.95rem;
  }
}

/* ===========================================
   响应式：手机（<= 560px）
   =========================================== */

@media (max-width: 560px) {
  .timer-panel,
  .task-panel {
    padding: var(--space-4);
  }

  .mode-tabs,
  .timer-actions,
  .task-management,
  .task-form,
  .task-item {
    grid-template-columns: 1fr;
  }

  .task-sort-label {
    display: grid;
    gap: var(--space-2);
  }

  .task-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}

/* ===========================================
   无障碍：减少动画偏好
   =========================================== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}
