/* voyage — mobile-first styles. Bordeaux wine palette. */
:root {
  --wine: #6b1f3a;
  --wine-dark: #4a1428;
  --wine-light: #f3e6ea;
  --gold: #c9a23f;
  --ink: #221a1d;
  --muted: #6f6068;
  --line: #e7dde1;
  --bg: #faf7f8;
  --card: #ffffff;
  --ok: #2e7d4f;
  --no: #b23b3b;
  --maybe: #b9892a;
  --radius: 14px;
  --shadow: 0 1px 3px rgba(40, 10, 20, .08), 0 6px 18px rgba(40, 10, 20, .05);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.5;
}
a { color: var(--wine); }

/* ---- top bar / nav ---- */
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  gap: .5rem; padding: .6rem 1rem;
  background: var(--wine); color: #fff;
  padding-top: max(.6rem, env(safe-area-inset-top));
}
.brand { color: #fff; text-decoration: none; font-weight: 700; font-size: 1.05rem; }
.nav { display: flex; align-items: center; gap: .25rem; }
.nav a { color: #f3dbe3; text-decoration: none; font-size: .9rem; padding: .35rem .55rem; border-radius: 999px; }
.nav a.on { background: rgba(255,255,255,.18); color: #fff; }
.nav a.who { background: var(--gold); color: var(--wine-dark); font-weight: 600; }

.wrap { max-width: 680px; margin: 0 auto; padding: 1rem 1rem 3rem; }

/* ---- hero / headings ---- */
.eyebrow { color: var(--muted); text-transform: uppercase; letter-spacing: .06em; font-size: .8rem; margin: .2rem 0; }
.trip-name, .page-head h1 { font-size: 1.7rem; margin: .1rem 0 .5rem; color: var(--wine-dark); }
.intro { color: var(--muted); }
.page-head { margin-bottom: 1rem; }
.hint { color: var(--muted); font-size: .9rem; }
.hint.small { font-size: .82rem; }

.countdown { background: var(--wine-light); color: var(--wine-dark); padding: .5rem .75rem; border-radius: 10px; font-size: .92rem; display: inline-block; }
.countdown.closed { background: #efe7d6; color: #7a5d12; }

/* ---- cards ---- */
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.1rem; margin: 1rem 0; box-shadow: var(--shadow);
}
.card.center { text-align: center; }
.card h1, .card h2 { margin-top: 0; color: var(--wine-dark); }

/* ---- forms / buttons ---- */
.stack { display: flex; flex-direction: column; gap: .6rem; }
input[type=password], input[type=text], input[type=datetime-local], textarea {
  width: 100%; padding: .7rem .8rem; font-size: 1rem; border: 1px solid var(--line);
  border-radius: 10px; background: #fff; color: var(--ink);
}
textarea { resize: vertical; font-family: inherit; }
.btn-primary {
  display: inline-block; text-align: center; background: var(--wine); color: #fff;
  border: 0; padding: .8rem 1rem; font-size: 1rem; font-weight: 600;
  border-radius: 10px; text-decoration: none; cursor: pointer;
}
.btn-primary:active { background: var(--wine-dark); }
.btn-small {
  display: inline-block; background: #fff; color: var(--wine-dark); border: 1px solid var(--line);
  padding: .4rem .65rem; border-radius: 8px; font-size: .85rem; cursor: pointer; text-decoration: none;
}
.btn-small.danger { color: #fff; background: var(--no); border-color: var(--no); }
.inline { display: inline; }
.row { display: flex; gap: .5rem; align-items: center; }
.row.wrap { flex-wrap: wrap; }
.error { background: #fdecec; color: var(--no); padding: .5rem .7rem; border-radius: 8px; }

/* ---- name picker ---- */
.household { border: 1px solid var(--line); border-radius: 10px; padding: .6rem .8rem; margin: .6rem 0; }
.household legend { color: var(--muted); font-size: .85rem; padding: 0 .3rem; }
.name-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.name-btn {
  padding: .8rem; border: 1px solid var(--line); border-radius: 10px; background: #fff;
  font-size: 1rem; cursor: pointer; text-align: left;
}
.name-btn.teen { background: #fbf7ee; }
.name-btn.current { border-color: var(--wine); box-shadow: 0 0 0 2px var(--wine-light); }
.teen-tag { color: var(--gold); font-size: .72rem; }

/* ---- item cards ---- */
.day-head { font-size: 1.15rem; color: var(--wine-dark); border-bottom: 2px solid var(--wine-light); padding-bottom: .3rem; margin: 1.4rem 0 .6rem; }
.day-tag, .day-tag { color: var(--muted); font-size: .82rem; margin: 1rem 0 .25rem; font-weight: 600; }
.item-card { background: var(--card); border: 1px solid var(--line); border-left: 4px solid var(--line); border-radius: var(--radius); padding: .9rem 1rem; margin: .7rem 0; box-shadow: var(--shadow); }
.item-card.open { border-left-color: var(--gold); }
.item-card.kind-choice.open, .item-card.kind-vote.open { border-left-color: var(--wine); }
.item-head { display: flex; flex-wrap: wrap; align-items: baseline; gap: .4rem .6rem; }
.time { color: var(--wine); font-weight: 700; font-size: .9rem; min-width: 3rem; }
.item-title { font-size: 1.05rem; margin: 0; flex: 1 1 60%; }
.badges { display: flex; gap: .3rem; flex-wrap: wrap; }
.who-badge { font-size: .72rem; color: var(--muted); background: #f2eef0; padding: .12rem .45rem; border-radius: 999px; }
.badge { font-size: .72rem; padding: .12rem .5rem; border-radius: 999px; font-weight: 600; }
.badge.booked { background: #eef0f2; color: #5a6573; }
.badge.open { background: var(--wine); color: #fff; }
.desc { margin: .5rem 0; color: #463b40; font-size: .95rem; }
.meta { display: flex; gap: .8rem; flex-wrap: wrap; font-size: .85rem; margin-bottom: .3rem; }
.cost { color: var(--gold); font-weight: 600; }

/* ---- vote / choice controls ---- */
.vote-form { display: flex; gap: .5rem; margin: .6rem 0 .2rem; }
.vote-btn {
  flex: 1; padding: .6rem .4rem; border: 1px solid var(--line); border-radius: 10px;
  background: #fff; font-size: .9rem; cursor: pointer;
}
.vote-btn b { display: block; font-size: 1rem; }
.vote-btn.mine { border-color: var(--wine); background: var(--wine-light); }
.choice-form { display: flex; flex-direction: column; gap: .45rem; margin: .6rem 0 .3rem; }
.choice-btn {
  display: block; width: 100%; text-align: left; padding: .6rem .7rem; border: 1px solid var(--line);
  border-radius: 10px; background: #fff; cursor: pointer; font-size: .95rem;
}
.choice-btn.mine { border-color: var(--wine); background: var(--wine-light); }
.choice-btn[disabled] { opacity: .8; cursor: default; }
.choice-main { display: flex; align-items: center; gap: .5rem; }
.tick { color: var(--wine); }
.choice-label { flex: 1; }
.count { color: var(--wine-dark); }
.choice-note { display: block; color: var(--muted); font-size: .8rem; margin-top: .15rem; padding-left: 1.3rem; }
.total { color: var(--muted); font-size: .82rem; margin: .2rem 0 0; }
.tally { display: flex; gap: .6rem; }
.tally .opt { padding: .3rem .55rem; border-radius: 8px; background: #f2eef0; font-size: .9rem; }
.tally .opt.mine { background: var(--wine-light); font-weight: 600; }

/* ---- comments ---- */
.comments { margin-top: .6rem; border-top: 1px dashed var(--line); padding-top: .4rem; }
.comments summary { cursor: pointer; color: var(--wine); font-size: .9rem; }
.cc { background: var(--wine-light); border-radius: 999px; padding: 0 .4rem; font-size: .78rem; }
.comment-list { list-style: none; padding: 0; margin: .5rem 0; }
.comment-list li { padding: .35rem 0; border-bottom: 1px solid var(--line); }
.c-author { font-weight: 600; color: var(--wine-dark); margin-right: .4rem; font-size: .85rem; }
.c-body { font-size: .92rem; word-break: break-word; }
.c-empty { color: var(--muted); font-size: .85rem; }
.comment-form { display: flex; gap: .4rem; align-items: flex-start; }
.comment-form textarea { flex: 1; }
.btn-send { background: var(--wine); color: #fff; border: 0; border-radius: 8px; padding: .55rem .7rem; cursor: pointer; }

/* ---- how-to ---- */
.how ol { padding-left: 1.2rem; }
.how li { margin: .3rem 0; }

/* ---- admin ---- */
.admin-head .stats { color: var(--muted); }
.admin-actions { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: .5rem; }
.admin-list { list-style: none; padding: 0; }
.admin-list > li { padding: .5rem 0; border-bottom: 1px solid var(--line); display: flex; gap: .4rem; flex-wrap: wrap; align-items: center; }
.admin-list input[type=text] { width: auto; flex: 1 1 8rem; }
.chk { font-size: .85rem; color: var(--muted); display: flex; align-items: center; gap: .25rem; }
.admin-item { flex-direction: column; align-items: stretch; }
.ai-main { display: flex; gap: .5rem; flex-wrap: wrap; align-items: baseline; }
.ai-day { color: var(--muted); font-size: .8rem; }
.ai-title { font-weight: 600; flex: 1; }
.ai-kind { font-size: .72rem; color: #fff; background: var(--muted); padding: 0 .4rem; border-radius: 999px; }
.ai-tally { font-size: .85rem; color: var(--wine-dark); margin: .25rem 0; display: flex; gap: .6rem; flex-wrap: wrap; }
.muted { color: var(--muted); }
.danger-zone { border-color: #f0c9c9; }
.danger-zone h2 { color: var(--no); }

/* ---- footer ---- */
.foot { text-align: center; color: var(--muted); font-size: .8rem; padding: 1.5rem 1rem; display: flex; justify-content: center; gap: 1rem; }
.foot a { color: var(--muted); }
.empty { color: var(--muted); text-align: center; padding: 2rem 0; }

@media (min-width: 560px) {
  .name-grid { grid-template-columns: repeat(3, 1fr); }
}

/* htmx: subtle fade on swap */
.item-card.htmx-swapping { opacity: .5; transition: opacity .12s; }
