/* ============================================================
   FORESTRY · COMPONENTS
   ──────────────────────────────────────────────────────────
   All component styles are scoped to .ds-forestry. Drop the
   class onto <html> (or any root container) and the components
   below render correctly. Pair with tokens.css.
   ============================================================ */

/* ── App shell ─────────────────────────────────────────────── */
.ds-forestry .app {
  display: grid;
  grid-template-columns: 224px 1fr;
  height: 100%;
  width: 100%;
}

/* ── Sidebar (dark forest) ────────────────────────────────── */
.ds-forestry .sidenav {
  background: var(--b-dark);
  border-right: 1px solid var(--b-dark-line);
  padding: 16px 12px;
  display: flex;
  flex-direction: column;
  gap: 1px;
  color: var(--b-dark-ink);
}
.ds-forestry .brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px 18px;
  border-bottom: 1px solid var(--b-dark-line);
  margin-bottom: 12px;
}
.ds-forestry .brand-mark {
  width: 30px;
  height: 30px;
  background: var(--b-accent-3);
  color: var(--b-dark);
  display: grid;
  place-items: center;
  font-family: var(--b-font-serif);
  font-weight: 600;
  font-size: 17px;
  font-style: italic;
  border-radius: 2px;
}
.ds-forestry .brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.ds-forestry .brand-text b {
  font-family: var(--b-font-serif);
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--b-dark-ink);
}
.ds-forestry .brand-text span {
  font-size: 10px;
  color: var(--b-gold-3);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-family: var(--b-font-mono);
}
.ds-forestry .nav-section {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--b-dark-ink-3);
  padding: 16px 8px 6px;
  font-weight: 500;
  font-family: var(--b-font-mono);
}
.ds-forestry .nav-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 8px 10px;
  color: var(--b-dark-ink-2);
  font-size: 13.5px;
  cursor: pointer;
  border-left: 2px solid transparent;
  margin-left: -2px;
  border-radius: 0 3px 3px 0;
  text-decoration: none;
  transition: background 100ms, color 100ms;
}
.ds-forestry .nav-item:hover { background: var(--b-dark-3); color: var(--b-dark-ink); }
.ds-forestry .nav-item.on {
  background: var(--b-dark-2);
  color: var(--b-dark-ink);
  font-weight: 500;
  border-left-color: var(--b-gold-3);
}
.ds-forestry .nav-item .nav-ic { width: 16px; height: 16px; color: var(--b-dark-ink-3); flex-shrink: 0; }
.ds-forestry .nav-item.on .nav-ic { color: var(--b-gold-3); }
.ds-forestry .nav-item .nav-badge {
  margin-left: auto;
  font-family: var(--b-font-mono);
  font-size: 11px;
  color: var(--b-dark-ink-3);
}
.ds-forestry .nav-item.on .nav-badge { color: var(--b-gold-3); }

/* ── Topbar ────────────────────────────────────────────────── */
.ds-forestry .topbar {
  height: 52px;
  border-bottom: 1px solid var(--b-line);
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 14px;
  background: var(--b-bg);
  flex-shrink: 0;
}
.ds-forestry .crumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--b-font-serif);
  font-size: 16px;
  color: var(--b-ink-3);
}
.ds-forestry .crumbs b { color: var(--b-ink); font-weight: 500; }
.ds-forestry .crumb-sep { color: var(--b-ink-4); }
.ds-forestry .search-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--b-line);
  background: var(--b-surface);
  font-size: 13px;
  color: var(--b-ink-3);
  width: 300px;
  font-family: var(--b-font-mono);
  border-radius: var(--b-r);
}
.ds-forestry .search-pill kbd {
  margin-left: auto;
  font-size: 10.5px;
  padding: 1px 5px;
  background: var(--b-surface-3);
  color: var(--b-ink-2);
  border-radius: 2px;
  font-family: inherit;
}
.ds-forestry .avatar {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--b-gold);
  color: var(--b-dark);
  display: grid;
  place-items: center;
  font-family: var(--b-font-serif);
  font-size: 13px;
  font-style: italic;
  font-weight: 600;
}

/* ── Page wrapper + header ─────────────────────────────────── */
.ds-forestry .page { padding: 28px 32px; overflow: auto; flex: 1; }
.ds-forestry .page-h {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--b-line);
}
.ds-forestry .page-h h1 {
  font-family: var(--b-font-serif);
  font-size: 30px;
  font-weight: 400;
  letter-spacing: -0.015em;
  margin: 0 0 4px;
  color: var(--b-ink);
}
.ds-forestry .page-h h1 em { font-style: italic; color: var(--b-ink-3); font-weight: 400; }
.ds-forestry .page-h p { font-size: 13px; color: var(--b-ink-3); margin: 0; }

/* ── Dark hero panels ──────────────────────────────────────── */
.ds-forestry .panel-dark {
  background: var(--b-dark);
  color: var(--b-dark-ink);
  border-radius: var(--b-r-lg);
  border: 1px solid var(--b-dark-line);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}
.ds-forestry .panel-dark .lbl,
.ds-forestry .panel-dark .sub { color: var(--b-dark-ink-3); }

.ds-forestry .panel-gold {
  background: linear-gradient(135deg, #1A2B22 0%, #14201A 100%);
  color: var(--b-dark-ink);
  border: 1px solid var(--b-gold-2);
  border-radius: var(--b-r-lg);
  position: relative;
  overflow: hidden;
}
.ds-forestry .panel-gold::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--b-gold-3), var(--b-gold), var(--b-gold-2));
}

/* ── Buttons ───────────────────────────────────────────────── */
.ds-forestry .btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border: 1px solid var(--b-line-2);
  background: var(--b-surface-2);
  color: var(--b-ink);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  border-radius: var(--b-r);
  text-decoration: none;
  transition: background 100ms, border-color 100ms;
}
.ds-forestry .btn:hover { background: var(--b-surface-3); border-color: var(--b-ink-3); }
.ds-forestry .btn.primary { background: var(--b-ink); color: var(--b-bg); border-color: var(--b-ink); }
.ds-forestry .btn.primary:hover { background: var(--b-ink-2); border-color: var(--b-ink-2); }
.ds-forestry .btn.accent { background: var(--b-accent); color: white; border-color: var(--b-accent); }
.ds-forestry .btn.accent:hover { background: var(--b-accent-2); }
.ds-forestry .btn.ghost { background: transparent; border-color: transparent; }
.ds-forestry .btn.ghost:hover { background: var(--b-surface-3); }
.ds-forestry .btn.sm { padding: 4px 10px; font-size: 12px; }

/* ── Card ──────────────────────────────────────────────────── */
.ds-forestry .card { background: var(--b-surface); border: 1px solid var(--b-line); border-radius: var(--b-r-lg); }
.ds-forestry .card-h {
  padding: 14px 18px;
  border-bottom: 1px solid var(--b-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ds-forestry .card-h h3 {
  margin: 0;
  font-family: var(--b-font-serif);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--b-ink);
}
.ds-forestry .card-h .sub { font-size: 12px; color: var(--b-ink-3); font-family: var(--b-font-mono); }
.ds-forestry .card-b { padding: 18px; }

/* ── Pills (status badges) ─────────────────────────────────── */
.ds-forestry .pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  font-size: 11px;
  font-family: var(--b-font-mono);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--b-surface-3);
  color: var(--b-ink-2);
  border-radius: var(--b-r-sm);
  white-space: nowrap;
}
.ds-forestry .pill.good   { background: var(--b-good-soft);   color: var(--b-good); }
.ds-forestry .pill.warn   { background: var(--b-warn-soft);   color: var(--b-warn); }
.ds-forestry .pill.bad    { background: var(--b-bad-soft);    color: var(--b-bad); }
.ds-forestry .pill.info   { background: var(--b-info-soft);   color: var(--b-info); }
.ds-forestry .pill.accent { background: var(--b-accent-soft); color: var(--b-accent); }
.ds-forestry .pill .dot { width: 5px; height: 5px; border-radius: 999px; background: currentColor; }

/* ── Inputs ────────────────────────────────────────────────── */
.ds-forestry .input,
.ds-forestry .select {
  height: 36px;
  padding: 0 12px;
  border: 1px solid var(--b-line-2);
  background: var(--b-surface);
  font-size: 13.5px;
  color: var(--b-ink);
  font-family: inherit;
  width: 100%;
  outline: none;
  border-radius: var(--b-r);
}
.ds-forestry .input:focus,
.ds-forestry .select:focus { border-color: var(--b-accent); }
.ds-forestry .label {
  display: block;
  font-size: 11.5px;
  color: var(--b-ink-3);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 500;
}

/* ── Table ─────────────────────────────────────────────────── */
.ds-forestry .table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.ds-forestry .table th {
  text-align: left;
  font-weight: 500;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--b-ink-3);
  padding: 10px 14px;
  border-bottom: 1px solid var(--b-ink-3);
}
.ds-forestry .table td {
  padding: 14px;
  border-bottom: 1px solid var(--b-line);
  color: var(--b-ink-2);
  font-family: var(--b-font-mono);
  font-size: 13px;
}
.ds-forestry .table td.t { font-family: var(--b-font-sans); color: var(--b-ink); }
.ds-forestry .table tr:hover td { background: var(--b-surface-2); }

/* ── KPI ───────────────────────────────────────────────────── */
.ds-forestry .kpi { background: var(--b-surface); border: 1px solid var(--b-line); padding: 18px 20px; border-radius: var(--b-r-lg); }
.ds-forestry .kpi .lbl { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--b-ink-3); margin-bottom: 10px; }
.ds-forestry .kpi .val {
  font-family: var(--b-font-serif);
  font-size: 32px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1;
}
.ds-forestry .kpi .val .unit { font-family: var(--b-font-mono); font-size: 14px; color: var(--b-ink-3); margin-left: 6px; letter-spacing: 0; }
.ds-forestry .kpi .delta { font-family: var(--b-font-mono); font-size: 11.5px; color: var(--b-ink-3); margin-top: 8px; }
.ds-forestry .kpi .delta.up   { color: var(--b-good); }
.ds-forestry .kpi .delta.down { color: var(--b-bad); }

/* ── Progress bar ──────────────────────────────────────────
   Usage:
     <div class="progress"><div class="progress-bar" style="width: 64%"></div></div>
   Modifiers on .progress-bar: .good / .warn / .bad / .accent
   Or key by score: <70% accent, 40-70% warn, <40% bad — implement at app level.
   ────────────────────────────────────────────────────────── */
.ds-forestry .progress {
  height: 6px;
  width: 100%;
  background: var(--b-line);
  border-radius: 999px;
  overflow: hidden;
}
.ds-forestry .progress.sm  { height: 4px; }
.ds-forestry .progress.lg  { height: 10px; }
.ds-forestry .progress-bar {
  height: 100%;
  background: var(--b-accent);
  border-radius: 999px;
  transition: width 240ms cubic-bezier(.2,.8,.2,1);
}
.ds-forestry .progress-bar.accent { background: var(--b-accent); }
.ds-forestry .progress-bar.good   { background: var(--b-good); }
.ds-forestry .progress-bar.warn   { background: var(--b-warn); }
.ds-forestry .progress-bar.bad    { background: var(--b-bad); }
.ds-forestry .progress-bar.info   { background: var(--b-info, #5b8dd6); }

/* ── Sparkline ─────────────────────────────────────────────── */
.ds-forestry .spark-path { fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linejoin: round; stroke-linecap: round; }
.ds-forestry .spark-fill { fill: currentColor; opacity: 0.18; }

/* ============================================================
   LEGACY UTILITY REMAP — let pages with bare Tailwind color
   classes (text-gray-700, bg-red-50, etc.) render correctly
   on dark forestry without per-page rewrites.
   ============================================================ */
.ds-forestry .text-muted-foreground { color: var(--b-ink-3); }
.ds-forestry .border { border-color: var(--b-line); }
.ds-forestry a:not(.btn):not(.nav-item) { color: var(--b-accent-3); }
.ds-forestry a:not(.btn):not(.nav-item):hover { color: var(--b-accent); }

.ds-forestry .text-gray-300,
.ds-forestry .text-gray-400,
.ds-forestry .text-gray-500,
.ds-forestry .text-gray-600 { color: var(--b-ink-3); }
.ds-forestry .text-gray-700,
.ds-forestry .text-gray-800,
.ds-forestry .text-gray-900 { color: var(--b-ink); }
.ds-forestry .bg-gray-50,
.ds-forestry .bg-gray-100,
.ds-forestry .bg-gray-200 { background: var(--b-surface-2); }
.ds-forestry .bg-white     { background: var(--b-surface); }

.ds-forestry .text-red-500, .ds-forestry .text-red-600,
.ds-forestry .text-red-700, .ds-forestry .text-red-800 { color: var(--b-bad); }
.ds-forestry .bg-red-50, .ds-forestry .bg-red-100 { background: var(--b-bad-soft); }
.ds-forestry .border-red-200, .ds-forestry .border-red-300 { border-color: rgba(232, 128, 110, 0.30); }
.ds-forestry .bg-red-500 { background: var(--b-bad); }

.ds-forestry .text-green-500, .ds-forestry .text-green-600,
.ds-forestry .text-green-700, .ds-forestry .text-green-800 { color: var(--b-good); }
.ds-forestry .bg-green-50, .ds-forestry .bg-green-100 { background: var(--b-good-soft); }
.ds-forestry .border-green-200, .ds-forestry .border-green-300 { border-color: rgba(79, 160, 112, 0.30); }

.ds-forestry .text-yellow-600, .ds-forestry .text-yellow-700,
.ds-forestry .text-amber-600,  .ds-forestry .text-amber-700 { color: var(--b-gold); }
.ds-forestry .bg-yellow-50,    .ds-forestry .bg-yellow-100,
.ds-forestry .bg-amber-50,     .ds-forestry .bg-amber-100 { background: var(--b-warn-soft); }
.ds-forestry .bg-yellow-400,   .ds-forestry .bg-yellow-500 { background: var(--b-gold); }

.ds-forestry .text-blue-500, .ds-forestry .text-blue-600,
.ds-forestry .text-blue-700, .ds-forestry .text-sky-600 { color: var(--b-blue); }
.ds-forestry .bg-blue-50, .ds-forestry .bg-blue-100 { background: var(--b-info-soft); }

.ds-forestry .hover\:bg-gray-100:hover { background: var(--b-surface-3); }
.ds-forestry .hover\:bg-gray-50:hover  { background: var(--b-surface-2); }
.ds-forestry .hover\:text-red-600:hover { color: var(--b-bad); }
.ds-forestry .hover\:text-gray-900:hover { color: var(--b-ink); }
.ds-forestry .hover\:bg-accent:hover { background: var(--b-surface-3); }
.ds-forestry .hover\:bg-muted:hover  { background: var(--b-surface-3); }

.ds-forestry .border, .ds-forestry .border-t, .ds-forestry .border-b,
.ds-forestry .border-l, .ds-forestry .border-r { border-color: var(--b-line); }
.ds-forestry .border-input { border-color: var(--b-line-2); }

.ds-forestry input, .ds-forestry textarea, .ds-forestry select { color: var(--b-ink); }
.ds-forestry input::placeholder, .ds-forestry textarea::placeholder { color: var(--b-ink-4); }

.ds-forestry pre, .ds-forestry code {
  background: var(--b-surface-2);
  color: var(--b-ink-2);
  font-family: var(--b-font-mono);
}
.ds-forestry [data-state='checked'] { background: var(--b-accent); border-color: var(--b-accent); }
.ds-forestry .bg-blue-50\/70 { background: var(--b-info-soft); color: var(--b-blue-3); }

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.ds-forestry .skip-link {
  position: absolute;
  top: -40px;
  left: 8px;
  background: var(--b-accent);
  color: white;
  padding: 8px 16px;
  border-radius: 4px;
  z-index: 1000;
  font-size: 14px;
  font-family: var(--b-font-sans);
  text-decoration: none;
  transition: top 0.15s;
}
.ds-forestry .skip-link:focus { top: 8px; outline: 2px solid white; outline-offset: 2px; }

.ds-forestry .table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ============================================================
   RESPONSIVE — phone/tablet portrait (< 900px)
   ============================================================ */
@media (max-width: 900px) {
  .ds-forestry .app { grid-template-columns: 1fr !important; }
  .ds-forestry .sidenav {
    flex-direction: row !important;
    overflow-x: auto;
    border-right: none;
    border-bottom: 1px solid var(--b-dark-line);
    padding: 8px 12px;
    align-items: center;
    gap: 4px;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
  .ds-forestry .sidenav .brand,
  .ds-forestry .sidenav .nav-section { display: none; }
  .ds-forestry .sidenav nav { flex-direction: row !important; flex: 0 1 auto !important; gap: 4px !important; }
  .ds-forestry .sidenav nav > div { display: flex; flex-direction: row; gap: 4px; }
  .ds-forestry .sidenav form {
    margin-top: 0 !important;
    border-top: none !important;
    padding-top: 0 !important;
    border-left: 1px solid var(--b-dark-line);
    padding-left: 8px;
    margin-left: 4px;
    flex-shrink: 0;
  }
  .ds-forestry .sidenav .nav-item { border-left: none; border-bottom: 2px solid transparent; padding: 6px 10px; }

  .ds-forestry .main { padding: 14px !important; }
  .ds-forestry .table { font-size: 12.5px; }
  .ds-forestry .table th, .ds-forestry .table td { padding: 8px 10px; }
  .ds-forestry .col-secondary { display: none !important; }
  .ds-forestry .responsive-grid { display: grid !important; grid-template-columns: 1fr !important; gap: 14px !important; }
  .ds-forestry .page-h { flex-direction: column; align-items: flex-start !important; gap: 8px; }
}

@media (max-width: 480px) {
  .ds-forestry .table th, .ds-forestry .table td { padding: 6px 8px; font-size: 11.5px; }
}
