:root {
  --green: #2f7d4f;
  --green-dark: #246340;
  --bg: #f6f7f5;
  --card: #ffffff;
  --line: #e2e5e0;
  --text: #1f2421;
  --muted: #6b726c;
  --danger: #b3261e;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  color: var(--text);
  background: var(--bg);
}

.topbar {
  position: sticky; top: 0; z-index: 5;
  background: var(--green); color: #fff;
  padding: max(env(safe-area-inset-top), 12px) 16px 0;
}
.topbar h1 { margin: 0 0 8px; font-size: 1.25rem; }
.tabs { display: flex; gap: 4px; }
.tab {
  background: transparent; color: #dfeede; border: 0;
  padding: 10px 14px; font-size: .95rem; cursor: pointer;
  border-bottom: 3px solid transparent;
}
.tab.is-active { color: #fff; border-bottom-color: #fff; font-weight: 600; }

main { padding: 16px; max-width: 1000px; margin: 0 auto; }
.view { display: none; }
.view.is-active { display: block; }

.toolbar { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.toolbar input[type="search"] { flex: 1 1 180px; }
input, select, textarea, button { font: inherit; }
input, select, textarea {
  padding: 9px 10px; border: 1px solid var(--line); border-radius: 8px;
  background: #fff; width: 100%;
}
button {
  padding: 9px 14px; border: 1px solid var(--line); border-radius: 8px;
  background: #fff; cursor: pointer;
}
button.primary { background: var(--green); color: #fff; border-color: var(--green); font-weight: 600; }
button.primary:hover { background: var(--green-dark); }
button.danger { color: var(--danger); border-color: #e7c3c0; }
button.icon { border: 0; background: transparent; font-size: 1.1rem; }

.recipe-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  padding: 14px; cursor: pointer; transition: box-shadow .15s, transform .15s;
}
.card:hover { box-shadow: 0 4px 14px rgba(0,0,0,.08); transform: translateY(-1px); }
.card h3 { margin: 0 0 6px; font-size: 1.02rem; }
.card .macros { color: var(--muted); font-size: .82rem; margin-bottom: 8px; }
.chips { display: flex; flex-wrap: wrap; gap: 4px; }
.chip {
  font-size: .72rem; padding: 2px 8px; border-radius: 999px;
  background: #eef3ee; color: var(--green-dark); border: 1px solid #dbe7db;
}
.chip.diet { background: #fdf3e7; color: #8a5a1a; border-color: #f0ddc2; }
.chip.version { background: #eef0fb; color: #3b3f8f; border-color: #dcdff2; }
.card.is-variant { border-left: 3px solid #c7cdf0; }

/* Print-only binder copy */
#print-area { display: none; }
@media print {
  body * { visibility: hidden; }
  #print-area, #print-area * { visibility: visible; }
  #print-area {
    display: block; position: absolute; inset: 0 auto auto 0; width: 100%;
    padding: 0 6px; color: #000; font-size: 12pt;
  }
  .topbar, .backdrop, main { display: none !important; }
  #print-area h1 { font-size: 20pt; margin: 0 0 2px; }
  #print-area h2 { font-size: 13pt; margin: 14px 0 4px; border-bottom: 1px solid #999; }
  #print-area h3 { font-size: 12pt; margin: 10px 0 2px; }
  #print-area .print-version { font-style: italic; margin-bottom: 6px; }
  #print-area .print-meta { color: #333; margin: 2px 0; }
  #print-area .print-source { margin-top: 12px; font-size: 10pt; color: #333; word-break: break-all; }
  #print-area ul, #print-area ol { margin: 4px 0 4px 18px; padding: 0; }
  #print-area li, #print-area p { margin: 2px 0; }
}

.empty, .placeholder { color: var(--muted); }
.placeholder { background: var(--card); border: 1px dashed var(--line); border-radius: 12px; padding: 28px; text-align: center; }
.hidden { display: none !important; }

/* Editor modal */
.backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.45);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 24px 12px; overflow-y: auto; z-index: 20;
}
.editor {
  background: #fff; border-radius: 14px; width: min(680px, 100%);
  display: flex; flex-direction: column; max-height: calc(100vh - 48px);
}
.editor-head, .editor-foot {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 18px; border-bottom: 1px solid var(--line);
}
.editor-foot { border-bottom: 0; border-top: 1px solid var(--line); }
.editor-head h2 { margin: 0; font-size: 1.1rem; flex: 1; }
.editor-body { padding: 16px 18px; overflow-y: auto; display: grid; gap: 14px; }
.editor-body label { display: grid; gap: 4px; font-size: .85rem; color: var(--muted); }
.editor-body label input, .editor-body label textarea { color: var(--text); }
fieldset { border: 1px solid var(--line); border-radius: 10px; padding: 12px; }
legend { font-size: .82rem; color: var(--muted); padding: 0 6px; }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.row3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.row4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 10px; }
.row5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.spacer { flex: 1; }
.ing-preview { font-size: .8rem; color: var(--muted); }
.ing-preview .aisle { margin-top: 6px; }
.ing-preview .aisle b { color: var(--green-dark); }

/* Editor: import bar, verify, images */
.import-bar { display: flex; gap: 8px; }
.import-bar input { flex: 1; }
.verify-row {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: #f4f7f4; border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px;
}
.verify-row span { flex: 1; font-size: .82rem; color: var(--muted); min-width: 180px; }
.img-thumbs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 8px; }
.thumb { position: relative; width: 84px; height: 84px; }
.thumb img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; border: 1px solid var(--line); background: #f0f0f0; }
.thumb-rm {
  position: absolute; top: -7px; right: -7px; width: 22px; height: 22px; padding: 0;
  border-radius: 999px; background: #fff; color: var(--danger); border: 1px solid var(--line);
  font-size: .8rem; line-height: 1; cursor: pointer;
}
.img-add { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.img-add input[type="url"] { flex: 1; min-width: 160px; }
.file-btn {
  display: inline-block; padding: 9px 12px; border: 1px solid var(--green); color: #fff;
  background: var(--green); border-radius: 8px; cursor: pointer; font-size: .9rem; white-space: nowrap;
}
.file-btn:hover { background: var(--green-dark); }
.hint { font-size: .78rem; color: var(--muted); margin: 8px 0 0; }
.card-thumb { width: 100%; height: 130px; object-fit: cover; border-radius: 8px; margin-bottom: 8px; background: #f0f0f0; }

/* Weekly plan */
.week-pick { display: flex; align-items: center; gap: 8px; font-size: .9rem; color: var(--muted); white-space: nowrap; }
.week-pick input { width: auto; }
.plan-summary {
  background: #eef3ee; border: 1px solid #dbe7db; color: var(--green-dark);
  border-radius: 10px; padding: 10px 12px; margin-bottom: 14px; font-size: .85rem;
}
.plan-grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
.plan-card { cursor: default; display: flex; flex-direction: column; gap: 8px; }
.plan-card:hover { box-shadow: none; transform: none; }
.plan-day { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--green-dark); font-weight: 600; }
.plan-day .muted { color: var(--muted); font-weight: 400; }
.plan-recipe { margin: 0; font-size: 1.02rem; cursor: pointer; }
.plan-recipe:hover { color: var(--green-dark); text-decoration: underline; }
.plan-actions { display: flex; align-items: center; gap: 8px; margin-top: auto; padding-top: 4px; }
.plan-actions label { display: flex; align-items: center; gap: 6px; font-size: .78rem; color: var(--muted); flex: 1; }
.plan-actions .push-select { width: auto; flex: 1; padding: 6px 8px; }
.plan-actions .reroll { padding: 6px 10px; font-size: .82rem; }
.plan-reminder { font-size: .76rem; color: var(--muted); line-height: 1.4; }
.reminders-status {
  background: #fff; border: 1px dashed var(--line); border-radius: 10px;
  padding: 8px 12px; margin-bottom: 14px; font-size: .82rem; color: var(--muted);
}
.reminders-status a { color: var(--green-dark); }

/* Shopping list */
.aisle-head {
  margin: 16px 0 6px; font-size: .72rem; text-transform: uppercase;
  letter-spacing: .04em; color: var(--green-dark); font-weight: 600;
}
.aisle-head:first-child { margin-top: 0; }
.shop-row {
  display: flex; align-items: center; gap: 8px;
  background: var(--card); border: 1px solid var(--line); border-radius: 8px;
  padding: 8px 10px; margin-bottom: 6px;
}
.shop-main { display: flex; align-items: center; gap: 10px; flex: 1; margin: 0; cursor: pointer; }
.shop-row input[type="checkbox"] { width: 18px; height: 18px; flex: 0 0 auto; }
.shop-qty { color: var(--muted); font-size: .85rem; min-width: 62px; }
.shop-name { flex: 1; }
.shop-row.is-checked .shop-name, .shop-row.is-checked .shop-qty { text-decoration: line-through; color: var(--muted); }
.shop-remove { color: var(--danger); flex: 0 0 auto; }

@media (max-width: 560px) {
  .row3, .row4, .row5 { grid-template-columns: 1fr 1fr; }
}
