{"js":"<style>
:root {
  --ink: #18140f;
  --paper: #f6f1ea;
  --paper2: #ede7dc;
  --cream: #faf7f2;
  --rust: #b84c2a;
  --rust-soft: rgba(184,76,42,0.08);
  --gold: #c9933a;
  --gold-soft: rgba(201,147,58,0.12);
  --sage: #5e7555;
  --sage-soft: rgba(94,117,85,0.1);
  --wine: #7b2d42;
  --wine-soft: rgba(123,45,66,0.1);
  --muted: #8a7f72;
  --border: #d8d0c5;
  --shadow: rgba(24,20,15,0.08);
  --shadow-md: rgba(24,20,15,0.14);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--paper);
  color: var(--ink);
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

/* ── HEADER ── */
header {
  background: var(--ink);
  color: var(--paper);
  padding: 0 28px;
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
  border-bottom: 2px solid var(--rust);
  position: relative;
  z-index: 10;
}
.logo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.55rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.logo-the { color: rgba(246,241,234,0.45); font-style: italic; font-weight: 400; font-size: 1.1rem; }
.logo-kitchen { color: var(--paper); }
.logo-dot { color: var(--rust); }

.header-nav { display: flex; gap: 4px; }
.nav-btn {
  background: transparent;
  border: none;
  color: rgba(246,241,234,0.5);
  padding: 6px 14px;
  border-radius: 3px;
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem;
  cursor: pointer;
  transition: all 0.18s;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.nav-btn:hover { color: var(--paper); background: rgba(246,241,234,0.08); }
.nav-btn.active { color: var(--paper); background: var(--rust); }

/* ── LAYOUT ── */
.app {
  display: flex;
  flex: 1;
  overflow: hidden;
}

/* ── SIDEBAR ── */
.sidebar {
  width: 260px;
  min-width: 260px;
  background: var(--ink);
  color: var(--paper);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex-shrink: 0;
}
.sidebar::-webkit-scrollbar { width: 3px; }
.sidebar::-webkit-scrollbar-thumb { background: rgba(246,241,234,0.1); }

.sb-section {
  padding: 16px 18px;
  border-bottom: 1px solid rgba(246,241,234,0.06);
}
.sb-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.sb-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.sb-tag {
  padding: 2px 7px;
  border-radius: 2px;
  font-size: 0.7rem;
  border: 1px solid;
  font-family: 'DM Mono', monospace;
}
.sb-tag.r { border-color: rgba(184,76,42,0.5); color: #e0896a; background: rgba(184,76,42,0.08); }
.sb-tag.c { border-color: rgba(94,117,85,0.4); color: #92b087; background: rgba(94,117,85,0.08); }
.sb-tag.e { border-color: rgba(246,241,234,0.15); color: rgba(246,241,234,0.5); background: rgba(246,241,234,0.04); }

.inv-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 0;
  border-bottom: 1px solid rgba(246,241,234,0.05);
  font-size: 0.76rem;
  color: rgba(246,241,234,0.65);
}
.inv-row .inv-cat-badge {
  font-size: 0.6rem;
  font-family: 'DM Mono', monospace;
  color: var(--sage);
  background: rgba(94,117,85,0.15);
  padding: 1px 5px;
  border-radius: 2px;
}
.inv-remove { background: none; border: none; color: rgba(246,241,234,0.18); cursor: pointer; font-size: 0.75rem; padding: 2px 4px; }
.inv-remove:hover { color: var(--rust); }
.add-inv { display: flex; gap: 5px; margin-top: 8px; }
.add-inv input, .add-inv select {
  background: rgba(246,241,234,0.06);
  border: 1px solid rgba(246,241,234,0.12);
  color: var(--paper);
  padding: 4px 7px;
  border-radius: 3px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.73rem;
  flex: 1;
}
.add-inv input::placeholder { color: rgba(246,241,234,0.25); }
.add-inv select option { background: #18140f; }
.add-inv-btn { background: var(--rust); border: none; color: white; padding: 4px 9px; border-radius: 3px; cursor: pointer; font-size: 0.8rem; flex-shrink: 0; }

.past-entry {
  font-size: 0.72rem;
  color: rgba(246,241,234,0.4);
  padding: 4px 0;
  border-bottom: 1px solid rgba(246,241,234,0.05);
  line-height: 1.4;
}
.past-entry .past-date { color: var(--gold); font-family: 'DM Mono', monospace; font-size: 0.6rem; }

/* ── MAIN ── */
.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}

.panel { display: none; flex-direction: column; flex: 1; overflow: hidden; }
.panel.active { display: flex; }

/* ── CHAT ── */
.chat-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.chat-msgs::-webkit-scrollbar { width: 4px; }
.chat-msgs::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

.msg { display: flex; gap: 12px; animation: msgIn 0.25s ease; }
.msg.u { flex-direction: row-reverse; align-self: flex-end; max-width: 72%; }
@keyframes msgIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }

.avatar {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-weight: 600;
}
.avatar.bot { background: var(--rust); color: white; font-family: 'Cormorant Garamond', serif; font-size: 1rem; font-style: italic; }
.avatar.usr { background: var(--ink); color: var(--gold); font-family: 'DM Mono', monospace; font-size: 0.7rem; }

.bubble {
  background: white;
  border: 1px solid var(--border);
  border-radius: 3px 12px 12px 12px;
  padding: 13px 17px;
  font-size: 0.86rem;
  line-height: 1.65;
  box-shadow: 0 2px 8px var(--shadow);
  max-width: 720px;
}
.msg.u .bubble { background: var(--ink); color: var(--paper); border-color: transparent; border-radius: 12px 3px 12px 12px; }

.bubble h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; color: var(--rust); margin-bottom: 10px; font-weight: 600; }
.bubble h3 { font-family: 'Cormorant Garamond', serif; font-size: 0.98rem; margin: 10px 0 3px; color: var(--ink); font-weight: 600; }
.bubble strong { color: var(--rust); }
.bubble em { color: var(--sage); }
.bubble p { margin-bottom: 6px; }
.bubble ul { padding-left: 16px; margin: 4px 0; }
.bubble li { margin-bottom: 2px; }
.bubble hr { border: none; border-top: 1px solid var(--border); margin: 10px 0; }

.day-card {
  background: var(--cream);
  border-left: 3px solid var(--rust);
  padding: 9px 13px;
  margin: 6px 0;
  border-radius: 0 4px 4px 0;
  cursor: pointer;
  transition: background 0.15s;
}
.day-card:hover { background: var(--paper2); }
.day-card .dc-day { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.day-card .dc-meal { font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; margin: 2px 0; }
.day-card .dc-note { font-size: 0.75rem; color: var(--muted); }
.day-card .dc-wine { font-size: 0.72rem; color: var(--wine); margin-top: 4px; display: flex; align-items: center; gap: 4px; }

.wine-match {
  background: var(--gold-soft);
  border: 1px solid rgba(201,147,58,0.25);
  border-radius: 4px;
  padding: 8px 12px;
  margin: 6px 0;
  font-size: 0.8rem;
}
.wine-match .wm-bottle { font-family: 'Cormorant Garamond', serif; font-size: 0.95rem; color: var(--gold); font-weight: 600; }
.wine-match .wm-why { font-size: 0.76rem; color: var(--muted); margin-top: 3px; }

.chips { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 10px; }
.chip {
  background: transparent;
  border: 1px solid var(--border);
  padding: 4px 11px;
  border-radius: 20px;
  font-size: 0.73rem;
  cursor: pointer;
  transition: all 0.15s;
  color: var(--muted);
  font-family: 'DM Sans', sans-serif;
}
.chip:hover { border-color: var(--rust); color: var(--rust); background: var(--rust-soft); }

.typing { display: flex; gap: 12px; align-items: center; }
.typing-dots { background: white; border: 1px solid var(--border); border-radius: 3px 12px 12px 12px; padding: 13px 17px; display: flex; gap: 4px; }
.typing-dots span { width: 5px; height: 5px; border-radius: 50%; background: var(--muted); animation: tdot 1.2s infinite; }
.typing-dots span:nth-child(2) { animation-delay: 0.2s; }
.typing-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes tdot { 0%,60%,100%{transform:translateY(0);opacity:.5} 30%{transform:translateY(-5px);opacity:1} }

/* CHAT INPUT */
.chat-footer {
  border-top: 1px solid var(--border);
  background: var(--cream);
  padding: 12px 28px 16px;
  flex-shrink: 0;
}
.quick-row { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.qp {
  background: white;
  border: 1px solid var(--border);
  padding: 4px 11px;
  border-radius: 20px;
  font-size: 0.72rem;
  cursor: pointer;
  color: var(--muted);
  transition: all 0.15s;
}
.qp:hover { border-color: var(--rust); color: var(--rust); }
.input-row { display: flex; gap: 8px; align-items: flex-end; }
.chat-input {
  flex: 1;
  background: white;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  padding: 10px 14px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.86rem;
  color: var(--ink);
  resize: none;
  min-height: 42px;
  max-height: 110px;
  line-height: 1.5;
  transition: border-color 0.18s;
}
.chat-input:focus { outline: none; border-color: var(--rust); }
.send-btn {
  width: 42px; height: 42px;
  background: var(--rust);
  border: none; color: white;
  border-radius: 6px; cursor: pointer;
  font-size: 1rem; transition: background 0.18s;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.send-btn:hover { background: #9a3d20; }
.send-btn:disabled { background: var(--border); cursor: not-allowed; }

/* ── WEEK PANEL ── */
.week-inner { flex: 1; overflow-y: auto; padding: 24px 28px; }
.week-inner::-webkit-scrollbar { width: 4px; }
.week-inner::-webkit-scrollbar-thumb { background: var(--border); }

.week-topbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px;
}
.week-topbar h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.55rem; font-weight: 600; }
.week-topbar h2 em { color: var(--rust); font-style: normal; }
.week-actions { display: flex; gap: 8px; }
.week-btn {
  background: var(--ink); color: var(--paper);
  border: none; padding: 7px 16px; border-radius: 3px;
  font-family: 'DM Mono', monospace; font-size: 0.68rem;
  letter-spacing: 0.05em; cursor: pointer; transition: background 0.18s;
}
.week-btn:hover { background: var(--rust); }
.week-btn.secondary { background: transparent; border: 1px solid var(--border); color: var(--muted); }
.week-btn.secondary:hover { border-color: var(--rust); color: var(--rust); background: var(--rust-soft); }

.week-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  margin-bottom: 20px;
}
.tile {
  background: white;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 12px 11px;
  min-height: 148px;
  cursor: pointer;
  transition: box-shadow 0.18s, transform 0.18s;
  position: relative;
  overflow: hidden;
}
.tile::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
.tile.weekday::before { background: var(--border); }
.tile.friday::before { background: var(--sage); }
.tile.weekend::before { background: var(--gold); }
.tile:hover { box-shadow: 0 4px 18px var(--shadow-md); transform: translateY(-1px); }
.tile.empty:hover { box-shadow: none; transform: none; }

.t-day { font-family: 'DM Mono', monospace; font-size: 0.58rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 7px; }
.t-meal { font-family: 'Cormorant Garamond', serif; font-size: 0.95rem; line-height: 1.3; margin-bottom: 5px; }
.t-note { font-size: 0.7rem; color: var(--muted); line-height: 1.4; }
.t-wine { font-size: 0.67rem; color: var(--wine); margin-top: 7px; display: flex; align-items: center; gap: 3px; font-family: 'DM Mono', monospace; }
.t-recipe-hint { position: absolute; bottom: 7px; right: 9px; font-size: 0.62rem; color: var(--border); font-family: 'DM Mono', monospace; letter-spacing: 0.05em; transition: color 0.15s; }
.tile:hover .t-recipe-hint { color: var(--rust); }
.t-empty { display: flex; align-items: center; justify-content: center; height: 100px; color: var(--border); font-size: 1.4rem; }

/* SHOPPING */
.shop-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 18px 22px;
  margin-top: 16px;
}
.shop-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; margin-bottom: 14px; }
.shop-cols { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.shop-col h4 { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rust); margin-bottom: 8px; }
.shop-col ul { list-style: none; }
.shop-col li {
  padding: 4px 0;
  border-bottom: 1px solid var(--paper2);
  font-size: 0.8rem;
  display: flex; align-items: center; gap: 8px;
}
.shop-col li::before { content:''; width:11px; height:11px; border:1.5px solid var(--border); border-radius:2px; flex-shrink:0; }

/* ── INTL THURSDAYS ── */
.intl-inner { flex: 1; overflow-y: auto; padding: 28px 32px; }
.intl-hero {
  background: var(--ink);
  border-radius: 8px;
  padding: 32px 36px;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
  text-align: center;
  color: var(--paper);
}
.intl-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, rgba(201,147,58,0.15) 0%, transparent 70%);
}
.intl-hero h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem; font-weight: 600;
  margin-bottom: 6px;
  position: relative;
}
.intl-hero p { color: rgba(246,241,234,0.6); font-size: 0.9rem; position: relative; }
.globe-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--rust); color: white; border: none;
  padding: 12px 28px; border-radius: 4px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem; cursor: pointer;
  margin-top: 20px; position: relative;
  transition: all 0.2s;
}
.globe-btn:hover { background: #9a3d20; transform: scale(1.02); }
.globe-btn.spinning { animation: spin-btn 0.6s ease; }
@keyframes spin-btn { 0%{transform:scale(1)} 50%{transform:scale(0.95) rotate(3deg)} 100%{transform:scale(1)} }

.country-reveal {
  background: white;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 24px 28px;
  margin-bottom: 16px;
  animation: revealIn 0.4s ease;
}
@keyframes revealIn { from{opacity:0;transform:scale(0.97)} to{opacity:1;transform:scale(1)} }
.country-reveal .cr-flag { font-size: 3rem; margin-bottom: 8px; }
.country-reveal .cr-name { font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; font-weight: 600; margin-bottom: 4px; }
.country-reveal .cr-region { font-size: 0.8rem; color: var(--muted); font-family: 'DM Mono', monospace; letter-spacing: 0.06em; text-transform: uppercase; }
.intl-info {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  margin-top: 16px;
}
.intl-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 14px 16px;
}
.intl-card h4 { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--rust); margin-bottom: 8px; }
.intl-card p { font-size: 0.82rem; line-height: 1.55; color: var(--ink); }

.use-for-thursday-btn {
  background: var(--sage); color: white; border: none;
  padding: 9px 20px; border-radius: 4px;
  font-family: 'DM Mono', monospace; font-size: 0.72rem;
  letter-spacing: 0.06em; cursor: pointer;
  margin-top: 14px; transition: background 0.18s;
}
.use-for-thursday-btn:hover { background: #4a6042; }

.intl-history { margin-top: 24px; }
.intl-history h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; margin-bottom: 12px; }
.country-log { display: flex; flex-wrap: wrap; gap: 7px; }
.country-pill {
  background: white; border: 1px solid var(--border);
  padding: 4px 12px; border-radius: 20px;
  font-size: 0.78rem; display: flex; align-items: center; gap: 5px;
}
.country-pill .cp-date { font-size: 0.65rem; color: var(--muted); font-family: 'DM Mono', monospace; }

/* ── VIVINO ── */
.vivino-inner { flex: 1; overflow-y: auto; padding: 24px 28px; }
.vivino-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.vivino-topbar h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.55rem; font-weight: 600; }

.vivino-upload {
  background: white;
  border: 2px dashed var(--border);
  border-radius: 6px;
  padding: 28px;
  text-align: center;
  margin-bottom: 20px;
  transition: border-color 0.18s;
}
.vivino-upload:hover { border-color: var(--rust); }

.vivino-upload .vu-icon { font-size: 2.5rem; margin-bottom: 10px; }
.vivino-upload h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; margin-bottom: 6px; }
.vivino-upload p { font-size: 0.8rem; color: var(--muted); margin-bottom: 14px; }

.vivino-paste-area {
  width: 100%; min-height: 100px;
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: 4px;
  padding: 10px 14px;
  font-family: 'DM Mono', monospace;
  font-size: 0.75rem;
  resize: vertical;
  color: var(--ink);
  margin-bottom: 10px;
}
.vivino-paste-area:focus { outline: none; border-color: var(--rust); }

.parse-btn {
  background: var(--rust); color: white; border: none;
  padding: 8px 20px; border-radius: 4px;
  font-family: 'DM Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.06em; cursor: pointer; transition: background 0.18s;
}
.parse-btn:hover { background: #9a3d20; }

.cellar-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
  margin-bottom: 20px;
}
.stat-card {
  background: white; border: 1px solid var(--border);
  border-radius: 5px; padding: 14px 16px; text-align: center;
}
.stat-card .sc-val { font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 700; color: var(--rust); }
.stat-card .sc-lbl { font-size: 0.7rem; color: var(--muted); font-family: 'DM Mono', monospace; letter-spacing: 0.06em; text-transform: uppercase; }

.bottle-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.bottle-card {
  background: white; border: 1px solid var(--border);
  border-radius: 5px; padding: 14px 16px;
  transition: box-shadow 0.18s;
}
.bottle-card:hover { box-shadow: 0 4px 14px var(--shadow-md); }
.bc-name { font-family: 'Cormorant Garamond', serif; font-size: 0.95rem; font-weight: 600; margin-bottom: 2px; line-height: 1.3; }
.bc-meta { font-size: 0.72rem; color: var(--muted); font-family: 'DM Mono', monospace; margin-bottom: 6px; }
.bc-rating { display: flex; align-items: center; gap: 4px; }
.bc-rating .stars { color: var(--gold); font-size: 0.7rem; }
.bc-rating .score { font-size: 0.72rem; color: var(--muted); }
.bc-qty { font-size: 0.7rem; color: white; background: var(--ink); padding: 1px 6px; border-radius: 2px; font-family: 'DM Mono', monospace; }
.bc-pairing { font-size: 0.72rem; color: var(--sage); margin-top: 6px; border-top: 1px solid var(--paper2); padding-top: 6px; }

.vivino-filter { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 14px; }
.vf-btn {
  background: transparent; border: 1px solid var(--border);
  padding: 4px 12px; border-radius: 20px;
  font-size: 0.72rem; cursor: pointer; color: var(--muted);
  transition: all 0.15s;
}
.vf-btn:hover, .vf-btn.active { border-color: var(--wine); color: var(--wine); background: var(--wine-soft); }

/* ── RECIPE MODAL ── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(24,20,15,0.65);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
  animation: fadeIn 0.2s ease;
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.modal-overlay.hidden { display: none; }
.modal {
  background: var(--cream);
  border-radius: 6px;
  width: 90%; max-width: 680px; max-height: 88vh;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(24,20,15,0.3);
  animation: slideUp 0.25s ease;
}
@keyframes slideUp { from{transform:translateY(12px);opacity:0} to{transform:translateY(0);opacity:1} }
.modal-header {
  background: var(--ink); color: var(--paper);
  padding: 18px 24px;
  display: flex; align-items: flex-start; justify-content: space-between;
  flex-shrink: 0;
}
.modal-header h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; font-weight: 600; line-height: 1.3; }
.modal-header p { font-size: 0.78rem; color: rgba(246,241,234,0.5); margin-top: 3px; }
.modal-close { background: none; border: none; color: rgba(246,241,234,0.4); font-size: 1.3rem; cursor: pointer; padding: 0 4px; line-height: 1; }
.modal-close:hover { color: var(--paper); }
.modal-body { flex: 1; overflow-y: auto; padding: 22px 24px; }
.modal-body::-webkit-scrollbar { width: 4px; }
.modal-body::-webkit-scrollbar-thumb { background: var(--border); }

.recipe-section { margin-bottom: 20px; }
.recipe-section h3 { font-family: 'DM Mono', monospace; font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--rust); margin-bottom: 10px; }
.recipe-section ul, .recipe-section ol { padding-left: 18px; }
.recipe-section li { margin-bottom: 5px; font-size: 0.84rem; line-height: 1.55; }
.recipe-section p { font-size: 0.84rem; line-height: 1.6; }

.wine-pairing-box {
  background: var(--gold-soft); border: 1px solid rgba(201,147,58,0.25);
  border-radius: 4px; padding: 12px 16px;
}
.wine-pairing-box h4 { font-family: 'Cormorant Garamond', serif; font-size: 1rem; color: var(--gold); margin-bottom: 5px; }
.wine-pairing-box p { font-size: 0.8rem; color: var(--ink); }

.recipe-loading { text-align: center; padding: 40px 20px; }
.recipe-loading .rl-icon { font-size: 2rem; margin-bottom: 10px; animation: pulse 1.5s infinite; }
@keyframes pulse { 0%,100%{opacity:0.4} 50%{opacity:1} }
.recipe-loading p { font-size: 0.84rem; color: var(--muted); }

.settings-inner { flex: 1; overflow-y: auto; padding: 24px 28px; max-width: 680px; }
.settings-inner h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; margin-bottom: 20px; }
.sg { background: white; border: 1px solid var(--border); border-radius: 5px; padding: 18px 22px; margin-bottom: 14px; }
.sg h3 { font-family: 'DM Mono', monospace; font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rust); margin-bottom: 12px; }
.sg-row { display: flex; gap: 8px; margin-bottom: 8px; }
.sg-input {
  flex: 1;
  background: var(--paper); border: 1.5px solid var(--border);
  border-radius: 4px; padding: 7px 11px;
  font-family: 'DM Sans', sans-serif; font-size: 0.82rem; color: var(--ink);
}
.sg-input:focus { outline: none; border-color: var(--rust); }
.sg-add { background: var(--rust); color: white; border: none; padding: 7px 14px; border-radius: 4px; cursor: pointer; font-size: 0.8rem; }
.tag-group { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.removable-tag {
  display: flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 20px;
  font-size: 0.76rem; border: 1px solid var(--border); background: var(--paper2);
}
.removable-tag button { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 0.78rem; padding: 0 2px; }
.removable-tag button:hover { color: var(--rust); }
.save-btn { background: var(--ink); color: var(--paper); border: none; padding: 9px 22px; border-radius: 4px; cursor: pointer; font-family: 'DM Mono', monospace; font-size: 0.7rem; letter-spacing: 0.06em; transition: background 0.18s; margin-top: 6px; }
.save-btn:hover { background: var(--rust); }

.empty-state { text-align: center; padding: 60px 20px; color: var(--muted); }
.empty-state .es-icon { font-size: 3rem; margin-bottom: 14px; }
.empty-state h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; color: var(--ink); margin-bottom: 6px; }
.empty-state p { font-size: 0.84rem; }

@media print {
  header, .sidebar, .chat-footer, .quick-row, .week-btn, .nav-btn, .header-nav { display: none !important; }
  body { height: auto; overflow: visible; }
  .app { height: auto; overflow: visible; }
  .panel { display: flex !important; }
  #chat-panel, #intl-panel, #vivino-panel, #settings-panel { display: none !important; }
  .week-inner { overflow: visible; }
  .week-grid { grid-template-columns: repeat(4,1fr); }
  .tile { break-inside: avoid; }
}
</style>

<!-- Optional: load your fonts (FunnelPages sometimes blocks external fonts; if it does, remove this) -->
<link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap" rel="stylesheet">

<header>
  <div class="logo">
    <span class="logo-the">the</span>
    <span class="logo-kitchen">Kitchen</span>
    <span class="logo-dot">·</span>
  </div>
  <div class="header-nav">
    <button class="nav-btn active" onclick="nav('chat',this)">Chat</button>
    <button class="nav-btn" onclick="nav('week',this)">This Week</button>
    <button class="nav-btn" onclick="nav('intl',this)">Int'l Thursdays</button>
    <button class="nav-btn" onclick="nav('vivino',this)">Cellar</button>
    <button class="nav-btn" onclick="nav('settings',this)">Profile</button>
  </div>
</header>

<div class="app">
  <div class="sidebar">
    <div class="sb-section">
      <div class="sb-label">Restrictions</div>
      <div class="sb-tags" id="sb-restrictions"></div>
    </div>
    <div class="sb-section">
      <div class="sb-label">Cuisines</div>
      <div class="sb-tags" id="sb-cuisines"></div>
    </div>
    <div class="sb-section">
      <div class="sb-label">Freezer & Pantry</div>
      <div id="sb-inventory" style="max-height:200px;overflow-y:auto;margin-bottom:8px;"></div>
      <div class="add-inv">
        <input type="text" id="inv-input" placeholder="Add item..." onkeydown="if(event.key==='Enter')addInv()">
        <select id="inv-cat">
          <option value="beef">🥩</option>
          <option value="pork">🐷</option>
          <option value="chicken">🍗</option>
          <option value="lamb">🐑</option>
          <option value="fish">🐟</option>
          <option value="pantry">🫙</option>
          <option value="fresh">🥬</option>
        </select>
        <button class="add-inv-btn" onclick="addInv()">+</button>
      </div>
    </div>
    <div class="sb-section">
      <div class="sb-label">Past Menus</div>
      <div id="sb-past"></div>
    </div>
    <div class="sb-section">
      <div class="sb-label">Int'l Thursdays Log</div>
      <div id="sb-intl-log"></div>
    </div>
  </div>

  <div class="main">
    <div id="chat-panel" class="panel active">
      <div class="chat-msgs" id="chat-msgs"></div>
      <div class="chat-footer">
        <div class="quick-row">
          <button class="qp" onclick="qp('Plan my full week')">📅 Plan my week</button>
          <button class="qp" onclick="qp('Saturday tinkering meal with wine pairing from my cellar')">🍷 Saturday + cellar pairing</button>
          <button class="qp" onclick="qp('What can I make tonight from my freezer?')">🧊 Use my freezer</button>
          <button class="qp" onclick="qp('Friday wing night — two creative flavour combos')">🍗 Wing flavours</button>
          <button class="qp" onclick="qp('Suggest a gluten-free weeknight meal under 30 minutes')">⚡ Quick weeknight</button>
        </div>
        <div class="input-row">
          <textarea class="chat-input" id="chat-input" placeholder="Plan my week, pair a wine, build a recipe..." rows="1"
            onkeydown="if(event.key==='Enter'&&!event.shiftKey){event.preventDefault();send()}"
            oninput="this.style.height='auto';this.style.height=this.scrollHeight+'px'"></textarea>
          <button class="send-btn" id="send-btn" onclick="send()">↑</button>
        </div>
      </div>
    </div>

    <div id="week-panel" class="panel">
      <div class="week-inner">
        <div class="week-topbar">
          <h2>Week of <em id="week-label">—</em></h2>
          <div class="week-actions">
            <button class="week-btn secondary" onclick="nav('chat',document.querySelectorAll('.nav-btn')[0]);qp('Plan my week')">↻ Regenerate</button>
            <button class="week-btn" onclick="window.print()">⊞ Print</button>
          </div>
        </div>
        <div id="week-grid" class="week-grid"></div>
        <div id="shop-card" class="shop-card" style="display:none;">
          <h3>🛒 Shopping List</h3>
          <div class="shop-cols" id="shop-cols"></div>
        </div>
        <div id="week-empty" class="empty-state">
          <div class="es-icon">🍽️</div>
          <h3>No menu planned yet</h3>
          <p>Head to Chat and say "Plan my week"</p>
        </div>
      </div>
    </div>

    <div id="intl-panel" class="panel">
      <div class="intl-inner">
        <div class="intl-hero">
          <h2>🌍 International Thursdays</h2>
          <p>Spin the globe. Cook the world. One country at a time.</p>
          <button class="globe-btn" id="globe-btn" onclick="spinGlobe()">
            <span id="globe-icon">🌐</span> Spin the Globe
          </button>
        </div>
        <div id="country-result"></div>
        <div class="intl-history" id="intl-history-section" style="display:none;">
          <h3>Countries Visited</h3>
          <div class="country-log" id="country-log"></div>
        </div>
      </div>
    </div>

    <div id="vivino-panel" class="panel">
      <div class="vivino-inner">
        <div class="vivino-topbar">
          <h2>Wine Cellar <span style="color:var(--muted);font-size:0.9rem;font-weight:400;" id="cellar-count"></span></h2>
        </div>
        <div id="cellar-loaded" style="display:none;">
          <div class="cellar-stats" id="cellar-stats"></div>
          <div class="vivino-filter" id="vivino-filter"></div>
          <div class="bottle-grid" id="bottle-grid"></div>
        </div>
        <div id="cellar-empty">
          <div class="vivino-upload">
            <div class="vu-icon">🍷</div>
            <h3>Import Your Cellar</h3>
            <p>Paste your Vivino CSV export below. Go to Vivino → My Wines → Export to CSV.</p>
            <textarea class="vivino-paste-area" id="vivino-csv" placeholder="Paste CSV data here...&#10;Wine Name,Winery,Rating,Quantity,Vintage..."></textarea>
            <button class="parse-btn" onclick="parseCellar()">Import Cellar</button>
          </div>
          <div class="empty-state" style="padding:20px 0;">
            <p style="font-size:0.8rem;">Or <a href="#" onclick="loadSampleCellar();return false;" style="color:var(--rust);">load a sample cellar</a> to try it out.</p>
          </div>
        </div>
      </div>
    </div>

    <div id="settings-panel" class="panel">
      <div class="settings-inner">
        <h2>Household Profile</h2>
        <div class="sg">
          <h3>Dietary Restrictions</h3>
          <div class="sg-row">
            <input class="sg-input" id="new-r" placeholder="e.g. nut-free..." onkeydown="if(event.key==='Enter')addTag('r')">
            <button class="sg-add" onclick="addTag('r')">Add</button>
          </div>
          <div class="tag-group" id="r-tags"></div>
        </div>
        <div class="sg">
          <h3>Favourite Cuisines</h3>
          <div class="sg-row">
            <input class="sg-input" id="new-fc" placeholder="e.g. Korean, Italian..." onkeydown="if(event.key==='Enter')addTag('fc')">
            <button class="sg-add" onclick="addTag('fc')">Add</button>
          </div>
          <div class="tag-group" id="fc-tags"></div>
        </div>
        <div class="sg">
          <h3>Cuisines to Explore</h3>
          <div class="sg-row">
            <input class="sg-input" id="new-ec" placeholder="e.g. Georgian, Basque..." onkeydown="if(event.key==='Enter')addTag('ec')">
            <button class="sg-add" onclick="addTag('ec')">Add</button>
          </div>
          <div class="tag-group" id="ec-tags"></div>
        </div>
        <div class="sg">
          <h3>Wine Preferences</h3>
          <div class="sg-row">
            <input class="sg-input" id="new-wp" placeholder="e.g. Côtes du Rhône..." onkeydown="if(event.key==='Enter')addTag('wp')">
            <button class="sg-add" onclick="addTag('wp')">Add</button>
          </div>
          <div class="tag-group" id="wp-tags"></div>
        </div>
        <button class="save-btn" onclick="saveSettings()">Save Profile</button>
      </div>
    </div>
  </div>
</div>

<div class="modal-overlay hidden" id="modal-overlay" onclick="if(event.target===this)closeModal()">
  <div class="modal">
    <div class="modal-header">
      <div>
        <h2 id="modal-title">Recipe</h2>
        <p id="modal-subtitle"></p>
      </div>
      <button class="modal-close" onclick="closeModal()">✕</button>
    </div>
    <div class="modal-body" id="modal-body">
      <div class="recipe-loading">
        <div class="rl-icon">👨‍🍳</div>
        <p>Building your recipe...</p>
      </div>
    </div>
  </div>
</div>

<script>
/* Storage: FunnelPages-safe */
const STORAGE_KEY = 'kitchen-v2';
async function loadS(){ try{ const raw=localStorage.getItem(STORAGE_KEY); if(raw) Object.assign(S, JSON.parse(raw)); }catch(e){} }
async function saveS(){ try{ localStorage.setItem(STORAGE_KEY, JSON.stringify(S)); }catch(e){} }

// ─── STATE ────────────────────────────────────────────────────────────────────
const S = {
  restrictions: ['gluten-free','legume-free','egg-free'],
  favCuisines: ['Italian','French','Korean','Mexican'],
  exploreCuisines: ['Moroccan','Georgian','Basque'],
  winePrefs: ['Côtes du Rhône','Rioja Reserva','Argentine Malbec','Napa Cabernet'],
  inventory: [
    {name:'ground beef',cat:'beef'},{name:'beef roast',cat:'beef'},
    {name:'ground pork',cat:'pork'},{name:'pork shoulder',cat:'pork'},
    {name:'chicken thighs',cat:'chicken'},{name:'whole chicken',cat:'chicken'},
    {name:'ground lamb',cat:'lamb'},{name:'lamb shoulder',cat:'lamb'},
    {name:'salmon',cat:'fish'},{name:'tamari',cat:'pantry'},
    {name:'rice',cat:'pantry'},{name:'corn tortillas',cat:'pantry'},
  ],
  pastMenus: [],
  intlHistory: [],
  cellar: [],
  currentMenu: null,
  currentShop: null,
  chatHistory: []
};

// ─── INIT ─────────────────────────────────────────────────────────────────────
async function init() {
  await loadS();
  renderSidebar();
  renderSettings();
  renderWeekGrid();
  renderCellar();
  renderIntlHistory();
  setWeekLabel();

  if (!S.chatHistory.length) {
    botMsg(`<h2>Welcome to The Kitchen 👨‍🍳</h2>
<p>Your personal menu planning agent — upgraded. I know your household, your restrictions, your freezer, and now your cellar.</p>
<p style="margin-top:8px;"><strong>What's new:</strong> click any meal tile to get the full recipe, spin the globe for International Thursdays, import your Vivino cellar for real-bottle pairings, and I track past menus to keep things fresh week to week.</p>
<p style="margin-top:8px;">Ready to plan?</p>`,
    ['Plan my week','Saturday meal + cellar pairing','Spin Int\'l Thursdays','Wing flavours Friday']);
  } else {
    S.chatHistory.forEach(m => m.role==='user' ? userBubble(m.content) : botBubble(m.content));
  }
}

function setWeekLabel() {
  const now = new Date(), day = now.getDay();
  const mon = new Date(now);
  mon.setDate(now.getDate() - (day === 0 ? 6 : day - 1));
  document.getElementById('week-label').textContent = mon.toLocaleDateString('en-CA',{month:'long',day:'numeric'});
}

// ─── NAV ──────────────────────────────────────────────────────────────────────
function nav(id, btn) {
  document.querySelectorAll('.panel').forEach(p => p.classList.remove('active'));
  document.querySelectorAll('.nav-btn').forEach(b => b.classList.remove('active'));
  document.getElementById(id+'-panel').classList.add('active');
  if (btn) btn.classList.add('active');
}

// ─── SIDEBAR ─────────────────────────────────────────────────────────────────
function renderSidebar() {
  document.getElementById('sb-restrictions').innerHTML = S.restrictions.map(r=>`<span class="sb-tag r">${r}</span>`).join('');
  document.getElementById('sb-cuisines').innerHTML = [
    ...S.favCuisines.map(c=>`<span class="sb-tag c">${c}</span>`),
    ...S.exploreCuisines.map(c=>`<span class="sb-tag e">↗${c}</span>`)
  ].join('');

  const inv = document.getElementById('sb-inventory');
  inv.innerHTML = S.inventory.map((it,i)=>`
    <div class="inv-row">
      <span>${it.name}</span>
      <div style="display:flex;align-items:center;gap:4px;">
        <span class="inv-cat-badge">${it.cat}</span>
        <button class="inv-remove" onclick="removeInv(${i})">×</button>
      </div>
    </div>`).join('');

  const past = document.getElementById('sb-past');
  past.innerHTML = S.pastMenus.length ? S.pastMenus.slice(-5).reverse().map(m=>
    `<div class="past-entry"><div class="past-date">${m.date}</div>${m.summary}</div>`).join('') :
    `<div style="font-size:0.72rem;color:rgba(246,241,234,0.3);">None yet.</div>`;

  const intlLog = document.getElementById('sb-intl-log');
  intlLog.innerHTML = S.intlHistory.length ? S.intlHistory.slice(-5).reverse().map(c=>
    `<div class="past-entry"><div class="past-date">${c.date}</div>${c.flag} ${c.name}</div>`).join('') :
    `<div style="font-size:0.72rem;color:rgba(246,241,234,0.3);">No countries yet.</div>`;
}

function addInv() {
  const v = document.getElementById('inv-input').value.trim();
  const cat = document.getElementById('inv-cat').value;
  if (!v) return;
  S.inventory.push({name:v,cat});
  document.getElementById('inv-input').value = '';
  renderSidebar(); saveS();
}
function removeInv(i) { S.inventory.splice(i,1); renderSidebar(); saveS(); }

// ─── SETTINGS ─────────────────────────────────────────────────────────────────
const tagMap = {
  r: {arr:'restrictions', inputId:'new-r', tagId:'r-tags'},
  fc: {arr:'favCuisines', inputId:'new-fc', tagId:'fc-tags'},
  ec: {arr:'exploreCuisines', inputId:'new-ec', tagId:'ec-tags'},
  wp: {arr:'winePrefs', inputId:'new-wp', tagId:'wp-tags'},
};

function renderSettings() {
  Object.entries(tagMap).forEach(([key, cfg]) => {
    document.getElementById(cfg.tagId).innerHTML = S[cfg.arr].map(v=>`
      <div class="removable-tag">${v}
        <button onclick="removeTag('${key}','${v.replace(/'/g,"\\'")}')">×</button>
      </div>`).join('');
  });
}
function addTag(key) {
  const cfg = tagMap[key];
  const v = document.getElementById(cfg.inputId).value.trim();
  if (v && !S[cfg.arr].includes(v)) { S[cfg.arr].push(v); document.getElementById(cfg.inputId).value=''; renderSettings(); renderSidebar(); saveS(); }
}
function removeTag(key, v) { const cfg=tagMap[key]; S[cfg.arr]=S[cfg.arr].filter(x=>x!==v); renderSettings(); renderSidebar(); saveS(); }
function saveSettings() {
  saveS();
  const b = document.querySelector('.save-btn');
  b.textContent = '✓ Saved'; setTimeout(()=>b.textContent='Save Profile',1500);
}

// ─── CHAT ─────────────────────────────────────────────────────────────────────
function userBubble(t) {
  const el = document.createElement('div');
  el.className = 'msg u';
  el.innerHTML = `<div class="avatar usr">G</div><div class="bubble">${t}</div>`;
  document.getElementById('chat-msgs').appendChild(el);
  scrollChat();
}
function botBubble(html) {
  const el = document.createElement('div');
  el.className = 'msg';
  el.innerHTML = `<div class="avatar bot">K</div><div class="bubble">${html}</div>`;
  document.getElementById('chat-msgs').appendChild(el);
  scrollChat();
}
function botMsg(html, chips=[]) {
  const el = document.createElement('div');
  el.className = 'msg';
  const chipsHtml = chips.length ? `<div class="chips">${chips.map(c=>`<button class="chip" onclick="qp(${JSON.stringify(c)})">${c}</button>`).join('')}</div>` : '';
  el.innerHTML = `<div class="avatar bot">K</div><div class="bubble">${html}${chipsHtml}</div>`;
  document.getElementById('chat-msgs').appendChild(el);
  scrollChat();
}
function showTyping() {
  const el = document.createElement('div');
  el.className = 'msg typing'; el.id = 'typing';
  el.innerHTML = `<div class="avatar bot">K</div><div class="typing-dots"><span></span><span></span><span></span></div>`;
  document.getElementById('chat-msgs').appendChild(el);
  scrollChat();
}
function hideTyping() { document.getElementById('typing')?.remove(); }
function scrollChat() { const m=document.getElementById('chat-msgs'); m.scrollTop=m.scrollHeight; }
function qp(t) { document.getElementById('chat-input').value=t; send(); }

async function send() {
  const inp = document.getElementById('chat-input');
  const t = inp.value.trim();
  if (!t) return;
  inp.value=''; inp.style.height='auto';
  document.getElementById('send-btn').disabled = true;

  userBubble(t);
  S.chatHistory.push({role:'user',content:t});
  showTyping();

  /* NOTE: The AI calls will NOT work from FunnelPages without a server-side proxy + API key.
     Keeping the UI running; show a friendly message instead of failing silently. */
  hideTyping();
  botBubble('<p>Chat is disabled in this FunnelPages embed (API keys can’t be safely used in-browser). Once this is hosted directly on HostGator with a small proxy, chat will work.</p>');
  S.chatHistory.push({role:'assistant',content:'<p>Chat is disabled in this FunnelPages embed (API keys can’t be safely used in-browser). Once this is hosted directly on HostGator with a small proxy, chat will work.</p>'});
  saveS();
  document.getElementById('send-btn').disabled = false;
}

function renderMenuResponse(p){ return '<p>(Menu rendering is available once chat is enabled.)</p>'; }
function applyMenu(p){}

/* Week/Intl/Cellar functions below still work offline (except AI parts) */
function renderWeekGrid() {
  const grid = document.getElementById('week-grid');
  const empty = document.getElementById('week-empty');
  const shop = document.getElementById('shop-card');

  if (!S.currentMenu) {
    grid.innerHTML=''; grid.style.display='none';
    empty.style.display='block'; shop.style.display='none'; return;
  }
  empty.style.display='none'; grid.style.display='grid';
}

function openRecipeFromChat(){ botBubble('<p>Recipe generation needs the AI proxy (hosted version).</p>'); }
async function openRecipe(){ botBubble('<p>Recipe generation needs the AI proxy (hosted version).</p>'); }

function closeModal() { document.getElementById('modal-overlay').classList.add('hidden'); }
document.addEventListener('keydown', e => { if (e.key==='Escape') closeModal(); });

const COUNTRIES = [
  {name:'Japan',flag:'🇯🇵',region:'East Asia'},
  {name:'Morocco',flag:'🇲🇦',region:'North Africa'},
  {name:'Peru',flag:'🇵🇪',region:'South America'},
  {name:'Georgia',flag:'🇬🇪',region:'Caucasus'},
  {name:'Lebanon',flag:'🇱🇧',region:'Middle East'},
  {name:'Thailand',flag:'🇹🇭',region:'Southeast Asia'},
  {name:'Portugal',flag:'🇵🇹',region:'Southern Europe'},
  {name:'Ethiopia',flag:'🇪🇹',region:'East Africa'},
  {name:'Argentina',flag:'🇦🇷',region:'South America'},
  {name:'Vietnam',flag:'🇻🇳',region:'Southeast Asia'},
  {name:'Turkey',flag:'🇹🇷',region:'Middle East / Europe'},
  {name:'India',flag:'🇮🇳',region:'South Asia'},
  {name:'Spain',flag:'🇪🇸',region:'Southern Europe'},
  {name:'Egypt',flag:'🇪🇬',region:'North Africa'},
  {name:'Colombia',flag:'🇨🇴',region:'South America'},
  {name:'Hungary',flag:'🇭🇺',region:'Central Europe'},
  {name:'Philippines',flag:'🇵🇭',region:'Southeast Asia'},
  {name:'Nigeria',flag:'🇳🇬',region:'West Africa'},
  {name:'Greece',flag:'🇬🇷',region:'Southern Europe'},
  {name:'Brazil',flag:'🇧🇷',region:'South America'},
  {name:'South Korea',flag:'🇰🇷',region:'East Asia'},
  {name:'Iran',flag:'🇮🇷',region:'Middle East'},
  {name:'Mexico',flag:'🇲🇽',region:'North America'},
  {name:'France',flag:'🇫🇷',region:'Western Europe'},
  {name:'Jamaica',flag:'🇯🇲',region:'Caribbean'},
  {name:'Sri Lanka',flag:'🇱🇰',region:'South Asia'},
  {name:'Uzbekistan',flag:'🇺🇿',region:'Central Asia'},
  {name:'Cuba',flag:'🇨🇺',region:'Caribbean'},
  {name:'Israel',flag:'🇮🇱',region:'Middle East'},
];

async function spinGlobe() {
  const btn = document.getElementById('globe-btn');
  btn.classList.add('spinning');
  setTimeout(()=>btn.classList.remove('spinning'),600);

  const past = S.intlHistory.map(c=>c.name);
  const available = COUNTRIES.filter(c=>!past.includes(c.name));
  const pool = available.length > 0 ? available : COUNTRIES;
  const country = pool[Math.floor(Math.random()*pool.length)];

  document.getElementById('country-result').innerHTML = `
    <div class="country-reveal">
      <div class="cr-flag">${country.flag}</div>
      <div class="cr-name">${country.name}</div>
      <div class="cr-region">${country.region}</div>
      <div class="intl-info" id="intl-info">
        <div class="intl-card"><h4>Note</h4><p>For full culinary context + recipe + wine pairing, use the hosted version (HostGator) with AI enabled.</p></div>
      </div>
      <button class="use-for-thursday-btn" onclick="useForThursday('${country.name}','${country.flag}')">
        Use for This Thursday →
      </button>
    </div>`;
}

function useForThursday(name, flag) {
  S.intlHistory.push({name, flag, date: new Date().toLocaleDateString('en-CA',{month:'short',day:'numeric'})});
  renderIntlHistory(); renderSidebar(); saveS();
  nav('chat', document.querySelectorAll('.nav-btn')[0]);
  setTimeout(()=>qp(`Plan a complete ${name} Thursday dinner for 4 — gluten-free, legume-free, egg-free. Include a full recipe and wine pairing.`),300);
}

function renderIntlHistory() {
  const sec = document.getElementById('intl-history-section');
  const log = document.getElementById('country-log');
  if (!S.intlHistory.length) { sec.style.display='none'; return; }
  sec.style.display='block';
  log.innerHTML = S.intlHistory.slice().reverse().map(c=>`
    <div class="country-pill">
      ${c.flag} ${c.name}
      <span class="cp-date">${c.date}</span>
    </div>`).join('');
}

function parseCellar() {
  const raw = document.getElementById('vivino-csv').value.trim();
  if (!raw) return;
  const lines = raw.split('\n').filter(l=>l.trim());
  const headers = lines[0].split(',').map(h=>h.trim().toLowerCase().replace(/['"]/g,''));

  const nameIdx = headers.findIndex(h=>h.includes('wine')||h.includes('name'));
  const wineryIdx = headers.findIndex(h=>h.includes('winery')||h.includes('producer'));
  const ratingIdx = headers.findIndex(h=>h.includes('rating')||h.includes('score'));
  const qtyIdx = headers.findIndex(h=>h.includes('qty')||h.includes('quantity')||h.includes('bottles'));
  const vintageIdx = headers.findIndex(h=>h.includes('vintage')||h.includes('year'));
  const typeIdx = headers.findIndex(h=>h.includes('type')||h.includes('varietal'));

  S.cellar = lines.slice(1).map(line => {
    const cols = line.split(',').map(c=>c.trim().replace(/^["']|["']$/g,''));
    return {
      name: cols[nameIdx]||'Unknown',
      winery: cols[wineryIdx]||'',
      rating: parseFloat(cols[ratingIdx])||0,
      qty: parseInt(cols[qtyIdx])||1,
      vintage: cols[vintageIdx]||'',
      type: cols[typeIdx]||'red',
    };
  }).filter(b=>b.name && b.name!=='Unknown');

  saveS();
  renderCellar();
}

function loadSampleCellar() {
  S.cellar = [
    {name:'Primitivo di Manduria',winery:'Feudi di Guagnano',rating:4.1,qty:6,vintage:'2019',type:'red'},
    {name:'Amarone della Valpolicella',winery:'Allegrini',rating:4.5,qty:2,vintage:'2017',type:'red'},
    {name:'Côtes du Rhône',winery:'Chapoutier',rating:3.9,qty:8,vintage:'2021',type:'red'},
    {name:'Rioja Reserva',winery:'La Rioja Alta',rating:4.2,qty:4,vintage:'2016',type:'red'},
    {name:'Malbec Reserva',winery:'Clos de los Siete',rating:4.0,qty:5,vintage:'2020',type:'red'},
    {name:'Cabernet Sauvignon',winery:'Jordan Winery',rating:4.3,qty:3,vintage:'2018',type:'red'},
    {name:'Barolo',winery:'Borgogno',rating:4.4,qty:2,vintage:'2015',type:'red'},
    {name:'Muscadet',winery:'Brégeon',rating:3.8,qty:6,vintage:'2022',type:'white'},
    {name:'Chablis Premier Cru',winery:'Moreau',rating:4.1,qty:3,vintage:'2021',type:'white'},
    {name:'Rosé Prosecco',winery:'Kirkland',rating:3.7,qty:12,vintage:'NV',type:'sparkling'},
    {name:'Ripasso Valpolicella',winery:'Masi',rating:4.0,qty:4,vintage:'2019',type:'red'},
    {name:'Châteauneuf-du-Pape',winery:'Château Rayas',rating:4.6,qty:1,vintage:'2014',type:'red'},
  ];
  saveS();
  renderCellar();
}

let activeFilter = 'all';
function renderCellar() {
  const empty = document.getElementById('cellar-empty');
  const loaded = document.getElementById('cellar-loaded');
  const count = document.getElementById('cellar-count');

  if (!S.cellar.length) { empty.style.display='block'; loaded.style.display='none'; count.textContent=''; return; }

  empty.style.display='none'; loaded.style.display='block';
  const total = S.cellar.reduce((a,b)=>a+(b.qty||1),0);
  count.textContent = `· ${total} bottles`;

  const reds = S.cellar.filter(b=>b.type==='red');
  const whites = S.cellar.filter(b=>b.type==='white');
  const sparkling = S.cellar.filter(b=>b.type==='sparkling');
  const avgRating = (S.cellar.reduce((a,b)=>a+(b.rating||0),0)/S.cellar.length).toFixed(1);

  document.getElementById('cellar-stats').innerHTML = [
    {val:total, lbl:'Bottles'},
    {val:reds.length, lbl:'Reds'},
    {val:whites.length+sparkling.length, lbl:'White/Sparkling'},
    {val:avgRating+'★', lbl:'Avg Rating'},
  ].map(s=>`<div class="stat-card"><div class="sc-val">${s.val}</div><div class="sc-lbl">${s.lbl}</div></div>`).join('');

  const types = ['all',...new Set(S.cellar.map(b=>b.type))];
  document.getElementById('vivino-filter').innerHTML = types.map(t=>
    `<button class="vf-btn ${activeFilter===t?'active':''}" onclick="filterCellar('${t}')">${t.charAt(0).toUpperCase()+t.slice(1)}</button>`
  ).join('');

  const filtered = activeFilter==='all' ? S.cellar : S.cellar.filter(b=>b.type===activeFilter);
  document.getElementById('bottle-grid').innerHTML = filtered.map(b=>`
    <div class="bottle-card">
      <div class="bc-name">${b.name}</div>
      <div class="bc-meta">${b.winery}${b.vintage?' · '+b.vintage:''}</div>
      <div style="display:flex;justify-content:space-between;align-items:center;">
        <div class="bc-rating">
          <span class="stars">${'★'.repeat(Math.round(b.rating||0))}</span>
          <span class="score">${b.rating||'—'}</span>
        </div>
        <span class="bc-qty">×${b.qty||1}</span>
      </div>
      <div class="bc-pairing">
        <span onclick="getPairing('${b.name.replace(/'/g,"\\'")}','${b.type||'red'}')" style="cursor:pointer;">🍽️ Get pairing suggestion →</span>
      </div>
    </div>`).join('');
}

function filterCellar(type) { activeFilter = type; renderCellar(); }

async function getPairing(name, type) {
  nav('chat', document.querySelectorAll('.nav-btn')[0]);
  setTimeout(()=>qp(`I have a bottle of ${name} (${type}). What should I cook this weekend to pair with it? Keep restrictions in mind: ${S.restrictions.join(', ')}.`),300);
}

init();
</script>","embed":""}
the
Kitchen
·
Restrictions
Cuisines
Freezer & Pantry
Past Menus
Int'l Thursdays Log
Week of —
🛒 Shopping List
🍽️
No menu planned yet
Head to Chat and say "Plan my week"
🌍 International Thursdays
Spin the globe. Cook the world. One country at a time.
Countries Visited
Wine Cellar
🍷
Import Your Cellar
Paste your Vivino CSV export below. Go to Vivino → My Wines → Export to CSV.
Or load a sample cellar to try it out.
Household Profile
Dietary Restrictions
Favourite Cuisines
Cuisines to Explore
Wine Preferences
Recipe
👨🍳
Building your recipe...