:root {
  --sage: #2D6A4F;
  --sage-dark: #255a42;
  --terracotta: #E07A5F;
  --terracotta-dark: #c96a52;
  --cream: #F7F3EE;
  --ink: #1F2937;
}

html, body {
  background-color: var(--cream);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
}

*:focus-visible {
  outline: 2px solid var(--sage);
  outline-offset: 2px;
}

.htmx-indicator { opacity: 0; transition: opacity .3s ease; }
.htmx-request .htmx-indicator { opacity: 1; }
.htmx-request.htmx-indicator { opacity: 1; }

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem 1rem;
  border-radius: .5rem;
  background-color: var(--sage);
  color: #fff;
  font-size: .875rem;
  font-weight: 500;
  transition: background-color .15s ease;
}
.btn-primary:hover { background-color: var(--sage-dark); }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem 1rem;
  border-radius: .5rem;
  border: 1px solid #d1d5db;
  background-color: #fff;
  color: var(--ink);
  font-size: .875rem;
  font-weight: 500;
  transition: background-color .15s ease;
}
.btn-secondary:hover { background-color: #f9fafb; }

.btn-danger {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem 1rem;
  border-radius: .5rem;
  background-color: var(--terracotta);
  color: #fff;
  font-size: .875rem;
  font-weight: 500;
  transition: background-color .15s ease;
}
.btn-danger:hover { background-color: var(--terracotta-dark); }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(31,41,55,.15); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(31,41,55,.3); }
