/* Elysian Sailing booking widget — navy & gold, matching the pricing grids */

:root {
  --navy: #1b2a4a;
  --navy-deep: #142038;
  --gold: #c9a227;
  --gold-soft: #e3c873;
  --cream: #f7f1e1;
  --cream-soft: #fbf8ef;
  --ink: #22304d;
  --muted: #7c8497;
  --danger: #b04a3a;
  --ok: #3a7d52;
}

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

body {
  font-family: Georgia, 'Times New Roman', serif;
  background: var(--cream-soft);
  color: var(--ink);
}

.widget { max-width: 760px; margin: 0 auto; background: #fff; min-height: 100vh; box-shadow: 0 0 40px rgba(20, 32, 56, .12); }

/* masthead */
.masthead { background: var(--navy); border-bottom: 3px solid var(--gold); padding: 22px 24px 18px; text-align: center; }
.brand { color: var(--gold); font-size: 26px; letter-spacing: 6px; font-weight: 700; }
.tagline { color: #b9c2d6; font-size: 12.5px; margin-top: 6px; letter-spacing: 1px; }

/* step nav */
.steps { display: flex; background: var(--navy-deep); padding: 0 8px; overflow-x: auto; }
.step { color: #8d99b5; font-size: 12px; padding: 11px 14px; letter-spacing: 1px; white-space: nowrap; border-bottom: 3px solid transparent; }
.step.active { color: var(--gold-soft); border-bottom-color: var(--gold); }
.step.done { color: #cdd6e6; }

main { padding: 26px 24px 34px; }
.loading { text-align: center; color: var(--muted); padding: 60px 0; }

h2.section { font-size: 21px; color: var(--navy); margin-bottom: 4px; }
p.sub { color: var(--muted); font-size: 14px; margin-bottom: 18px; }

/* experience cards */
.cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 560px) { .cards { grid-template-columns: 1fr; } }
.card {
  border: 1px solid #dfd9c8; border-radius: 8px; padding: 18px 16px 14px; cursor: pointer;
  background: var(--cream-soft); transition: all .15s;
}
.card:hover { border-color: var(--gold); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(20,32,56,.08); }
.card .icon { font-size: 22px; }
.card h3 { color: var(--navy); font-size: 16.5px; margin: 8px 0 4px; }
.card .desc { font-size: 13px; color: var(--muted); line-height: 1.45; }
.card .from { margin-top: 10px; font-size: 13.5px; color: var(--gold); font-weight: 700; letter-spacing: .5px; }

/* calendar */
.cal-head { display: flex; justify-content: space-between; align-items: center; margin: 6px 0 10px; }
.cal-head .month { font-size: 17px; color: var(--navy); font-weight: 700; letter-spacing: 1px; }
.cal-nav { background: var(--navy); color: var(--gold-soft); border: 0; border-radius: 4px; padding: 6px 13px; font-size: 15px; cursor: pointer; font-family: inherit; }
.cal-nav:disabled { opacity: .35; cursor: default; }
.cal { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal .dow { text-align: center; font-size: 11px; color: var(--muted); letter-spacing: 1px; padding: 4px 0; }
.day {
  aspect-ratio: 1.15; border: 1px solid #e7e2d3; border-radius: 5px; font-size: 14px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  cursor: pointer; background: #fff; position: relative; font-family: inherit; color: var(--ink);
}
.day:hover:not(:disabled) { border-color: var(--gold); background: var(--cream); }
.day:disabled { color: #c8c4b8; background: #faf9f4; cursor: default; text-decoration: line-through; }
.day.empty { border: 0; background: transparent; cursor: default; text-decoration: none; }
.day.booked:disabled { background: #efece3; color: #b6b1a2; }
.day.shared { border-color: var(--gold); }
.day.shared::after { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); position: absolute; bottom: 5px; }
.day.selected { background: var(--navy); color: #fff; border-color: var(--navy); }
.day.inrange { background: var(--cream); border-color: var(--gold-soft); }
.legend { display: flex; gap: 16px; margin-top: 10px; font-size: 12px; color: var(--muted); flex-wrap: wrap; }
.legend span::before { content: '■ '; }
.legend .l-open::before { color: #fff; text-shadow: 0 0 1px #999; }
.legend .l-booked::before { color: #d8d4c7; }
.legend .l-shared::before { color: var(--gold); }

/* option pickers */
.opts { display: flex; gap: 10px; margin: 14px 0; flex-wrap: wrap; }
.opt {
  flex: 1; min-width: 130px; border: 1px solid #dfd9c8; border-radius: 6px; padding: 12px 10px;
  text-align: center; cursor: pointer; background: #fff; font-family: inherit;
}
.opt:hover:not(:disabled) { border-color: var(--gold); }
.opt.selected { border-color: var(--navy); background: var(--navy); color: #fff; }
.opt.selected .price { color: var(--gold-soft); }
.opt:disabled { opacity: .4; cursor: default; }
.opt .name { font-size: 14px; font-weight: 700; }
.opt .meta { font-size: 11.5px; color: inherit; opacity: .7; margin-top: 2px; }
.opt .price { font-size: 15px; color: var(--navy); font-weight: 700; margin-top: 5px; }

/* small muted helper line under the slot options */
.slot-note { font-size: 12.5px; color: var(--muted); line-height: 1.5; margin: -2px 0 14px; font-style: italic; }

.row { display: flex; gap: 14px; align-items: center; margin: 14px 0; flex-wrap: wrap; }
.row label { font-size: 14px; color: var(--navy); font-weight: 700; }
select, input[type=text], input[type=email], input[type=tel], textarea {
  font-family: inherit; font-size: 15px; padding: 9px 11px; border: 1px solid #cfc9b8;
  border-radius: 5px; background: #fff; color: var(--ink); width: 100%;
}
select { width: auto; min-width: 90px; }
textarea { resize: vertical; min-height: 70px; }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 13px; color: var(--navy); font-weight: 700; margin-bottom: 5px; letter-spacing: .5px; }

.notice { background: var(--cream); border-left: 3px solid var(--gold); padding: 10px 14px; font-size: 13px; margin: 12px 0; color: var(--ink); line-height: 1.5; }
.notice.error { border-left-color: var(--danger); color: var(--danger); background: #faf0ee; }
.notice.success { border-left-color: var(--ok); color: var(--ok); background: #eff7f1; }

/* quote */
.quote { border: 1px solid #e0dac9; border-radius: 8px; overflow: hidden; margin: 14px 0; }
.quote .qhead { background: var(--navy); color: var(--gold-soft); padding: 11px 16px; font-size: 14px; letter-spacing: 1.5px; }
.quote table { width: 100%; border-collapse: collapse; }
.quote td { padding: 10px 16px; font-size: 14px; border-bottom: 1px solid #f0ecdf; }
.quote td.amt { text-align: right; white-space: nowrap; font-weight: 700; }
.quote tr.total td { background: var(--cream); font-size: 16px; color: var(--navy); font-weight: 700; }
.quote tr.deposit td { color: var(--ok); font-weight: 700; }
.fineprint { font-size: 12px; color: var(--muted); line-height: 1.55; margin-top: 8px; }

/* buttons */
.btnbar { display: flex; gap: 12px; margin-top: 22px; }
.btn {
  font-family: inherit; font-size: 15px; letter-spacing: 1px; padding: 13px 26px;
  border-radius: 5px; cursor: pointer; border: 0;
}
.btn.primary { background: var(--gold); color: var(--navy-deep); font-weight: 700; flex: 1; }
.btn.primary:hover { background: var(--gold-soft); }
.btn.primary:disabled { opacity: .5; cursor: default; }
.btn.ghost { background: #fff; border: 1px solid #cfc9b8; color: var(--muted); }

/* terms + confirmation */
.terms { font-size: 13px; line-height: 1.6; background: var(--cream-soft); border: 1px solid #e7e2d3; border-radius: 6px; padding: 12px 14px; max-height: 150px; overflow-y: auto; margin-bottom: 10px; }
.agree { display: flex; gap: 9px; align-items: flex-start; font-size: 13.5px; margin: 10px 0 4px; }
.agree input { margin-top: 3px; }

.confirm { text-align: center; padding: 30px 10px; }
.confirm .big { font-size: 44px; }
.confirm h2 { color: var(--navy); margin: 10px 0 6px; }
.confirm .bid { display: inline-block; background: var(--navy); color: var(--gold-soft); letter-spacing: 3px; padding: 8px 22px; border-radius: 4px; font-size: 18px; margin: 12px 0; }

.widget-footer { text-align: center; font-size: 12.5px; color: var(--muted); padding: 18px 0 26px; border-top: 1px solid #eee8da; }
.widget-footer a { color: var(--navy); }
