.tn-day-breathing {
  animation: tn-day-breathe 12s ease-in-out infinite;
}

@keyframes tn-day-breathe {
  0%, 100% { box-shadow: var(--tn-shadow-panel); }
  50% { box-shadow: 0 14px 38px rgba(47, 111, 115, 0.11); }
}

.tn-signal-pulse {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #16a36c;
}

.tn-signal-pulse::after {
  content: "";
  position: absolute;
  inset: -7px;
  border-radius: inherit;
  border: 1px solid rgba(22, 163, 108, 0.34);
  animation: tn-signal-pulse 1.8s ease-out infinite;
}

@keyframes tn-signal-pulse {
  0% { transform: scale(0.65); opacity: 0.8; }
  100% { transform: scale(1.45); opacity: 0; }
}

.tn-pressable {
  transition: transform 0.16s cubic-bezier(0.16, 1, 0.3, 1), filter 0.16s ease;
}

.tn-pressable:active {
  transform: translateY(1px) scale(0.985);
  filter: saturate(0.95) brightness(0.98);
}

.tn-ink-reveal {
  position: relative;
  overflow: hidden;
}

.tn-ink-reveal::before {
  content: "";
  position: absolute;
  left: 16px;
  top: 18px;
  bottom: 18px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--tn-accent), var(--tn-teal));
  transform: scaleY(0);
  transform-origin: top;
  animation: tn-ink-draw 0.62s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes tn-ink-draw {
  to { transform: scaleY(1); }
}

.tn-loader {
  display: grid;
  justify-items: center;
  gap: 12px;
  padding: 28px;
  border-radius: 28px;
  background: var(--tn-surface);
  border: 1px solid var(--tn-border);
  box-shadow: var(--tn-shadow-soft);
}

.tn-loader-calendar,
.tn-loader-diary,
.tn-loader-market {
  width: 86px;
  height: 58px;
  display: grid;
  align-items: end;
  grid-template-columns: repeat(5, 1fr);
  gap: 5px;
}

.tn-loader-calendar span,
.tn-loader-diary span,
.tn-loader-market span {
  display: block;
  border-radius: 999px;
  background: var(--tn-accent);
  animation: tn-loader-rise 1.1s ease-in-out infinite;
}

.tn-loader-calendar span { height: 10px; background: var(--tn-teal); }
.tn-loader-calendar span:nth-child(2) { height: 24px; animation-delay: .08s; }
.tn-loader-calendar span:nth-child(3) { height: 16px; animation-delay: .16s; }
.tn-loader-calendar span:nth-child(4) { height: 32px; animation-delay: .24s; }
.tn-loader-calendar span:nth-child(5) { height: 20px; animation-delay: .32s; }

.tn-loader-diary span { height: 18px; background: #5d9bff; }
.tn-loader-diary span:nth-child(2) { height: 28px; animation-delay: .08s; }
.tn-loader-diary span:nth-child(3) { height: 14px; animation-delay: .16s; }
.tn-loader-diary span:nth-child(4) { height: 38px; animation-delay: .24s; }
.tn-loader-diary span:nth-child(5) { height: 24px; animation-delay: .32s; }

.tn-loader-market span { height: 34px; background: #16a36c; }
.tn-loader-market span:nth-child(2),
.tn-loader-market span:nth-child(4) { background: var(--tn-loss); }
.tn-loader-market span:nth-child(3) { height: 48px; animation-delay: .16s; }

@keyframes tn-loader-rise {
  0%, 100% { transform: scaleY(0.68); opacity: .58; }
  50% { transform: scaleY(1); opacity: 1; }
}
