.term-root {
  --term-bg: var(--color-background, #0d1210);
  --term-panel: var(--color-card, #151b18);
  --term-panel-soft: color-mix(in srgb, var(--color-card, #151b18) 70%, var(--color-background, #0d1210));
  --term-border: var(--color-border, rgba(238, 244, 238, 0.12));
  --term-border-strong: color-mix(in srgb, var(--color-primary, #d0f2d8) 36%, var(--color-border, rgba(238,244,238,0.12)));
  --term-fg: var(--color-foreground, #eef4ee);
  --term-muted: var(--color-muted-foreground, #9eb5a6);
  --term-subtle: color-mix(in srgb, var(--color-foreground, #eef4ee) 70%, transparent);
  --term-accent: var(--color-primary, #d0f2d8);
  --term-accent-strong: color-mix(in srgb, var(--color-primary, #d0f2d8) 80%, white);
  --term-danger: var(--color-destructive, #e06868);
  --term-warning: var(--color-warning, #d6c674);
  --term-completed: var(--color-muted-foreground, #9eb5a6);
  --term-shadow: 0 18px 48px rgba(0, 0, 0, 0.24);
  --term-mono: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  background: var(--term-bg);
  color: var(--term-fg);
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 57px);
}

.term-root .term-banner {
  align-items: center;
  border-bottom: 1px solid var(--term-border);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 8px 16px;
}

.term-root .term-banner-error {
  background: color-mix(in srgb, var(--term-danger) 14%, var(--term-bg));
  color: var(--term-danger);
}

.term-root .term-banner-close {
  background: transparent;
  border: 0;
  color: inherit;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0 6px;
}

.term-root .term-grid {
  display: grid;
  flex: 1;
  grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
  min-height: 0;
}

.term-root .term-sidebar {
  background: var(--term-panel-soft);
  border-right: 1px solid var(--term-border);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.term-root .term-sidebar-head {
  align-items: center;
  border-bottom: 1px solid var(--term-border);
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 10px 12px;
}

.term-root .term-search {
  background: var(--term-bg);
  border: 1px solid var(--term-border);
  border-radius: 6px;
  color: var(--term-fg);
  font-size: 13px;
  padding: 6px 10px;
}

.term-root .term-search:focus {
  border-color: var(--term-border-strong);
  outline: none;
}

.term-root .term-rows {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  padding: 6px;
}

.term-root .term-group-title {
  color: var(--term-accent);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 12px 10px 5px;
  text-transform: uppercase;
}

.term-root .term-row {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  color: inherit;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 10px 12px;
  text-align: left;
  transition: background 120ms ease, border-color 120ms ease;
}

.term-root .term-row + .term-row {
  margin-top: 2px;
}

.term-root .term-row:hover {
  background: color-mix(in srgb, var(--term-accent) 8%, transparent);
}

.term-root .term-row-active {
  background: color-mix(in srgb, var(--term-accent) 18%, transparent);
  border-color: var(--term-border-strong);
}

.term-root .term-row-head {
  align-items: baseline;
  display: flex;
  gap: 8px;
}

.term-root .term-row-icon {
  flex: 0 0 auto;
  font-size: 13px;
  line-height: 1;
}

.term-root .term-row-title {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.term-root .term-row-time {
  color: var(--term-muted);
  font-size: 11px;
  white-space: nowrap;
}

.term-root .term-row-meta {
  align-items: center;
  color: var(--term-muted);
  display: flex;
  flex-wrap: wrap;
  font-size: 12px;
  gap: 6px;
}

.term-root .term-row-meta span + span::before {
  color: color-mix(in srgb, var(--term-muted) 45%, transparent);
  content: "/";
  margin-right: 6px;
}

.term-root .term-row-repeat {
  color: var(--term-accent);
}

.term-root .term-row-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.term-root .term-status-scheduled .term-row-title,
.term-root .term-status-scheduled.term-status-pill {
  color: var(--term-accent);
}

.term-root .term-status-completed .term-row-title,
.term-root .term-status-completed.term-status-pill {
  color: var(--term-completed);
}

.term-root .term-status-cancelled .term-row-title,
.term-root .term-status-cancelled.term-status-pill {
  color: var(--term-danger);
  text-decoration: line-through;
  text-decoration-thickness: 1px;
}

.term-root .term-sidebar-foot {
  border-top: 1px solid var(--term-border);
  color: var(--term-muted);
  font-size: 11px;
  letter-spacing: 0.04em;
  padding: 8px 12px;
  text-transform: uppercase;
}

.term-root .term-empty {
  color: var(--term-muted);
  font-size: 13px;
  padding: 24px 16px;
  text-align: center;
}

.term-root .term-editor {
  background: var(--term-bg);
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow-y: auto;
}

.term-root .term-editor-empty {
  align-items: center;
  color: var(--term-muted);
  display: flex;
  flex: 1;
  font-size: 14px;
  justify-content: center;
  text-align: center;
}

.term-root .term-editor-bar {
  align-items: center;
  background: var(--term-panel);
  border-bottom: 1px solid var(--term-border);
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 10px 16px;
  position: sticky;
  top: 0;
  z-index: 2;
}

.term-root .term-title-input {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--term-fg);
  font-size: 18px;
  font-weight: 500;
  padding: 6px 10px;
}

.term-root .term-title-input:focus {
  border-color: var(--term-border-strong);
  outline: none;
}

.term-root .term-editor-actions {
  display: flex;
  gap: 8px;
}

.term-root .term-meta {
  border-bottom: 1px solid var(--term-border);
  color: var(--term-muted);
  display: flex;
  flex-wrap: wrap;
  font-size: 11px;
  gap: 18px;
  letter-spacing: 0.04em;
  padding: 6px 16px;
  text-transform: uppercase;
}

.term-root .term-meta-cell {
  white-space: nowrap;
}

.term-root .term-meta-status {
  color: var(--term-subtle);
}

.term-root .term-time-row {
  align-items: end;
  border-bottom: 1px solid var(--term-border);
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(190px, 240px) minmax(190px, 240px) auto minmax(170px, 220px);
  padding: 12px 16px;
}

.term-root .term-time-field,
.term-root .term-field-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.term-root .term-field-full {
  grid-column: 1 / -1;
}

.term-root .term-field-label,
.term-root .term-tags-label {
  color: var(--term-muted);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.term-root .term-field-input {
  background: var(--term-panel-soft);
  border: 1px solid var(--term-border);
  border-radius: 6px;
  color: var(--term-fg);
  font-size: 12px;
  min-height: 30px;
  padding: 5px 8px;
}

.term-root .term-field-input:focus {
  border-color: var(--term-border-strong);
  outline: none;
}

.term-root .term-check-field {
  align-items: center;
  color: var(--term-muted);
  display: flex;
  font-size: 12px;
  gap: 7px;
  min-height: 31px;
  white-space: nowrap;
}

.term-root .term-check-field input {
  accent-color: var(--term-accent);
}

.term-root .term-location-row {
  border-bottom: 1px solid var(--term-border);
  display: grid;
  padding: 12px 16px;
}

.term-root .term-card {
  background: var(--term-panel-soft);
  border: 1px solid var(--term-border);
  border-radius: 8px;
  margin: 14px 16px 0;
  padding: 0;
}

.term-root .term-card-toggle {
  align-items: center;
  background: transparent;
  border: 0;
  color: var(--term-muted);
  cursor: pointer;
  display: flex;
  font-size: 11px;
  font-weight: 700;
  justify-content: space-between;
  letter-spacing: 0.08em;
  padding: 10px 12px;
  text-transform: uppercase;
  width: 100%;
}

.term-root .term-card-toggle-icon {
  color: var(--term-accent);
  font-size: 15px;
  line-height: 1;
}

.term-root .term-card-grid {
  border-top: 1px solid var(--term-border);
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr 1fr;
  padding: 10px 12px 12px;
}

.term-root .term-tags-row {
  align-items: center;
  border-bottom: 1px solid var(--term-border);
  display: grid;
  gap: 12px;
  grid-template-columns: auto minmax(220px, 380px) minmax(0, 1fr);
  padding: 12px 16px;
}

.term-root .term-tags-input {
  background: var(--term-panel-soft);
  border: 1px solid var(--term-border);
  border-radius: 6px;
  color: var(--term-fg);
  font-size: 12px;
  padding: 5px 10px;
}

.term-root .term-tags-input:focus {
  border-color: var(--term-border-strong);
  outline: none;
}

.term-root .term-tags-display {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.term-root .term-tag {
  background: color-mix(in srgb, var(--term-accent) 16%, transparent);
  border: 1px solid color-mix(in srgb, var(--term-accent) 38%, transparent);
  border-radius: 999px;
  color: var(--term-accent);
  font-size: 11px;
  letter-spacing: 0.02em;
  padding: 2px 8px;
}

.term-root .term-tag-mini {
  font-size: 10px;
  padding: 1px 6px;
}

.term-root .term-notes-textarea {
  background: var(--term-bg);
  border: 0;
  color: var(--term-fg);
  flex: 1;
  font-family: var(--term-mono);
  font-size: 14px;
  line-height: 1.65;
  min-height: 260px;
  outline: none;
  padding: 18px 22px;
  resize: vertical;
}

.term-root .term-btn,
.term-root .term-status-pill {
  background: var(--term-panel-soft);
  border: 1px solid var(--term-border);
  border-radius: 6px;
  color: var(--term-fg);
  cursor: pointer;
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 6px 12px;
  text-transform: uppercase;
  transition: background 120ms ease, border-color 120ms ease;
}

.term-root .term-btn:hover:not(:disabled),
.term-root .term-status-pill:hover:not(:disabled) {
  border-color: var(--term-border-strong);
}

.term-root .term-btn:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.term-root .term-btn-primary {
  background: var(--term-accent);
  border-color: var(--term-accent);
  color: var(--term-bg);
  font-weight: 600;
}

.term-root .term-btn-primary:hover:not(:disabled) {
  background: var(--term-accent-strong);
}

.term-root .term-btn-danger {
  color: var(--term-danger);
}

.term-root .term-btn-danger:hover:not(:disabled) {
  background: color-mix(in srgb, var(--term-danger) 14%, transparent);
  border-color: var(--term-danger);
}

.term-root .term-status-pill {
  font-weight: 700;
}

.term-root .term-status-scheduled.term-status-pill {
  background: color-mix(in srgb, var(--term-accent) 14%, transparent);
  border-color: color-mix(in srgb, var(--term-accent) 44%, transparent);
}

.term-root .term-status-completed.term-status-pill {
  background: color-mix(in srgb, var(--term-completed) 12%, transparent);
  border-color: color-mix(in srgb, var(--term-completed) 36%, transparent);
}

.term-root .term-status-cancelled.term-status-pill {
  background: color-mix(in srgb, var(--term-danger) 12%, transparent);
  border-color: color-mix(in srgb, var(--term-danger) 44%, transparent);
  text-decoration: none;
}

@media (max-width: 900px) {
  .term-root .term-grid {
    grid-template-columns: 1fr;
  }

  .term-root .term-sidebar {
    border-bottom: 1px solid var(--term-border);
    border-right: 0;
    max-height: 42vh;
  }

  .term-root .term-time-row {
    grid-template-columns: 1fr 1fr;
  }

  .term-root .term-tags-row {
    grid-template-columns: 1fr;
  }
}
