:root { --gap: 14px; --fg: #0e0e0e; --bg: #fafafa; --card: #ffffff; --muted: #6b7280; --accent: #8b5cf6; }
*{ box-sizing: border-box; }
html,body{ margin:0; padding:0; font:16px/1.45 system-ui, -apple-system, Segoe UI, Roboto, sans-serif; color:var(--fg); background:var(--bg); }
.wrap{ max-width: 920px; margin:0 auto; padding: 22px; }
header h1{ margin:0 0 8px; font-size: 1.6rem; }
.userbar{ display:flex; gap:10px; align-items:center; }
.userbar form.inline{ margin-left:auto; }
.userbar button{ border:0; background:var(--accent); color:white; padding:6px 10px; border-radius:8px; cursor:pointer; }
.flash{ background:#ecfccb; border:1px solid #a3e635; padding:10px; border-radius:10px; margin: 12px 0; }
.card{ background:var(--card); border:1px solid #e5e7eb; border-radius:14px; padding:16px; margin: 16px 0; box-shadow: 0 1px 2px rgba(0,0,0,0.03); }
label{ display:block; font-weight:600; margin:8px 0 6px; }
input[type=text], input[type=number], select, textarea{ width:100%; padding:10px; border:1px solid #e5e7eb; border-radius:10px; }
textarea{ resize: vertical; }
button{ margin-top:12px; border:0; background:var(--accent); color:#fff; padding:10px 14px; border-radius:12px; cursor:pointer; }
.grid{ display:grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
.checkbox{ display:flex; align-items:end; }
#notes{ display:grid; gap:12px; }
.wine-photo{ margin:12px 0 6px; }
.wine-photo img{ max-width: 220px; height:auto; border-radius:12px; border:1px solid #e5e7eb; display:block; }
.wine-photo .caption{ color:var(--muted); font-size:.9rem; margin-top:4px; }
.note{ border:1px solid #e5e7eb; border-radius:12px; padding:12px; background:white; }
.note.mine{ border-color:#c4b5fd; background:#faf5ff; }
.note header{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
.note .who{ font-weight:700; }
.note .meta{ color:var(--muted); font-size: .9rem; }
footer{ margin:24px 0 8px; color:var(--muted); text-align:center; }
@media (max-width: 640px){ .grid{ grid-template-columns: 1fr; } }
.wine-info {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 16px;
  padding: 12px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  margin: 12px 0 18px;
}
.wine-info__photo img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  display: block;
}
.wine-info__title {
  font-size: 1.05rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 4px;
}
.wine-info__title .vintage {
  color: #6b7280;
  font-weight: 600;
}
.chip.bio {
  background: #16a34a14;
  color: #16a34a;
  border: 1px solid #16a34a66;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 700;
}
.wine-info__line {
  color: #374151;
  margin-bottom: 6px;
}
.wine-info__row span {
  color: #374151;
  display: flex;
  align-items: center;
  gap: 6px;
}
.wine-info__row span::first-letter {
  margin-right: 2px;
}.wine-info__row:first-of-type { border-top: 0; padding-top: 4px; }
.wine-info__row span { color: #6b7280; }
.wine-info__notes {
  margin-top: 8px;
  color: #374151;
}
@media (max-width: 640px){
  .wine-info { grid-template-columns: 1fr; }
}
.userbar {
  display: flex;
  align-items: center;
  gap: 8px;
}
.userbar .admin-link {
  margin-left: 12px;
  font-size: 0.9rem;
  color: #2563eb;
  text-decoration: underline;
}