/* Wave & Wander booking — matches the main site's coastal palette. */
:root {
  --forest: #1a3a2f;
  --forest-light: #2d5a4a;
  --river: #4a7c8c;
  --river-light: #6a9cac;
  --sand: #d4c4a8;
  --sand-light: #e8dcc8;
  --cream: #f5f2eb;
  --cream-dark: #ebe6db;
  --amber: #c97b4a;
  --amber-hover: #b56a3a;
  --slate: #2d3436;
  --slate-light: #636e72;
  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Work Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --ok: #2d7d5a;
  --err: #b3402f;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font-body);
  color: var(--slate);
  background: var(--cream);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--river); }

.wrap { max-width: 640px; margin: 0 auto; padding: 2rem 1.25rem 4rem; }
.wrap-wide { max-width: 960px; }

header.bar {
  background: var(--forest);
  color: var(--cream);
  padding: 1rem 1.25rem;
}
header.bar .inner {
  max-width: 960px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
header.bar a { color: var(--sand-light); text-decoration: none; }
header.bar .brand {
  font-family: var(--font-display); font-weight: 600; font-size: 1.15rem;
  color: var(--cream); letter-spacing: 0.02em;
}

h1, h2, h3 { font-family: var(--font-display); color: var(--forest); font-weight: 600; }
h1 { font-size: 2rem; margin-bottom: 0.35rem; }
h2 { font-size: 1.4rem; margin: 1.75rem 0 0.75rem; }
.lead { color: var(--slate-light); margin-bottom: 1.5rem; }

.card {
  background: #fff; border: 1px solid var(--cream-dark);
  border-radius: 16px; padding: 1.5rem; margin-bottom: 1.25rem;
  box-shadow: 0 2px 10px rgba(26,58,47,0.05);
}

label { display: block; font-weight: 500; margin: 0.85rem 0 0.3rem; font-size: 0.95rem; }
input, select, textarea {
  width: 100%; padding: 0.7rem 0.85rem; font: inherit;
  border: 1px solid var(--sand); border-radius: 10px; background: var(--cream);
}
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--river); background: #fff;
}
textarea { min-height: 90px; resize: vertical; }
.row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 520px) { .row { grid-template-columns: 1fr; } }

.hp { position: absolute; left: -9999px; }  /* honeypot */

.check { display: flex; align-items: flex-start; gap: 0.6rem; margin-top: 1rem; }
.check input { width: auto; margin-top: 0.35rem; }
.check label { margin: 0; font-weight: 400; }

.btn {
  display: inline-block; border: none; cursor: pointer;
  background: var(--amber); color: #fff; font-weight: 600;
  padding: 0.8rem 1.6rem; border-radius: 999px; font-size: 1rem;
  text-decoration: none; transition: background 0.2s;
}
.btn:hover { background: var(--amber-hover); }
.btn-block { width: 100%; }
.btn-ghost { background: transparent; color: var(--forest); border: 1px solid var(--sand); }
.btn-ghost:hover { background: var(--cream-dark); }
.btn-sm { padding: 0.4rem 0.9rem; font-size: 0.85rem; }
.btn-danger { background: var(--err); }

.avail { margin-top: 0.75rem; font-weight: 500; min-height: 1.4em; }
.avail.ok { color: var(--ok); }
.avail.no { color: var(--err); }

.flash { padding: 0.85rem 1rem; border-radius: 10px; margin-bottom: 1rem; font-weight: 500; }
.flash.success { background: #e3f1ea; color: var(--ok); }
.flash.error { background: #f7e4e1; color: var(--err); }

.muted { color: var(--slate-light); font-size: 0.9rem; }
.field-error { color: var(--err); font-size: 0.85rem; margin-top: 0.25rem; }

table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 0.65rem 0.6rem; border-bottom: 1px solid var(--cream-dark); font-size: 0.92rem; }
th { color: var(--slate-light); font-weight: 600; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em; }

.tag { display: inline-block; padding: 0.15rem 0.6rem; border-radius: 999px; font-size: 0.78rem; font-weight: 600; }
.tag.pending { background: #fbe7d4; color: #9a5b1d; }
.tag.confirmed { background: #d9ede2; color: var(--ok); }
.tag.out { background: #d7e7ee; color: #2a6072; }
.tag.returned { background: var(--cream-dark); color: var(--slate-light); }
.tag.cancelled, .tag.no_show { background: #f1ddda; color: var(--err); }

.inline-form { display: inline; }
.actions { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.adminnav { display: flex; gap: 1.25rem; margin: 1rem 0 1.5rem; flex-wrap: wrap; }
.adminnav a { font-weight: 500; text-decoration: none; }
.conflict { color: var(--err); font-size: 0.82rem; font-weight: 600; }
