/* Pantry — ported from the original artifact's inline styles. */
:root {
  --cream: #f5f0e8;
  --dark: #1a1a14;
  --accent: #c84b2f;
  --mid: #8a8070;
  --card-bg: #fff;
  --border: #e0d8cc;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
}

body {
  min-height: 100vh;
  background: var(--cream);
  font-family: "Georgia", "Times New Roman", serif;
  color: var(--dark);
  -webkit-font-smoothing: antialiased;
}

/* Header */
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: max(20px, env(safe-area-inset-top)) 24px 16px;
  border-bottom: 1px solid var(--border);
}
.logo { display: flex; align-items: center; gap: 8px; }
.logo-icon { font-size: 22px; color: var(--accent); }
.logo-text { font-size: 22px; letter-spacing: 0.12em; font-weight: 400; font-variant: small-caps; }
.reset-btn { background: none; border: none; color: var(--mid); cursor: pointer; font-size: 13px; font-family: inherit; }

/* Layout */
.main { max-width: 680px; margin: 0 auto; padding: 32px 20px calc(60px + env(safe-area-inset-bottom)); }

/* Capture */
.capture-wrap { display: flex; flex-direction: column; gap: 24px; }
.tagline { font-size: 26px; line-height: 1.35; font-weight: 400; margin: 0; }
.btn-group { display: flex; flex-direction: column; gap: 12px; }
.upload-btn {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 24px; border: 2px solid var(--border); border-radius: 12px;
  background: #fffdf9; cursor: pointer; font-size: 16px;
  font-family: inherit; color: var(--dark); text-align: left;
  transition: border-color 0.2s;
}
.upload-btn:hover, .upload-btn:active { border-color: var(--accent); }
.upload-icon { font-size: 28px; }

/* Centered loading column */
.centered-col { display: flex; flex-direction: column; align-items: center; gap: 24px; padding-top: 40px; }
.preview { width: 100%; max-height: 300px; object-fit: cover; border-radius: 12px; border: 1px solid var(--border); }
.preview-small { width: 100%; max-height: 180px; object-fit: cover; border-radius: 10px; border: 1px solid var(--border); }
.spinner-wrap { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.detecting-label { color: var(--mid); font-size: 15px; margin: 0; letter-spacing: 0.04em; }

/* Confirm */
.confirm-wrap { display: flex; flex-direction: column; gap: 18px; }
.section-title { font-size: 20px; font-weight: 400; margin: 0; letter-spacing: 0.02em; }
.section-sub { font-size: 13px; color: var(--mid); margin: -10px 0 0; }
.chip-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px 6px 14px; border-radius: 999px; font-size: 13px;
  border: 1px solid; transition: all 0.15s;
}
.chip:hover { opacity: 0.85; }
.chip-on { background: var(--dark); color: var(--cream); border-color: var(--dark); }
.chip-off { background: transparent; color: var(--mid); border-color: var(--border); }
.chip-label { cursor: pointer; }
.chip-x { cursor: pointer; font-size: 10px; opacity: 0.6; }
.add-row { display: flex; gap: 8px; }
.add-input {
  flex: 1; padding: 10px 14px; border: 1px solid var(--border); border-radius: 8px;
  background: #fffdf9; font-size: 16px; font-family: inherit; outline: none; color: var(--dark);
}
.add-btn { width: 44px; background: var(--accent); color: #fff; border: none; border-radius: 8px; font-size: 20px; cursor: pointer; }
.primary-btn {
  padding: 14px 24px; background: var(--accent); color: #fff; border: none; border-radius: 10px;
  font-size: 15px; cursor: pointer; font-family: inherit; align-self: stretch;
}
.error-box { padding: 12px 16px; background: #fde8e4; border: 1px solid #f5c0b5; border-radius: 8px; font-size: 13px; color: #a03020; }
.debug-box { padding: 10px 14px; background: #f0f4ff; border: 1px solid #c0d0f0; border-radius: 8px; font-size: 11px; color: #446; font-family: monospace; word-break: break-all; }

/* Results */
.results-wrap { display: flex; flex-direction: column; gap: 40px; }
.section { display: flex; flex-direction: column; gap: 14px; }
.recipe-grid { display: flex; flex-direction: column; gap: 10px; }
.recipe-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.recipe-card:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.07); }
.recipe-top { display: flex; align-items: center; gap: 14px; padding: 14px 16px; cursor: pointer; }
.recipe-rank { font-size: 12px; color: var(--accent); font-weight: 700; min-width: 24px; }
.recipe-info { flex: 1; }
.recipe-name { font-size: 15px; font-weight: 500; }
.recipe-meta { font-size: 12px; color: var(--mid); margin-top: 2px; }
.chevron { font-size: 10px; color: var(--mid); }
.recipe-body { padding: 0 16px 16px; border-top: 1px solid var(--border); }
.uses-row { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0 10px; }
.use-chip { font-size: 11px; padding: 3px 9px; background: #f0ece4; border-radius: 999px; color: var(--mid); }
.steps-list { margin: 0; padding-left: 18px; }
.step-item { font-size: 13px; line-height: 1.6; color: #444; margin-bottom: 4px; }

.plan-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.day-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px; display: flex; flex-direction: column; gap: 8px; }
.day-card:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.07); }
.day-label { font-size: 13px; font-weight: 700; letter-spacing: 0.06em; color: var(--accent); }
.meal-row { display: flex; gap: 8px; align-items: flex-start; }
.meal-type { font-size: 13px; flex-shrink: 0; margin-top: 1px; }
.meal-text { font-size: 13px; line-height: 1.4; color: var(--dark); }
.day-note { font-size: 11px; color: var(--mid); border-top: 1px solid var(--border); padding-top: 8px; margin-top: 2px; }

@media (max-width: 420px) {
  .plan-grid { grid-template-columns: 1fr; }
  .tagline { font-size: 23px; }
}

/* Animations */
@keyframes spin { to { transform: rotate(360deg); } }
.spinner { width: 36px; height: 36px; border: 3px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.fade-in { animation: fadeIn 0.35s ease both; }
