:root {
  --bg: #f5f7fb;
  --surface: rgba(255,255,255,0.88);
  --surface-strong: #ffffff;
  --line: #dde4ef;
  --text: #1f2937;
  --muted: #667085;
  --primary: #4f7f62;
  --primary-2: #6f9f7f;
  --accent: #d9ecde;
  --danger: #c64b4b;
  --danger-soft: #fdecec;
  --warning: #b37b00;
  --success: #216f41;
  --radius: 20px;
  --shadow: 0 14px 40px rgba(31, 41, 55, 0.08);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, #fcfefc 0%, #f3f7fb 45%, #eef2f7 100%);
  color: var(--text);
}
button, input, select, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }

.page-shell {
  width: min(1280px, calc(100vw - 28px));
  margin: 0 auto;
  padding: 28px 0 42px;
}

.site-header {
  display: grid;
  gap: 18px;
  margin-bottom: 22px;
}

.hero-card, .card {
  background: var(--surface);
  border: 1px solid rgba(221, 228, 239, 0.9);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}

.hero-card {
  padding: 26px 28px;
  background: linear-gradient(135deg, rgba(255,255,255,0.97), rgba(239,248,243,0.9));
}
.compact-hero { padding: 22px 24px; }
.hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}
.hero-card h1 {
  margin: 0;
  font-size: clamp(1.7rem, 2.6vw, 2.45rem);
}
.subtitle { color: var(--muted); margin: 8px 0 0; line-height: 1.45; }
.hero-meta, .actions-row, .tabs-wrap, .inline-tags, .stack { display: flex; gap: 10px; flex-wrap: wrap; }
.stack { flex-direction: column; }
.gap-sm { gap: 12px; }
.gap-xs { gap: 6px; }
.align-end { align-items: flex-end; }

nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.nav-link {
  padding: 11px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(221, 228, 239, 0.85);
  color: var(--muted);
  transition: 0.18s ease;
}
.nav-link:hover, .nav-link.active {
  color: var(--text);
  background: var(--surface-strong);
  box-shadow: 0 8px 26px rgba(79, 127, 98, 0.12);
  transform: translateY(-1px);
}

.layout { display: grid; gap: 18px; }
.grid { display: grid; gap: 18px; }
.stats-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.two-cols { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.vegetables-grid { grid-template-columns: 320px minmax(0, 1fr); }

.card {
  padding: 22px;
}
.card-header, .toolbar-row, .card-actions-line, .plot-meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.card-header h2, .toolbar-row h2, .card h3, .card h4 { margin: 0; }
.no-pad-bottom { padding-bottom: 0; }
.eyebrow, .section-kicker { color: var(--primary); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.muted { color: var(--muted); }
.small { font-size: .92rem; }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: .86rem;
  border: 1px solid transparent;
  background: rgba(79, 127, 98, 0.12);
  color: var(--primary);
  white-space: nowrap;
}
.badge.soft { background: rgba(111, 159, 127, 0.12); color: var(--primary-2); }
.badge.success { background: rgba(33, 111, 65, 0.12); color: var(--success); }
.badge.warning { background: rgba(179,123,0,0.14); color: var(--warning); }
.badge.danger { background: rgba(198,75,75,0.13); color: var(--danger); }
.badge.muted { background: rgba(102,112,133,.1); color: var(--muted); }

.btn {
  border: none;
  border-radius: 14px;
  padding: 11px 15px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: white;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(79,127,98,.18);
  transition: .18s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn.secondary { background: linear-gradient(135deg, #5f7fcf, #7399da); }
.btn.ghost {
  background: rgba(255,255,255,0.85);
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: none;
}
.btn.danger { background: linear-gradient(135deg, #c64b4b, #db6a6a); }
.btn.danger.ghost { color: var(--danger); border-color: rgba(198,75,75,.25); background: var(--danger-soft); }
.compact-wrap { gap: 8px; }

.stat-card h2 { margin: 8px 0 4px; font-size: clamp(1.8rem, 3vw, 2.3rem); }

.message {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.9);
}
.message.success { background: rgba(33,111,65,.11); border-color: rgba(33,111,65,.18); color: var(--success); }
.message.danger { background: rgba(198,75,75,.12); border-color: rgba(198,75,75,.18); color: var(--danger); }
.message.warning { background: rgba(179,123,0,.12); border-color: rgba(179,123,0,.18); color: var(--warning); }
.hidden { display: none !important; }

.list-block, .suggestions-grid, .plots-grid, .orchard-grid, .flowers-grid, .species-grid {
  display: grid;
  gap: 12px;
}
.list-item, .species-card, .flower-card, .orchard-card, .detail-panel, .detail-subgroup {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,0.82);
  padding: 16px;
}
.list-item-column { display: grid; gap: 10px; }
.empty-state {
  border: 1px dashed var(--line);
  border-radius: 18px;
  padding: 18px;
  text-align: center;
  color: var(--muted);
  background: rgba(255,255,255,0.55);
}
.list-button {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,0.84);
  padding: 14px 15px;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 6px;
}
.list-button.active, .tab.active {
  border-color: rgba(79,127,98,.4);
  background: rgba(217,236,222,.58);
}
.tab {
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,0.8);
  cursor: pointer;
}
.detail-stack { display: grid; gap: 14px; }
.cycle-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px 16px; margin-top: 14px; }
.inline-tag {
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(79,127,98,.1);
  color: var(--primary);
  font-size: .88rem;
}
.inline-tag.soft { background: rgba(95,127,207,.09); color: #4d63aa; }

.progress {
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: rgba(79,127,98,.1);
  overflow: hidden;
}
.progress-bar {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #7bc197, #4f7f62);
}
.plot-bar {
  display: flex;
  height: 38px;
  overflow: hidden;
  border-radius: 14px;
  background: rgba(79,127,98,.08);
  margin: 12px 0;
}
.plot-segment {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .84rem;
  color: white;
  min-width: 44px;
  text-align: center;
  padding: 0 8px;
}
.plot-segment.empty { background: rgba(102,112,133,.24); color: var(--text); }
.callout {
  margin-top: 14px;
  border-radius: 18px;
  padding: 14px 16px;
  border: 1px solid rgba(79,127,98,.15);
}
.callout.soft { background: rgba(217,236,222,.45); }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}
.compact-form { margin-top: 10px; }
.form-grid label {
  display: grid;
  gap: 8px;
  font-weight: 600;
  color: var(--text);
}
.form-grid input, .form-grid select, .form-grid textarea {
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--line);
  padding: 12px 14px;
  background: rgba(255,255,255,.92);
  color: var(--text);
}
.form-grid textarea { resize: vertical; min-height: 88px; }
.full-width { grid-column: 1 / -1; }

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.44);
  display: grid;
  place-items: center;
  padding: 18px;
  z-index: 90;
}
.modal-card {
  width: min(860px, 100%);
  max-height: min(88vh, 1000px);
  overflow: auto;
  border-radius: 24px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(221,228,239,.95);
  box-shadow: 0 30px 80px rgba(15,23,42,.22);
  padding: 22px;
}
.modal-card.large { width: min(980px, 100%); }
.modal-header { position: sticky; top: 0; background: rgba(255,255,255,.98); z-index: 2; padding-bottom: 10px; }

.suggestion-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,.82);
  display: grid;
  gap: 10px;
}
.suggestion-card .small { line-height: 1.4; }

.species-grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.orchard-grid, .flowers-grid, .plots-grid { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.orchard-card, .flower-card, .species-card { display: grid; gap: 12px; }
.orchard-meta { display: grid; gap: 8px; }
.table-like { display: grid; gap: 8px; }
.table-like .row { display: flex; justify-content: space-between; gap: 16px; border-bottom: 1px dashed rgba(221,228,239,.8); padding-bottom: 6px; }
.table-like .row:last-child { border-bottom: none; padding-bottom: 0; }

@media (max-width: 1024px) {
  .stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .two-cols, .vegetables-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .page-shell { width: min(100vw - 16px, 100%); padding-top: 16px; }
  .hero-card, .card, .modal-card { padding: 16px; }
  .hero-top, .card-header, .toolbar-row, .card-actions-line, .plot-meta { flex-direction: column; }
  .form-grid, .cycle-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr; }
}
