:root {
  --green-900: #081c15;
  --green-800: #1b4332;
  --green-700: #2d6a4f;
  --green-600: #40916c;
  --green-500: #52b788;
  --green-400: #74c69d;
  --green-300: #95d5b2;
  --green-200: #b7e4c7;
  --green-100: #d8f3dc;
  --green-50:  #f0faf3;
  --cream:     #fdf8f0;
  --text-dark: #0d2818;
}

body {
  background-color: var(--green-50);
  color: var(--text-dark);
  font-family: 'Segoe UI', system-ui, sans-serif;
}

/* ── Navbar ── */
.navbar-farm {
  background-color: var(--green-800);
  border-bottom: 3px solid var(--green-600);
}
.navbar-farm .navbar-brand {
  color: #fff;
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: .02em;
}
.navbar-farm .navbar-brand span { color: var(--green-300); }
.navbar-farm .nav-link {
  color: var(--green-200) !important;
  font-size: .9rem;
  padding: .5rem 1rem;
  border-radius: 6px;
  transition: background .2s;
}
.navbar-farm .nav-link:hover,
.navbar-farm .nav-link.active {
  background-color: var(--green-700);
  color: #fff !important;
}
.navbar-farm .nav-link.active { font-weight: 600; }

/* ── Page header ── */
.page-hero {
  background: linear-gradient(135deg, var(--green-800) 0%, var(--green-700) 100%);
  color: #fff;
  padding: 2.5rem 0 2rem;
  margin-bottom: 2rem;
}
.page-hero h1 { font-size: 1.9rem; font-weight: 700; margin: 0; }
.page-hero p  { color: var(--green-200); margin: .3rem 0 0; font-size: .95rem; }

/* ── Stat cards ── */
.stat-card {
  background: #fff;
  border-radius: 12px;
  padding: 1.4rem 1.6rem;
  box-shadow: 0 2px 8px rgba(27,67,50,.08);
  height: 100%;
}
.stat-card .stat-value { font-size: 2.2rem; font-weight: 700; color: var(--green-800); line-height: 1; }
.stat-card .stat-label { color: #555; font-size: .85rem; margin-top: .3rem; }
.stat-card .stat-icon  { font-size: 2rem; opacity: .25; }
.stat-card.accent-yellow { background: #fffdf0; }
.stat-card.accent-red    { background: #fff5f5; }
.stat-card.accent-blue   { background: #f0f7ff; }

/* ── Section card ── */
.section-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(27,67,50,.07);
  margin-bottom: 1.5rem;
}
.section-card .section-card-header {
  background: var(--green-800);
  color: #fff;
  border-radius: 12px 12px 0 0;
  padding: .85rem 1.25rem;
  font-weight: 600;
  font-size: 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.section-card .section-card-body { padding: 1.25rem; }

/* ── Badges / pills ── */
.badge-done    { background-color: var(--green-600); color: #fff; }
.badge-partial { background-color: #e9b949;          color: #3d2b00; }
.badge-pending { background-color: #c0392b;          color: #fff; }
.badge-inprog  { background-color: #2980b9;          color: #fff; }

/* ── Table ── */
.table-farm thead th {
  background-color: var(--green-100);
  color: var(--green-800);
  font-weight: 600;
  border-bottom: 2px solid var(--green-300);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.table-farm tbody tr:hover { background-color: var(--green-50); }

/* ── Buttons ── */
.btn-farm-primary {
  background-color: var(--green-700);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 500;
}
.btn-farm-primary:hover { background-color: var(--green-800); color: #fff; }
.btn-farm-outline {
  border: 2px solid var(--green-700);
  color: var(--green-700);
  border-radius: 8px;
  font-weight: 500;
  background: transparent;
}
.btn-farm-outline:hover { background-color: var(--green-700); color: #fff; }

/* ── Progress bar ── */
.progress-farm { background-color: var(--green-100); border-radius: 20px; height: 10px; }
.progress-farm .progress-bar { background-color: var(--green-500); border-radius: 20px; }

/* ── Worker avatar ── */
.worker-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background-color: var(--green-700);
  color: #fff;
  font-weight: 700;
  font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* ── Crop tab pills ── */
.crop-tabs .nav-link {
  color: var(--green-700);
  border-radius: 30px;
  padding: .4rem 1.2rem;
  font-size: .9rem;
  border: 2px solid var(--green-300);
  margin-right: .4rem;
}
.crop-tabs .nav-link.active {
  background: var(--green-700);
  color: #fff;
  border-color: var(--green-700);
}

/* ── Timeline ── */
.timeline-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--green-500);
  border: 2px solid var(--green-300);
  flex-shrink: 0;
  margin-top: 4px;
}
.timeline-line {
  width: 2px;
  background: var(--green-200);
  flex: 1;
  min-height: 20px;
  margin: 2px auto;
}

/* ── Report month selector ── */
.month-chip {
  display: inline-block;
  padding: .35rem .9rem;
  border-radius: 20px;
  border: 2px solid var(--green-300);
  font-size: .82rem;
  cursor: pointer;
  transition: all .2s;
  color: var(--green-700);
}
.month-chip.active, .month-chip:hover {
  background: var(--green-700);
  color: #fff;
  border-color: var(--green-700);
}

/* ── Footer ── */
footer {
  background-color: var(--green-800);
  color: var(--green-200);
  text-align: center;
  padding: 1.2rem;
  font-size: .82rem;
  margin-top: 3rem;
}

/* ── Responsive tweaks ── */
@media (max-width: 767px) {
  .page-hero h1 { font-size: 1.4rem; }
  .stat-card .stat-value { font-size: 1.7rem; }
}
