/* Timer 页面样式 */

.timer-page {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  text-align: center;
}

.timer-task-title {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: var(--space-5);
}

.timer-circle {
  width: 280px;
  height: 280px;
  border-radius: 50%;
  border: 8px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin-bottom: var(--space-6);
  position: relative;
}

.timer-circle--running {
  border-color: var(--color-primary);
  animation: pulse 2s infinite;
}

.timer-time {
  font-size: 64px;
  font-weight: 700;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}

.timer-hint {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-top: var(--space-2);
}

.timer-controls {
  display: flex;
  gap: var(--space-3);
}

.timer-complete {
  margin-top: var(--space-5);
}

.reward-animation {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.7);
  z-index: 300;
  flex-direction: column;
  color: #fff;
  font-size: 48px;
  animation: fadeIn 300ms;
}

.reward-text {
  font-size: 24px;
  margin-top: var(--space-4);
}

@keyframes starBurst {
  0% { transform: scale(0); opacity: 1; }
  100% { transform: scale(2); opacity: 0; }
}
