/* DIRECTION C — Operations Console
   Lifted directly from altura dashboard tokens & visual language.
   JetBrains Mono throughout. Cream + violet + orange + blue. */

.con {
  --cream:     #faf5ec;
  --cream-2:   #f3ecdf;
  --violet:    #1f0c2a;
  --violet-2:  #2b1438;
  --blue:      #3476b2;
  --orange:    #cd4219;
  --ink:       #1f0c2a;
  --ink-soft:  #5a4960;
  --ink-faint: #9a8a93;
  --rule:      rgba(31, 12, 42, 0.16);
  --rule-soft: rgba(31, 12, 42, 0.08);
  --green:     #5e9a4a;

  font-family: 'JetBrains Mono', ui-monospace, monospace;
  background: var(--cream);
  color: var(--ink);
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .01em;
}
.con * { box-sizing: border-box; }
.con a { text-decoration: none; color: inherit; }

.con .uc { text-transform: uppercase; letter-spacing: .18em; }
.con .accent { color: var(--orange); }
.con .blue   { color: var(--blue); }
.con .soft   { color: var(--ink-soft); }
.con .faint  { color: var(--ink-faint); }

/* ── shared atoms ─────────────────────────────────────────── */
.con .label {
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  font-weight: 500; color: var(--ink-soft);
}
.con .label.b  { color: var(--blue); font-weight: 600; }
.con .label.o  { color: var(--orange); font-weight: 600; }

.con .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--orange); display: inline-block; }
.con .dot.b { background: var(--blue); }
.con .dot.g { background: var(--green); }
.con .dot.v { background: var(--violet); }
.con .dot.a { background: #c9892a; }

.con .rule { height: 1px; background: var(--rule-soft); }
.con .vrule { width: 1px; background: var(--rule-soft); align-self: stretch; }

.con .tag {
  font-size: 9px; letter-spacing: .18em; text-transform: uppercase;
  padding: 4px 8px; border-radius: 2px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 6px;
}
.con .tag.live    { background: #e7f1e2; color: #4a7a37; }
.con .tag.alert   { background: #f7e1d8; color: var(--orange); }
.con .tag.warn    { background: #fbedd2; color: #8a6314; }
.con .tag.info    { background: #e3edf6; color: #2a608f; }
.con .tag.draft   { background: var(--cream-2); color: var(--ink-soft); }

/* buttons */
.con .btn {
  display: inline-flex; align-items: center; gap: 10px;
  height: 40px; padding: 0 16px;
  border-radius: 3px;
  font: 600 11px/1 'JetBrains Mono', monospace;
  text-transform: uppercase; letter-spacing: .18em;
  border: 1px solid var(--ink); background: transparent; color: var(--ink);
  white-space: nowrap;
}
.con .btn.primary { background: var(--orange); border-color: var(--orange); color: #fff; }
.con .btn.ghost   { background: var(--cream); }
.con .btn.violet  { background: var(--violet); border-color: var(--violet); color: #fff; }
.con .btn.wa      { background: #1f8a4d; border-color: #1f8a4d; color: #fff; }
.con .btn.lg      { height: 48px; padding: 0 22px; font-size: 12px; }
.con .btn.xl      { height: 58px; padding: 0 28px; font-size: 13px; letter-spacing: .2em; }
.con .btn .plus   { font-weight: 700; font-size: 13px; opacity: .8; }
.con .btn .arrow  { margin-left: 4px; }

/* section title (the dashboard pattern: orange underline) */
.con .section-title {
  font-size: 16px; font-weight: 600; letter-spacing: .04em;
  padding-bottom: 10px; border-bottom: 2px solid var(--orange);
  margin-bottom: 18px;
  display: flex; justify-content: space-between; align-items: end;
}
.con .section-title .meta { font-size: 10px; letter-spacing: .18em; color: var(--ink-soft); font-weight: 400; }

/* ── top status bar + nav ─────────────────────────────────── */
.con-status {
  display: flex; align-items: center; gap: 28px;
  padding: 12px 32px;
  border-bottom: 1px solid var(--rule-soft);
  font-size: 10px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--ink-soft);
  background: var(--cream);
}
.con-status .item { display: inline-flex; align-items: center; gap: 8px; }
.con-status .item b { color: var(--ink); font-weight: 600; letter-spacing: .18em; }
.con-status .spacer { flex: 1; }
.con-status .live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); position: relative; }
.con-status .live-dot::after { content:''; position:absolute; inset:-4px; border-radius:50%; border:1px solid var(--green); opacity:.4; animation: con-pulse 1.8s ease-out infinite; }
@keyframes con-pulse { 0% { transform: scale(.5); opacity:.6 } 100% { transform: scale(1.4); opacity:0 } }

.con-nav {
  display: flex; align-items: center; gap: 36px;
  padding: 20px 32px;
  border-bottom: 1px solid var(--rule);
  background: #14081d;
  color: #fff;
}
.con-nav .right .btn.ghost {
  background: transparent;
  border-color: rgba(255,255,255,.4);
  color: #fff;
}
.con-nav .logo { display: flex; align-items: center; gap: 14px; }
.con-nav .logo img { width: 130px; height: auto; display: block; }
.con-nav .logo.dark { background: var(--violet); padding: 8px 14px; border-radius: 3px; }
.con-nav .nav-links { display: flex; gap: 28px; margin-left: 18px; }
.con-nav .nav-links a {
  font-size: 11px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink); padding: 8px 0; position: relative;
}
.con-nav .nav-links a.active { font-weight: 600; }
.con-nav .nav-links a.active::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px; background: var(--orange);
}
.con-nav .nav-spacer { flex: 1; }
.con-nav .right { display: flex; align-items: center; gap: 12px; }

/* Default: full labels everywhere; short labels hidden until mobile */
.con-nav .btn .lbl-short,
.con-modal-hd .title .lbl-short,
.con-modal-hd .close .lbl-short { display: none; }

/* ── hero ─────────────────────────────────────────────────── */
.con-hero {
  display: grid;
  grid-template-columns: 1fr 580px;
  gap: 56px;
  padding: 64px 32px 72px;
  align-items: start;
  position: relative;
}

.con-hero .crumb {
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 28px; font-weight: 600;
}
.con-hero .crumb .sep { color: var(--ink-faint); margin: 0 8px; }
.con-hero h1 {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600;
  font-size: 60px;
  line-height: 1.02;
  letter-spacing: -.025em;
  color: var(--ink);
  margin: 0 0 28px;
  max-width: 760px;
  text-wrap: balance;
}
.con-hero h1 .em { color: var(--orange); }
.con-hero h1 .blue-em { color: var(--blue); }
.con-hero h1 .underline {
  background: linear-gradient(transparent 68%, rgba(205,66,25,.25) 68%);
  padding: 0 2px;
}
.con-hero .lede {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 560px;
  margin: 0 0 36px;
  letter-spacing: .015em;
}
.con-hero .lede b { color: var(--ink); font-weight: 600; }

.con-hero .cta-row { display: flex; gap: 10px; margin-bottom: 44px; align-items: center; }
.con-hero .cta-row .note { font-size: 10px; letter-spacing: .18em; color: var(--ink-soft); text-transform: uppercase; margin-left: 6px; }

.con-hero .trust {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--rule); border-radius: 4px;
  background: #fff;
}
.con-hero .trust .item { padding: 16px 18px; }
.con-hero .trust .item + .item { border-left: 1px solid var(--rule-soft); }
.con-hero .trust .k { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 8px; }
.con-hero .trust .v { font-size: 18px; font-weight: 600; letter-spacing: -.005em; display: flex; align-items: center; gap: 8px; min-height: 23px; }
.con-hero .trust .v .stars { color: var(--orange); font-size: 13px; letter-spacing: .1em; }
.con-hero .trust .sub { font-size: 10px; letter-spacing: .12em; color: var(--ink-soft); margin-top: 4px; }

/* support console mock (right of hero) */
.con-console {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 1px 0 var(--rule), 0 30px 60px -30px rgba(31,12,42,.18);
}
.con-console-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--rule-soft);
  background: var(--cream);
}
.con-console-hd .title {
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  font-weight: 600; color: var(--blue);
}
.con-console-hd .right { display: flex; align-items: center; gap: 12px; font-size: 10px; letter-spacing: .18em; color: var(--ink-soft); text-transform: uppercase; }

.con-console-meta {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border-bottom: 1px solid var(--rule-soft);
  background: rgba(0,0,0,.015);
}
.con-console-meta .m { padding: 12px 16px; }
.con-console-meta .m + .m { border-left: 1px solid var(--rule-soft); }
.con-console-meta .k { font-size: 9px; letter-spacing: .22em; color: var(--ink-soft); text-transform: uppercase; margin-bottom: 4px; }
.con-console-meta .v { font-size: 13px; font-weight: 600; }

.con-msg { padding: 16px 16px; border-bottom: 1px solid var(--rule-soft); display: grid; grid-template-columns: 70px 1fr; gap: 14px; }
.con-msg:last-child { border-bottom: 0; }
.con-msg .time { font-size: 10px; letter-spacing: .12em; color: var(--ink-soft); padding-top: 4px; }
.con-msg .kind {
  font-size: 9px; letter-spacing: .22em; text-transform: uppercase;
  font-weight: 600; padding: 4px 8px; border-radius: 2px; display: inline-block;
  margin-bottom: 8px;
}
.con-msg .kind.check { background: #e3edf6; color: var(--blue); }
.con-msg .kind.alert { background: #f7e1d8; color: var(--orange); }
.con-msg .kind.taxi  { background: #e7f1e2; color: #4a7a37; }
.con-msg .kind.path  { background: #fbedd2; color: #8a6314; }
.con-msg .body p { margin: 0; font-size: 12.5px; line-height: 1.5; color: var(--ink); letter-spacing: .015em; }
.con-msg .body .who { font-size: 10px; letter-spacing: .18em; color: var(--ink-soft); margin-top: 8px; text-transform: uppercase; }
.con-msg .body .reply {
  margin-top: 12px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 9px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600;
  padding: 7px 10px; border-radius: 3px;
  background: var(--violet); color: #fff; border: 0;
}
.con-msg .body .meta-row { margin-top: 10px; display: flex; gap: 14px; flex-wrap: wrap; font-size: 10px; color: var(--ink-soft); letter-spacing: .12em; }
.con-msg .body .meta-row span b { color: var(--ink); font-weight: 600; }
.con-msg .body .alt {
  margin-top: 10px;
  padding: 10px 12px;
  border-left: 2px solid var(--orange);
  background: #fff8f3;
  font-size: 11.5px; line-height: 1.4; color: var(--ink);
}
.con-msg .body .alt b { font-weight: 600; }

.con-input-bar {
  padding: 12px 16px; display: flex; gap: 10px; align-items: center;
  background: var(--cream-2); border-top: 1px solid var(--rule-soft);
}
.con-input-bar input {
  flex: 1; border: 1px solid var(--rule); border-radius: 3px;
  padding: 9px 12px; background: #fff; font: 500 12px/1 'JetBrains Mono', monospace;
  color: var(--ink); outline: none;
}
.con-input-bar .cursor { display: inline-block; width: 6px; height: 12px; background: var(--orange); animation: con-blink 1s steps(2) infinite; margin-left: 2px; vertical-align: -2px; }
@keyframes con-blink { 50% { opacity: 0; } }

/* topo decoration in hero corner */
.con-topo {
  position: absolute; pointer-events: none; opacity: .35;
  color: var(--violet);
}

/* ── section atoms ────────────────────────────────────────── */
.con-sec { padding: 96px 32px; border-top: 1px solid var(--rule); position: relative; }
.con-sec.cream2 { background: var(--cream-2); }
.con-sec.violet { background: var(--violet); color: #e8dde9; border-top-color: var(--violet); }
.con-sec.violet .label { color: var(--orange); }
.con-sec.violet .section-title { color: #fff; }
.con-sec.violet .section-title .meta { color: rgba(255,255,255,.55); }

.con-sec-hd { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; margin-bottom: 48px; }
.con-sec-hd .left { max-width: 760px; }
.con-sec-hd .label { display: block; margin-bottom: 14px; }
.con-sec-hd h2 {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  font-size: 42px; line-height: 1.05; letter-spacing: -.02em;
  margin: 0; text-wrap: balance;
}
.con-sec-hd h2 .em { color: var(--orange); }
.con-sec-hd h2 .blue-em { color: var(--blue); }
.con-sec-hd .right {
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-soft); text-align: right; padding-bottom: 6px; min-width: 240px;
}

/* ── support layer cards ──────────────────────────────────── */
.con-feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.con-feat {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 26px 24px 26px 28px;
  position: relative;
  display: flex; flex-direction: column; gap: 18px;
}
.con-feat::before {
  content: ''; position: absolute; left: 0; top: 22px; bottom: 22px; width: 3px;
  background: var(--orange);
}
.con-feat-hd { display: flex; align-items: center; justify-content: space-between; }
.con-feat-hd .num { font-size: 10px; letter-spacing: .22em; color: var(--ink-soft); text-transform: uppercase; }
.con-feat-hd .ic {
  width: 32px; height: 32px; border: 1px solid var(--rule); border-radius: 3px;
  display: grid; place-items: center; background: var(--cream-2);
  color: var(--violet);
}
.con-feat h3 {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  font-size: 18px; line-height: 1.25; letter-spacing: -.005em;
  margin: 0;
}
.con-feat p { font-size: 13.5px; line-height: 1.55; color: var(--ink-soft); margin: 0; letter-spacing: .015em; }
.con-feat p b { color: var(--ink); font-weight: 600; }

.con-feat-demo {
  background: #fff; border: 1px solid var(--rule);
  border-radius: 3px; padding: 12px 14px;
  font-size: 11px; line-height: 1.5; color: var(--ink-soft);
  display: flex; flex-direction: column; gap: 6px;
}
.con-feat-demo .row { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.con-feat-demo .row b { color: var(--ink); font-weight: 600; }
.con-feat-demo .row .ok   { color: var(--green); font-weight: 600; }
.con-feat-demo .row .warn { color: var(--orange); font-weight: 600; }
.con-feat-demo .row .blue { color: var(--blue); font-weight: 600; }
.con-feat-demo .row .pin  { color: var(--violet); font-weight: 600; }

/* ── self-guided spectrum ─────────────────────────────────── */
.con-kicker {
  font: 700 13px/1 'JetBrains Mono', monospace;
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--orange); margin-bottom: 18px; display: flex; align-items: center; gap: 14px;
  flex-wrap: wrap;
}
.con-kicker .bar { display: inline-block; width: 36px; height: 2px; background: var(--orange); }
.con-kicker .sub { color: var(--ink-soft); letter-spacing: .14em; font-weight: 500; font-size: 11px; }
.con-kicker .sub b { color: var(--ink); }

.con-spectrum-lede {
  max-width: 920px; margin: 0 auto 56px;
  text-align: center; font-size: 17px; line-height: 1.55;
  color: var(--ink-soft); letter-spacing: .01em;
}
.con-spectrum-lede b { color: var(--ink); font-weight: 600; }
.con-spectrum-lede em { font-style: normal; color: var(--orange); font-weight: 600; }

.con-spectrum { display: grid; grid-template-columns: 1fr 1.15fr 1fr; gap: 16px; align-items: stretch; }
.con-spec-col {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 0;
  display: flex; flex-direction: column;
  position: relative;
}
.con-spec-col.us {
  background: var(--cream-2);
  border: 1.5px solid var(--orange);
  box-shadow: 0 12px 32px -16px rgba(205,66,25,.35);
  transform: translateY(-8px);
}
.con-spec-col.us::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--orange);
}
.con-spec-col .col-hd { padding: 22px 22px 18px; border-bottom: 1px solid var(--rule); position: relative; }
.con-spec-col.us .col-hd { border-bottom-color: rgba(205,66,25,.25); }
.con-spec-col .col-hd .num {
  font: 500 10px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft);
}
.con-spec-col.us .col-hd .num { color: var(--orange); font-weight: 600; }
.con-spec-col .col-hd h3 {
  font: 700 16px/1.2 'JetBrains Mono', monospace;
  letter-spacing: .04em; margin: 8px 0 8px;
}
.con-spec-col.us .col-hd h3 { color: var(--orange); }
.con-spec-col .col-hd p {
  font: 500 12.5px/1.5 'JetBrains Mono', monospace;
  letter-spacing: .015em; color: var(--ink-soft); margin: 0;
}
.con-spec-col.us .col-hd p { color: var(--ink); }
.con-spec-col .here-tag {
  position: absolute; top: -12px; right: 16px;
  font: 700 10px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  padding: 7px 10px; background: var(--orange); color: #fff;
  border-radius: 3px;
}

.con-spec-rows { display: flex; flex-direction: column; flex: 1; }
.con-spec-row {
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--rule-soft);
  font-size: 12.5px; line-height: 1.45;
}
.con-spec-row:last-child { border-bottom: 0; }
.con-spec-col.us .con-spec-row { border-bottom-color: rgba(205,66,25,.15); }
.con-spec-row .k {
  font: 600 9.5px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.con-spec-row .v { color: var(--ink); }
.con-spec-row .v.muted { color: var(--ink-soft); }
.con-spec-col.us .con-spec-row .v b { color: var(--orange); font-weight: 700; }

.con-spec-foot {
  padding: 14px 22px; border-top: 1px solid var(--rule-soft);
  display: flex; align-items: center; justify-content: space-between;
  font: 600 10px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.con-spec-col.us .con-spec-foot { border-top-color: rgba(205,66,25,.15); color: var(--orange); }

/* ── talk to a local · 3-path conversion panel ────────────── */
.con-talk-hd {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 40px; margin-bottom: 48px;
}
.con-talk-hd .left { max-width: 720px; }
.con-talk-hd h2 {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  font-size: 42px; line-height: 1.05; letter-spacing: -.02em;
  margin: 14px 0 18px;
}
.con-talk-hd h2 .em { color: var(--orange); }
.con-talk-hd .lede { font-size: 16px; line-height: 1.55; color: var(--ink-soft); margin: 0; max-width: 580px; letter-spacing: .015em; }
.con-talk-hd .lede b { color: var(--ink); font-weight: 600; }
.con-talk-hd .right {
  font: 500 10.5px/1.5 'JetBrains Mono', monospace; letter-spacing: .22em;
  text-transform: uppercase; color: var(--ink-soft); text-align: right; min-width: 240px; padding-bottom: 6px;
}

.con-talk-grid { display: grid; grid-template-columns: 1.18fr 1fr; gap: 18px; align-items: stretch; }

.con-talk-card {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 30px 32px 30px;
  display: flex; flex-direction: column; gap: 18px;
  position: relative;
}
.con-talk-card .badge {
  position: absolute; top: -12px; left: 22px;
  font: 700 10px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  padding: 7px 10px; border-radius: 3px;
  background: #1f8a4d; color: #fff;
}
.con-talk-card.wa {
  background: linear-gradient(180deg, #F2FAF5 0%, #E9F5EE 100%);
  border-color: #1f8a4d;
  box-shadow: 0 14px 32px -16px rgba(31,138,77,.35);
}
.con-talk-card.call .badge { background: var(--orange); }

.con-talk-card .row-top {
  display: flex; align-items: center; justify-content: space-between;
  font: 500 10px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft);
}
.con-talk-card .row-top .num b { color: var(--ink); font-weight: 600; }
.con-talk-card .row-top .meta { font-weight: 500; }
.con-talk-card.wa .row-top .meta { color: #1f8a4d; font-weight: 600; }
.con-talk-card.call .row-top .meta { color: var(--orange); font-weight: 600; }

.con-talk-card h3 {
  font: 600 26px/1.15 'JetBrains Mono', monospace;
  letter-spacing: -.015em; margin: 0;
}
.con-talk-card h3 .em { color: #1f8a4d; }
.con-talk-card.call h3 .em { color: var(--orange); }
.con-talk-card .desc { font-size: 14.5px; line-height: 1.55; color: var(--ink-soft); margin: 0; letter-spacing: .015em; }
.con-talk-card .desc b { color: var(--ink); font-weight: 600; }

/* WhatsApp chat preview */
.con-talk-chat {
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(31,138,77,.2);
  border-radius: 4px;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 8px;
}
.con-talk-chat .b {
  display: inline-block;
  padding: 8px 11px;
  font-size: 12.5px; line-height: 1.4;
  border-radius: 4px;
  font-family: 'Geist', sans-serif; letter-spacing: 0;
  max-width: 86%;
}
.con-talk-chat .b.you { background: #DCF8C6; align-self: flex-end; color: #1c1a14; }
.con-talk-chat .b.us  { background: #fff; border: 1px solid var(--rule-soft); align-self: flex-start; color: var(--ink); }
.con-talk-chat .b b { font-weight: 700; }
.con-talk-chat .typing { font: 500 11px/1 'JetBrains Mono', monospace; color: #1f8a4d; letter-spacing: .15em; text-transform: uppercase; margin-top: 2px; padding-left: 4px; display: inline-flex; align-items: center; gap: 8px; }
.con-talk-chat .typing .dots { display: inline-flex; gap: 3px; }
.con-talk-chat .typing .dots i { width: 5px; height: 5px; border-radius: 50%; background: #1f8a4d; display: inline-block; opacity: .35; animation: tk-pulse 1.4s ease-in-out infinite; }
.con-talk-chat .typing .dots i:nth-child(2) { animation-delay: .2s; }
.con-talk-chat .typing .dots i:nth-child(3) { animation-delay: .4s; }
@keyframes tk-pulse { 0%, 60%, 100% { opacity: .35; } 30% { opacity: 1; } }

.con-talk-card .big-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  height: 64px; padding: 0 28px;
  background: #1f8a4d; color: #fff;
  border: 0; border-radius: 4px;
  font: 700 14px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  margin-top: auto;
  box-shadow: 0 8px 20px -8px rgba(31,138,77,.5);
}
.con-talk-card.call .big-btn { background: var(--orange); box-shadow: 0 8px 20px -8px rgba(205,66,25,.45); }
.con-talk-card .big-btn .arrow { font-size: 18px; }
.con-talk-card .foot-note {
  font: 500 10px/1.5 'JetBrains Mono', monospace; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-soft); text-align: center; margin-top: -4px;
  min-height: 30px; /* reserve 2 lines so both cards' buttons align */
}
.con-talk-card .foot-note b { color: var(--ink); font-weight: 600; }

/* Call slot picker */
.con-talk-slots { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.con-talk-slots .slot {
  background: #fff; border: 1px solid var(--rule);
  padding: 11px 8px; border-radius: 3px; text-align: center;
}
.con-talk-slots .slot .day  { font: 500 9px/1 'JetBrains Mono', monospace; letter-spacing: .22em; color: var(--ink-soft); text-transform: uppercase; }
.con-talk-slots .slot .time { font: 600 14px/1 'JetBrains Mono', monospace; margin-top: 6px; }
.con-talk-slots .slot.on { background: var(--ink); border-color: var(--ink); color: #fff; }
.con-talk-slots .slot.on .day { color: rgba(255,255,255,.6); }
.con-talk-slots .slot.gone { opacity: .35; }

.con-talk-card .field-row { display: flex; gap: 8px; align-items: flex-end; }
.con-talk-card .field-row .field { flex: 1; }
.con-talk-card .field { display: flex; flex-direction: column; gap: 6px; }
.con-talk-card .field label { font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); }
.con-talk-card .field .ctl {
  border: 1px solid var(--rule); border-radius: 3px;
  padding: 11px 12px; background: #fff;
  font: 500 13px/1.3 'JetBrains Mono', monospace; color: var(--ink);
}
.con-talk-card .field .ctl.placeholder { color: var(--ink-faint); }

/* "Book a Call" perks list — keeps the call card balanced with the WhatsApp side */
.con-call-perks {
  margin: 4px 0 6px;
  padding: 18px 20px;
  list-style: none;
  background: rgba(205, 66, 25, 0.05);
  border: 1px solid rgba(205, 66, 25, 0.18);
  border-radius: 4px;
  display: flex; flex-direction: column; gap: 12px;
}
.con-call-perks li {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 10px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink);
  letter-spacing: .01em;
}
.con-call-perks li .k {
  font: 600 10px/1.6 'JetBrains Mono', monospace;
  letter-spacing: .2em;
  color: var(--orange);
}
.con-call-perks li b { font-weight: 600; }

/* ── HubSpot scheduler modal ──────────────────────────────
   Rendered once at the root; toggled via window event
   `open-scheduler`. Closes on backdrop click, ESC, or × button. */
.con-modal {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  background: rgba(20, 8, 29, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity .22s ease;
}
.con-modal.open { opacity: 1; pointer-events: auto; }
.con-modal-card {
  width: min(960px, 100%);
  max-height: calc(100vh - 48px);
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 6px;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,.5);
  transform: translateY(12px);
  transition: transform .28s cubic-bezier(.2,.7,.2,1);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.con-modal.open .con-modal-card { transform: translateY(0); }
.con-modal-hd {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 18px;
  background: #14081d;
  color: #fff;
  border-bottom: 1px solid var(--rule);
}
.con-modal-hd .title {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 11px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
}
.con-modal-hd .sub {
  margin-left: auto;
  font: 500 10px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.con-modal-hd .close {
  appearance: none;
  background: transparent;
  border: 1px solid rgba(255,255,255,.35);
  color: #fff;
  font: 600 10.5px/1 'JetBrains Mono', monospace;
  letter-spacing: .22em; text-transform: uppercase;
  padding: 8px 12px;
  border-radius: 3px;
  cursor: pointer;
}
.con-modal-hd .close:hover { background: rgba(255,255,255,.08); }
.con-modal-body {
  flex: 1;
  min-height: min(720px, calc(100vh - 108px));
  background: #fff;
  position: relative;
}
.con-modal-body iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
  display: block;
}
@media (max-width: 720px) {
  .con-modal { padding: 0; align-items: stretch; }
  .con-modal-card {
    max-height: 100vh;
    height: 100vh;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
  }
  .con-modal-body { min-height: 0; }
  .con-modal-hd {
    padding: 10px 12px;
    gap: 10px;
    flex-wrap: nowrap;
  }
  .con-modal-hd .title {
    font-size: 9.5px;
    letter-spacing: .18em;
    min-width: 0;
    flex: 1;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
  .con-modal-hd .title .lbl-full { display: none; }
  .con-modal-hd .title .lbl-short { display: inline; }
  .con-modal-hd .sub { display: none; }
  .con-modal-hd .close {
    padding: 0;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    letter-spacing: 0;
    flex-shrink: 0;
  }
  .con-modal-hd .close .lbl-full { display: none; }
  .con-modal-hd .close .lbl-short { display: inline; line-height: 1; }
  .con-call-perks { padding: 14px 16px; gap: 10px; }
  .con-call-perks li { font-size: 12.5px; grid-template-columns: 30px 1fr; }
}

/* Tertiary brief disclosure */
.con-brief-disclose {
  margin-top: 22px;
  padding: 16px 22px;
  background: var(--cream-2);
  border: 1px dashed var(--rule);
  border-radius: 4px;
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
}
.con-brief-disclose .left {
  font: 500 12px/1.4 'JetBrains Mono', monospace; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-soft);
}
.con-brief-disclose .left b { color: var(--ink); font-weight: 600; }
.con-brief-disclose .arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 11px/1 'JetBrains Mono', monospace; letter-spacing: .22em; text-transform: uppercase;
  color: var(--orange); white-space: nowrap; flex-shrink: 0;
}

/* ── design your own route ────────────────────────────────── */
.con-form-wrap {
  display: grid; grid-template-columns: 480px 1fr; gap: 80px; align-items: start;
}
.con-form-side h2 {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  font-size: 40px; line-height: 1.05; letter-spacing: -.02em;
  margin: 16px 0 22px;
}
.con-form-side h2 .em { color: var(--orange); }
.con-form-side .lede { font-size: 15px; color: var(--ink-soft); margin: 0 0 28px; line-height: 1.55; max-width: 440px; }
.con-form-side .lede b { color: var(--ink); font-weight: 600; }

.con-form-side .bullets { padding: 0; margin: 0 0 32px; list-style: none; display: flex; flex-direction: column; gap: 14px; }
.con-form-side .bullets li { display: grid; grid-template-columns: 22px 1fr; gap: 8px; align-items: baseline; font-size: 12px; letter-spacing: .015em; color: var(--ink); }
.con-form-side .bullets li::before { content: '→'; color: var(--orange); font-weight: 700; }

.con-form-side .alt {
  padding-top: 24px; border-top: 1px dashed var(--rule);
  display: flex; align-items: center; gap: 14px;
}
.con-form-side .alt .label { margin: 0; }

/* form card */
.con-form {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 0;
  box-shadow: 0 1px 0 var(--rule), 0 30px 60px -30px rgba(31,12,42,.14);
}
.con-form-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 22px;
  border-bottom: 1px solid var(--rule-soft);
}
.con-form-hd .crumb {
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--blue); font-weight: 600;
}
.con-form-hd .crumb .sep { color: var(--ink-faint); margin: 0 8px; }
.con-form-hd .crumb b { color: var(--ink); font-weight: 600; }
.con-form-hd .x { color: var(--ink-soft); font-size: 16px; }

.con-form-body { padding: 22px 22px 22px; }
.con-form-title {
  font-size: 22px; font-weight: 600; letter-spacing: -.005em; margin: 0 0 18px;
}
.con-form .field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; margin-bottom: 18px; }
.con-form .field-grid.one { grid-template-columns: 1fr; }
.con-form .field label { display: block; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink); margin-bottom: 6px; font-weight: 500; }
.con-form .field .ctl {
  width: 100%; border: 1px solid var(--rule); border-radius: 3px;
  padding: 11px 12px; font: 500 13px/1.3 'JetBrains Mono', monospace;
  background: #fff; color: var(--ink); outline: none;
}
.con-form .field .ctl.focus { border-color: var(--orange); box-shadow: 0 0 0 3px rgba(205,66,25,.1); }
.con-form .field .ctl.placeholder { color: var(--ink-faint); }
.con-form .field .hint { font-size: 10px; letter-spacing: .12em; color: var(--ink-soft); margin-top: 6px; text-transform: uppercase; }
.con-form .field .tag.warn-tag { background: #fbedd2; color: #8a6314; font-size: 9px; padding: 3px 7px; border-radius: 2px; letter-spacing: .18em; margin-top: 6px; display: inline-block; text-transform: uppercase; font-weight: 600; }

.con-form .chips { display: flex; flex-wrap: wrap; gap: 6px; }
.con-form .chip {
  border: 1px solid var(--rule); border-radius: 999px; padding: 7px 12px;
  font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  background: #fff; color: var(--ink); font-weight: 500;
}
.con-form .chip.on { background: var(--ink); color: #fff; border-color: var(--ink); }

.con-form .scale { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.con-form .scale .lvl {
  border: 1px solid var(--rule); background: #fff;
  padding: 12px 4px; text-align: center; border-radius: 3px;
}
.con-form .scale .lvl .n { font-size: 16px; font-weight: 600; }
.con-form .scale .lvl .lbl { font-size: 9px; letter-spacing: .18em; color: var(--ink-soft); text-transform: uppercase; margin-top: 3px; }
.con-form .scale .lvl.on { background: var(--orange); color: #fff; border-color: var(--orange); }
.con-form .scale .lvl.on .lbl { color: rgba(255,255,255,.85); }

.con-form-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px; border-top: 1px solid var(--rule-soft); gap: 14px;
}
.con-form-foot .hint { font-size: 10px; letter-spacing: .18em; color: var(--ink-soft); text-transform: uppercase; }
.con-form-foot .actions { display: flex; gap: 10px; }

/* ── curated routes ───────────────────────────────────────── */
.con-trek-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.con-trek {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 4px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: border-color .15s, box-shadow .15s, transform .15s;
}
.con-trek:hover { border-color: var(--orange); box-shadow: 0 14px 34px -18px rgba(31,12,42,.45); transform: translateY(-3px); }
.con-trek .img { height: 220px; position: relative; overflow: hidden; }
.con-trek .img .photo-real {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
}
.con-trek .ribbon {
  position: absolute; top: 14px; left: 14px;
  background: var(--violet); color: #fff;
  font-size: 9px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600;
  padding: 6px 10px; border-radius: 3px;
}
.con-trek .id-tag {
  position: absolute; top: 14px; right: 14px;
  font-size: 9px; letter-spacing: .22em; text-transform: uppercase;
  padding: 6px 10px; border-radius: 3px;
  background: rgba(255,255,255,.92); color: var(--ink);
}
.con-trek .body { padding: 22px; display: flex; flex-direction: column; gap: 14px; flex: 1; }
.con-trek h3 {
  font-size: 22px; font-weight: 600; letter-spacing: -.01em; margin: 0;
  font-family: 'JetBrains Mono', monospace;
}
.con-trek .tagline { font-size: 13px; color: var(--ink-soft); margin: 0; line-height: 1.5; }
.con-trek .specs {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
  padding-top: 14px; border-top: 1px solid var(--rule-soft); margin-top: auto;
}
.con-trek .spec .k { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 4px; }
.con-trek .spec .v { font-size: 12px; font-weight: 600; }
.con-trek .foot {
  padding: 14px 22px; border-top: 1px solid var(--rule-soft);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--orange); font-weight: 600;
  background: var(--cream-2);
}

/* ── differentiator (positive comparison) ─────────────────── */
.con-compare {
  border: 1px solid var(--rule); border-radius: 4px; overflow: hidden;
  background: var(--cream);
}
.con-compare-hd {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border-bottom: 1px solid var(--rule);
}
.con-compare-hd .h {
  padding: 18px 22px; font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--ink-soft); font-weight: 600;
}
.con-compare-hd .h + .h { border-left: 1px solid var(--rule); }
.con-compare-hd .h.us { color: var(--orange); }
.con-compare-hd .h.us::before { content: ''; display: inline-block; width: 8px; height: 8px; background: var(--orange); margin-right: 8px; vertical-align: 1px; }
.con-compare-row { display: grid; grid-template-columns: 1fr 1fr 1fr; border-bottom: 1px solid var(--rule-soft); }
.con-compare-row:last-child { border-bottom: 0; }
.con-compare-row .c { padding: 20px 22px; font-size: 13px; line-height: 1.5; }
.con-compare-row .c + .c { border-left: 1px solid var(--rule-soft); }
.con-compare-row .c.k { font-weight: 600; letter-spacing: .015em; }
.con-compare-row .c.them { color: var(--ink-soft); }
.con-compare-row .c.us { background: #fff8f3; color: var(--ink); font-weight: 500; }
.con-compare-row .c.us b { color: var(--orange); font-weight: 600; }

/* ── social proof / stats ─────────────────────────────────── */
.con-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--rule); border-radius: 4px; background: var(--cream);
  margin-bottom: 32px;
}
.con-stat { padding: 22px 24px; }
.con-stat + .con-stat { border-left: 1px solid var(--rule-soft); }
.con-stat .k { font-size: 9.5px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 8px; }
.con-stat .v {
  font-size: 36px; font-weight: 600; letter-spacing: -.01em; line-height: 1;
}
.con-stat .v.orange { color: var(--orange); }
.con-stat .v.blue   { color: var(--blue); }
.con-stat .sub { font-size: 10px; letter-spacing: .12em; color: var(--ink-soft); margin-top: 6px; text-transform: uppercase; }

.con-quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.con-quote {
  background: var(--cream); border: 1px solid var(--rule); border-radius: 4px;
  padding: 26px 24px; display: flex; flex-direction: column; gap: 18px;
}
.con-quote .stars { color: var(--orange); font-size: 12px; letter-spacing: .15em; }
.con-quote .text { font-size: 14.5px; line-height: 1.5; margin: 0; letter-spacing: .015em; }
.con-quote .text::before { content: '"'; color: var(--orange); font-size: 26px; font-weight: 700; margin-right: 4px; line-height: 0; }
.con-quote .by { display: flex; align-items: center; gap: 12px; margin-top: auto; padding-top: 16px; border-top: 1px solid var(--rule-soft); }
.con-quote .ava { width: 40px; height: 40px; border-radius: 50%; background: var(--cream-2); overflow: hidden; flex-shrink: 0; }
.con-quote .ava img { width: 100%; height: 100%; object-fit: cover; }
.con-quote .by .name { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; }
.con-quote .by .meta { font-size: 10px; letter-spacing: .12em; color: var(--ink-soft); margin-top: 3px; text-transform: uppercase; }

/* ── faq ──────────────────────────────────────────────────── */
.con-faq { border-top: 1px solid var(--rule); }
.con-faq-item {
  border-bottom: 1px solid var(--rule-soft);
  padding: 22px 0;
  display: grid; grid-template-columns: 80px 1fr 24px; gap: 24px; align-items: start;
}
.con-faq-item .num { font-size: 10px; letter-spacing: .22em; color: var(--ink-soft); padding-top: 5px; text-transform: uppercase; }
.con-faq-item .q { font-size: 17px; font-weight: 600; letter-spacing: -.005em; margin: 0; }
.con-faq-item .a { font-size: 13.5px; line-height: 1.55; color: var(--ink-soft); margin: 10px 0 0; max-width: 760px; }
.con-faq-item .chev { color: var(--ink-soft); padding-top: 4px; text-align: right; }
.con-faq-item.open .chev { color: var(--orange); }

/* ── final cta (violet) ──────────────────────────────────── */
.con-final {
  background: var(--violet); color: #e8dde9;
  padding: 96px 32px 88px; position: relative; overflow: hidden;
}
.con-final h2 {
  font-family: 'JetBrains Mono', monospace; font-weight: 600;
  font-size: 56px; line-height: 1.02; letter-spacing: -.025em;
  color: #fff; margin: 18px 0 28px; max-width: 920px; text-wrap: balance;
}
.con-final h2 .em { color: var(--orange); }
.con-final .lede { font-size: 16px; color: #b8a5bd; margin: 0 0 36px; max-width: 600px; line-height: 1.6; letter-spacing: .015em; }
.con-final .cta-row { display: flex; gap: 12px; align-items: center; margin-bottom: 60px; }
.con-final .btn.ghost { background: transparent; border-color: rgba(255,255,255,.4); color: #fff; }
.con-final .meta-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  padding-top: 32px; border-top: 1px solid rgba(255,255,255,.12);
}
.con-final .meta { padding-right: 20px; }
.con-final .meta .k { font-size: 9.5px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 10px; }
.con-final .meta .v { font-size: 13.5px; letter-spacing: .04em; color: #fff; line-height: 1.45; }

/* ── footer ─────────────────────────────────────────────── */
.con-foot {
  padding: 22px 32px; background: #14081d;
  color: rgba(255,255,255,.45);
  font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  display: flex; align-items: center; gap: 28px;
}
.con-foot .spacer { flex: 1; }

/* floating whatsapp */
.con-wa-float {
  position: absolute; right: 24px; bottom: 24px; z-index: 4;
  background: #1f8a4d; color: #fff;
  border: 0; border-radius: 4px;
  height: 56px; padding: 0 22px;
  display: inline-flex; align-items: center; gap: 12px;
  font: 600 11px/1 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: .22em;
  box-shadow: 0 14px 30px -10px rgba(31,138,77,.5);
}

/* Designer annotation — points at "Book a Call" buttons to document behaviour */
.con-design-note {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 9.5px/1.3 'JetBrains Mono', monospace;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--orange);
  background: rgba(205,66,25,.06);
  border: 1px dashed var(--orange);
  border-radius: 3px;
  padding: 5px 9px;
  white-space: nowrap;
}
.con-design-note::before {
  content: '↳'; font-weight: 700; opacity: .8;
}
.con-final .con-design-note {
  color: #ffb89e;
  background: rgba(255,184,158,.06);
  border-color: rgba(255,184,158,.5);
}


/* ───────────────────────────────────────────────────────────
   APP ADDITIONS — behaviour the static prototype implied but
   didn't wire (FAQ accordion, Supabase-rendered grids, loading).
   ─────────────────────────────────────────────────────────── */

/* Curated route specs render as a 2-column grid (matches final design) */
.con-trek .specs { grid-template-columns: repeat(2, 1fr); gap: 14px; }
.con-trek .spec.full { grid-column: 1 / -1; }
.con-trek .spec .sub {
  font-size: 9px; color: var(--ink-soft); letter-spacing: .14em;
  font-weight: 500; margin-top: 3px; text-transform: uppercase;
}

/* FAQ accordion — answers hidden until the item is open */
.con-faq-item { cursor: pointer; }
.con-faq-item .a { display: none; }
.con-faq-item.open .a { display: block; }

/* Loading / empty / error state for Supabase-backed sections */
.con-data-state {
  grid-column: 1 / -1;
  padding: 40px 22px;
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-soft); text-align: center;
}
.con-data-state.error { color: var(--orange); }
.con-faq .con-data-state { text-align: left; padding: 28px 0; }

/* ───────────────────────────────────────────────────────────
   RESPONSIVE LAYER
   Desktop design is preserved at >1080px. Below that we
   progressively collapse multi-column grids to single column,
   shrink display type, and tighten section padding.
   ─────────────────────────────────────────────────────────── */

/* ─── Tablet: 1080px and below ────────────────────────────── */
@media (max-width: 1080px) {
  .con { font-size: 12.5px; }

  /* Status bar wraps */
  .con-status { flex-wrap: wrap; gap: 14px 22px; padding: 10px 22px; }
  .con-status .spacer { display: none; }

  /* Nav wraps; hide secondary links */
  .con-nav { gap: 20px; padding: 16px 22px; flex-wrap: wrap; }
  .con-nav .nav-links { gap: 22px; margin-left: 0; }

  /* Hero collapses to single column */
  .con-hero { grid-template-columns: 1fr; gap: 40px; padding: 48px 22px 56px; }
  .con-hero h1 { font-size: 48px; }
  .con-hero .lede { font-size: 15px; max-width: none; }

  /* Sections */
  .con-sec { padding: 72px 22px; }
  .con-sec-hd { flex-direction: column; align-items: flex-start; gap: 18px; margin-bottom: 36px; }
  .con-sec-hd .right { text-align: left; min-width: 0; }
  .con-sec-hd h2 { font-size: 36px; }

  /* Spectrum becomes 1 col but keeps emphasis card prominence */
  .con-spectrum { grid-template-columns: 1fr; gap: 16px; }
  .con-spec-col.us { transform: none; }

  /* 3-up grids become 2-up */
  .con-feats { grid-template-columns: repeat(2, 1fr); }
  .con-trek-grid { grid-template-columns: repeat(2, 1fr); }
  .con-quotes { grid-template-columns: repeat(2, 1fr); }

  /* Feat-demo rows: prevent value/label misalignment when label wraps */
  .con-feat-demo .row { align-items: flex-start; gap: 14px; }
  .con-feat-demo .row > :last-child { white-space: nowrap; text-align: right; flex-shrink: 0; }

  /* Stats 4 → 2 */
  .con-stats { grid-template-columns: repeat(2, 1fr); }
  .con-stat + .con-stat:nth-child(3) { border-left: 0; border-top: 1px solid var(--rule-soft); }
  .con-stat:nth-child(3), .con-stat:nth-child(4) { border-top: 1px solid var(--rule-soft); }

  /* Talk-to-local 2 → 1 */
  .con-talk-grid { grid-template-columns: 1fr; }
  .con-talk-hd { flex-direction: column; align-items: flex-start; gap: 14px; }
  .con-talk-hd h2 { font-size: 36px; }
  .con-talk-hd .right { text-align: left; min-width: 0; }

  /* Form 2 → 1 */
  .con-form-wrap { grid-template-columns: 1fr; gap: 40px; }
  .con-form-side h2 { font-size: 34px; }

  /* Final CTA */
  .con-final { padding: 72px 22px 64px; }
  .con-final h2 { font-size: 44px; }
  .con-final .meta-row { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .con-final .meta { padding-right: 0; }
}

/* ─── Mobile: 720px and below ─────────────────────────────── */
@media (max-width: 720px) {
  .con { font-size: 12px; }

  /* Status bar: keep just the essentials */
  .con-status { gap: 10px 14px; padding: 9px 16px; font-size: 9.5px; letter-spacing: .16em; }
  .con-status .item:nth-child(n+4) { display: none; }

  /* Nav: compact single-row header with logo + buttons */
  .con-nav {
    padding: 12px 14px;
    gap: 10px;
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
  }
  .con-nav .logo img { width: 96px; }
  .con-nav .nav-links {
    margin-left: 0;
    gap: 14px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--rule-soft);
  }
  .con-nav .nav-links a { font-size: 10px; flex-shrink: 0; }
  .con-nav .nav-spacer { flex: 1; min-width: 6px; }
  .con-nav .right {
    width: auto;
    gap: 6px;
    flex-direction: row;
    flex-shrink: 0;
  }
  .con-nav .right .btn {
    flex: 0 0 auto;
    justify-content: center;
    padding: 0 10px;
    gap: 6px;
    height: 36px;
    font-size: 9.5px;
    letter-spacing: .14em;
  }
  .con-nav .right .btn svg { width: 13px; height: 13px; }
  .con-nav .btn .lbl-full { display: none; }
  .con-nav .btn .lbl-short { display: inline; }

  /* Hero */
  .con-hero { padding: 36px 16px 44px; gap: 32px; }
  .con-hero h1 { font-size: 34px; line-height: 1.05; margin-bottom: 20px; letter-spacing: -.02em; }
  .con-hero .lede { font-size: 14px; margin-bottom: 26px; }
  .con-hero .cta-row { flex-wrap: wrap; gap: 8px; margin-bottom: 32px; }
  .con-hero .cta-row .btn { flex: 1 1 100%; justify-content: center; }
  .con-hero .cta-row .note { flex: 1 1 100%; text-align: center; margin-left: 0; }
  .con-hero .crumb { margin-bottom: 18px; font-size: 9.5px; letter-spacing: .18em; }

  /* Trust strip: stack to single column rows */
  .con-hero .trust { grid-template-columns: 1fr; }
  .con-hero .trust .item + .item { border-left: 0; border-top: 1px solid var(--rule-soft); }
  .con-hero .trust .v { font-size: 16px; }

  /* Support console mock: tighten */
  .con-console-hd { padding: 10px 12px; flex-wrap: wrap; gap: 8px; }
  .con-console-hd .title { font-size: 10px; }
  .con-console-hd .right { font-size: 9px; gap: 10px; }
  .con-console-meta { grid-template-columns: 1fr; }
  .con-console-meta .m + .m { border-left: 0; border-top: 1px solid var(--rule-soft); }
  .con-msg { grid-template-columns: 56px 1fr; gap: 10px; padding: 14px 12px; }
  .con-msg .body p { font-size: 12px; }
  .con-msg .body .meta-row { gap: 8px 12px; font-size: 9.5px; }
  .con-input-bar { padding: 10px 12px; flex-wrap: wrap; }
  .con-input-bar input { font-size: 12px; padding: 9px 10px; }

  /* Kicker / spectrum lede */
  .con-kicker { font-size: 11px; gap: 10px; }
  .con-kicker .sub { font-size: 10px; }
  .con-spectrum-lede { font-size: 14.5px; margin-bottom: 36px; text-align: left; }

  /* All sections */
  .con-sec { padding: 56px 16px; }
  .con-sec-hd { margin-bottom: 28px; gap: 14px; }
  .con-sec-hd h2 { font-size: 28px; line-height: 1.08; }

  /* 3- & 2-up grids → 1 */
  .con-feats { grid-template-columns: 1fr; }
  .con-trek-grid { grid-template-columns: 1fr; }
  .con-quotes { grid-template-columns: 1fr; }

  .con-feat { padding: 22px 20px 22px 24px; gap: 14px; }
  .con-feat h3 { font-size: 16px; }
  .con-feat p { font-size: 13px; }
  .con-feat-demo .row { align-items: flex-start; gap: 14px; }
  .con-feat-demo .row > :last-child { white-space: nowrap; text-align: right; flex-shrink: 0; }

  /* Trek cards */
  .con-trek .img { height: 200px; }
  .con-trek .body { padding: 18px; gap: 12px; }
  .con-trek h3 { font-size: 20px; }
  .con-trek .specs { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }

  /* Stats: 2 → 1 with rule between */
  .con-stats { grid-template-columns: 1fr; }
  .con-stat + .con-stat { border-left: 0; border-top: 1px solid var(--rule-soft); }
  .con-stat .v { font-size: 30px; }
  .con-stat { padding: 18px 20px; }

  /* Talk-to-local cards */
  .con-talk-hd h2 { font-size: 28px; }
  .con-talk-card { padding: 26px 22px; gap: 14px; }
  .con-talk-card h3 { font-size: 22px; }
  .con-talk-card .desc { font-size: 13.5px; }
  .con-talk-card .big-btn { height: 56px; font-size: 12px; letter-spacing: .18em; padding: 0 18px; }
  .con-talk-slots { grid-template-columns: repeat(2, 1fr); }
  .con-brief-disclose { flex-direction: column; align-items: flex-start; gap: 12px; padding: 14px 16px; }
  .con-brief-disclose .left { font-size: 11px; }

  /* Quote cards */
  .con-quote { padding: 22px 20px; gap: 14px; }
  .con-quote .text { font-size: 13.5px; }

  /* Form */
  .con-form-wrap { gap: 32px; }
  .con-form-side h2 { font-size: 28px; }
  .con-form-side .lede { font-size: 14px; }
  .con-form-side .alt { flex-direction: column; align-items: flex-start; gap: 10px; }
  .con-form-hd { padding: 12px 16px; }
  .con-form-body { padding: 18px 16px; }
  .con-form-title { font-size: 19px; }
  .con-form .field-grid { grid-template-columns: 1fr; gap: 14px; }
  .con-form .scale { grid-template-columns: repeat(5, 1fr); gap: 4px; }
  .con-form .scale .lvl { padding: 10px 2px; }
  .con-form .scale .lvl .n { font-size: 14px; }
  .con-form .scale .lvl .lbl { font-size: 8px; letter-spacing: .14em; }
  .con-form .chip { font-size: 9.5px; padding: 6px 10px; letter-spacing: .14em; }
  .con-form-foot { padding: 14px 16px; flex-direction: column; align-items: stretch; gap: 12px; }
  .con-form-foot .actions { width: 100%; }
  .con-form-foot .actions .btn { flex: 1; justify-content: center; }

  /* Comparison table: collapse 3-col grid to stacked rows */
  .con-compare-hd { display: none; }
  .con-compare-row {
    grid-template-columns: 1fr;
    padding: 4px 0 8px;
    border-bottom: 1px solid var(--rule);
  }
  .con-compare-row:last-child { border-bottom: 0; }
  .con-compare-row .c { padding: 14px 18px; font-size: 12.5px; }
  .con-compare-row .c + .c { border-left: 0; border-top: 1px solid var(--rule-soft); }
  .con-compare-row .c.k {
    background: var(--cream-2);
    font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
    color: var(--ink-soft); padding: 10px 18px;
  }
  .con-compare-row .c.them::before {
    content: 'TYPICAL PLATFORM →'; display: block;
    font-size: 9px; letter-spacing: .22em; color: var(--ink-faint);
    margin-bottom: 6px; font-weight: 600;
  }
  .con-compare-row .c.us::before {
    content: '◆ ALTURA →'; display: block;
    font-size: 9px; letter-spacing: .22em; color: var(--orange);
    margin-bottom: 6px; font-weight: 600;
  }

  /* FAQ */
  .con-faq-item { grid-template-columns: 1fr; gap: 8px; padding: 18px 0; position: relative; }
  .con-faq-item .num { padding-top: 0; font-size: 9.5px; }
  .con-faq-item .q { font-size: 15px; padding-right: 28px; }
  .con-faq-item .a { font-size: 13px; }
  .con-faq-item .chev {
    position: absolute; top: 18px; right: 0; padding-top: 0;
  }

  /* Final CTA */
  .con-final { padding: 56px 16px 52px; }
  .con-final h2 { font-size: 32px; line-height: 1.06; }
  .con-final .lede { font-size: 14px; }
  .con-final .cta-row { flex-direction: column; align-items: stretch; gap: 8px; margin-bottom: 40px; }
  .con-final .cta-row .btn { justify-content: center; }
  .con-final .meta-row { grid-template-columns: 1fr; gap: 16px; padding-top: 22px; }
  .con-final .meta { padding-right: 0; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,.08); }
  .con-final .meta:last-child { border-bottom: 0; padding-bottom: 0; }

  /* Footer */
  .con-foot { flex-wrap: wrap; gap: 10px 18px; padding: 18px 16px; font-size: 9.5px; }
  .con-foot .spacer { display: none; }

  /* Floating WhatsApp: shrink and stay clear of content */
  .con-wa-float {
    right: 14px; bottom: 14px;
    height: 48px; padding: 0 16px;
    font-size: 10px; letter-spacing: .16em; gap: 8px;
  }
}

/* ─── Small mobile: 420px and below ──────────────────────── */
@media (max-width: 420px) {
  .con-hero h1 { font-size: 30px; }
  .con-sec-hd h2 { font-size: 24px; }
  .con-talk-hd h2 { font-size: 24px; }
  .con-final h2 { font-size: 28px; }
  .con-talk-slots { grid-template-columns: repeat(2, 1fr); }
  .con-nav { padding: 10px 12px; gap: 8px; }
  .con-nav .logo img { width: 84px; }
  .con-nav .nav-links { gap: 12px; }
  .con-nav .right { gap: 5px; }
  .con-nav .right .btn {
    width: auto;
    padding: 0 9px;
    font-size: 9px;
    letter-spacing: .12em;
    height: 34px;
    gap: 5px;
  }
  .con-nav .right .btn svg { width: 12px; height: 12px; }
  .con-wa-float .arrow,
  .con-wa-float { font-size: 9.5px; padding: 0 14px; }
}

/* ════════════════════════════════════════════════════════════════════════
   BOOKING JOURNEY — explore library · route detail · booking pipeline.
   Ported from the design prototype (booking.css + journey.css), built on the
   .con tokens above. Every journey root carries .con (tokens) + .bk. Mounted
   full-viewport into #journey.app-shell by booking.js.
   ════════════════════════════════════════════════════════════════════════ */

/* full-viewport app-shell (journey screens own their inner scroll) */
.app-shell {
  height: 100dvh; max-width: 1440px; margin: 0 auto;
  background: var(--cream); position: relative;
  box-shadow: 0 0 80px rgba(31, 12, 42, .08); overflow: hidden;
}
@media (max-width: 900px) { .app-shell { box-shadow: none; } }

.bk {
  --accent: var(--orange);
  --stripe: #635bff;
  --ok: var(--green);
  height: 100%; display: flex; flex-direction: column;
  background: var(--cream); color: var(--ink);
  font-family: 'JetBrains Mono', ui-monospace, monospace; overflow: hidden;
}
.bk * { box-sizing: border-box; }
.bk button { font-family: inherit; cursor: pointer; }
.bk .accent { color: var(--accent); }
.bk > .con-status, .bk > .con-nav,
.jn > .con-status, .jn > .con-nav { flex-shrink: 0; }

/* shared step heading */
.bk-step-head { margin-bottom: 18px; }
.bk-step-head .kick { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--accent); font-weight: 600; display: block; margin-bottom: 10px; }
.bk-step-head h2 { font-family: 'JetBrains Mono', monospace; font-weight: 600; font-size: 30px; line-height: 1.04; letter-spacing: -.02em; margin: 0; }
.bk-step-head h2 .em { color: var(--accent); }
.bk-step-head .sub { font-size: 13px; color: var(--ink-soft); margin: 10px 0 0; line-height: 1.5; max-width: 620px; letter-spacing: .01em; }
.bk-step-head .sub b { color: var(--ink); font-weight: 600; }

/* pipeline stepper */
.bk-pipe { display: flex; align-items: stretch; flex-shrink: 0; background: var(--cream-2); border-bottom: 1px solid var(--rule); padding: 0 12px; }
.bk-pipe .seg { flex: 1; display: flex; align-items: center; gap: 10px; padding: 13px 10px; position: relative; min-width: 0; color: var(--ink-faint); }
.bk-pipe .seg + .seg::before { content: '›'; position: absolute; left: -3px; top: 50%; transform: translateY(-50%); color: var(--rule); font-size: 13px; }
.bk-pipe .seg .n { width: 24px; height: 24px; flex-shrink: 0; border-radius: 3px; border: 1px solid var(--rule); background: #fff; display: grid; place-items: center; font-size: 10px; font-weight: 600; letter-spacing: .02em; }
.bk-pipe .seg .t { font-size: 9.5px; letter-spacing: .18em; text-transform: uppercase; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bk-pipe .seg.done { color: var(--ink-soft); }
.bk-pipe .seg.done .n { background: var(--ink); border-color: var(--ink); color: #fff; }
.bk-pipe .seg.active { color: var(--ink); }
.bk-pipe .seg.active .n { background: var(--accent); border-color: var(--accent); color: #fff; box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent); }
.bk-pipe .seg.active .t { font-weight: 700; }
.bk-pipe-compact { display: none; }

.bk-stage { flex: 1; min-height: 0; overflow: hidden; padding: 26px 30px; display: flex; flex-direction: column; }

/* sticky bottom summary bar */
.bk-bar { flex-shrink: 0; display: flex; align-items: center; gap: 22px; padding: 0 24px; height: 76px; background: #14081d; color: #fff; }
.bk-bar .facts { display: flex; align-items: center; gap: 22px; min-width: 0; overflow: hidden; }
.bk-bar .fact { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.bk-bar .fact .k { font-size: 8.5px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.45); }
.bk-bar .fact .v { font-size: 12.5px; font-weight: 600; letter-spacing: .01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bk-bar .fact .v.big { font-size: 17px; }
.bk-bar .fact .v .accent { color: #ff8a5e; }
.bk-bar .vr { width: 1px; align-self: stretch; margin: 18px 0; background: rgba(255,255,255,.12); }
.bk-bar .spacer { flex: 1; }
.bk-bar .acts { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.bk .btn.back { background: transparent; border-color: rgba(255,255,255,.32); color: #fff; }
.bk .btn.go { background: var(--accent); border-color: var(--accent); color: #fff; }
.bk .btn.go[disabled] { opacity: .4; pointer-events: none; }
.bk .btn.lg2 { height: 46px; padding: 0 22px; font-size: 12px; }

/* step content scroll area (container-width responsive) */
.bk-scroll { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; container-type: size; }

/* routes picker */
.bk-routes { display: grid; grid-template-columns: repeat(auto-fill, minmax(218px, 1fr)); gap: 14px; }
.bk-route { background: #fff; border: 1px solid var(--rule); border-radius: 4px; overflow: hidden; display: flex; flex-direction: column; cursor: pointer; transition: border-color .15s, box-shadow .15s, transform .15s; }
.bk-route:hover { border-color: var(--accent); box-shadow: 0 10px 28px -16px rgba(31,12,42,.4); transform: translateY(-2px); }
.bk-route.sel { border-color: var(--accent); box-shadow: 0 0 0 1.5px var(--accent), 0 12px 30px -16px rgba(205,66,25,.5); }
.bk-route .img { height: 116px; position: relative; overflow: hidden; background: var(--cream-2); }
.bk-route .img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.bk-route .ribbon { position: absolute; top: 10px; left: 10px; background: var(--violet); color: #fff; font-size: 8px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; padding: 4px 8px; border-radius: 2px; }
.bk-route .id-tag { position: absolute; top: 10px; right: 10px; background: rgba(255,255,255,.92); color: var(--ink); font-size: 8px; letter-spacing: .16em; padding: 4px 8px; border-radius: 2px; font-weight: 600; }
.bk-route .check { position: absolute; bottom: 10px; right: 10px; width: 24px; height: 24px; border-radius: 50%; background: var(--accent); color: #fff; display: none; place-items: center; font-size: 13px; }
.bk-route.sel .check { display: grid; }
.bk-route .body { padding: 14px 15px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.bk-route h3 { font-size: 17px; font-weight: 600; letter-spacing: -.01em; margin: 0; }
.bk-route .tag { font-size: 11px; line-height: 1.45; color: var(--ink-soft); margin: 0; }
.bk-route .specs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding-top: 11px; border-top: 1px solid var(--rule-soft); margin-top: auto; }
.bk-route .specs .k { font-size: 8px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 3px; }
.bk-route .specs .v { font-size: 11px; font-weight: 600; }
.bk-route .price-row { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; padding: 11px 15px; border-top: 1px solid var(--rule-soft); background: var(--cream); white-space: nowrap; }
.bk-route .price-row > div { min-width: 0; }
.bk-route .price-row .p { font-size: 16px; font-weight: 700; }
.bk-route .price-row .pp { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); margin-left: 3px; font-weight: 500; }
.bk-route .price-row .pick { font-size: 9px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--accent); }
.bk-custom-card { margin-top: 14px; display: flex; align-items: center; gap: 18px; padding: 16px 20px; border: 1px dashed var(--rule); border-radius: 4px; background: var(--cream-2); cursor: pointer; transition: border-color .15s, background .15s; }
.bk-custom-card:hover { border-color: var(--accent); background: #fff; }
.bk-custom-card .ic { width: 38px; height: 38px; border-radius: 4px; border: 1px solid var(--rule); display: grid; place-items: center; color: var(--violet); background: #fff; flex-shrink: 0; }
.bk-custom-card .tx { flex: 1; min-width: 0; }
.bk-custom-card .tx .t { font-size: 13px; font-weight: 600; }
.bk-custom-card .tx .t .em { color: var(--accent); }
.bk-custom-card .tx .d { font-size: 11px; color: var(--ink-soft); margin-top: 3px; letter-spacing: .01em; }
.bk-custom-card .go-tag { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; font-weight: 700; color: var(--accent); white-space: nowrap; }

/* dates */
.bk-dates { display: flex; flex-direction: column; gap: 16px; }
.bk-month .ml { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 9px; font-weight: 600; }
.bk-month .grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(124px, 1fr)); gap: 8px; }
.bk-datechip { border: 1px solid var(--rule); background: #fff; border-radius: 4px; padding: 11px 12px; cursor: pointer; transition: border-color .15s, transform .12s; position: relative; }
.bk-datechip:hover { border-color: var(--accent); transform: translateY(-1px); }
.bk-datechip.sel { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 7%, #fff); box-shadow: 0 0 0 1.5px var(--accent); }
.bk-datechip .dow { font-size: 8.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-soft); }
.bk-datechip .dd { font-size: 17px; font-weight: 700; letter-spacing: -.01em; margin: 3px 0 6px; }
.bk-datechip .spots { font-size: 8px; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; display: inline-flex; align-items: center; gap: 5px; }
.bk-datechip .spots .sd { width: 5px; height: 5px; border-radius: 50%; }
.bk-datechip .spots.low { color: #8a6314; } .bk-datechip .spots.low .sd { background: #c9892a; }
.bk-datechip .spots.ok { color: var(--green); } .bk-datechip .spots.ok .sd { background: var(--green); }
.bk-datechip.sel .check { position: absolute; top: 8px; right: 8px; color: var(--accent); font-size: 12px; }
.bk-datechip .flexnote { margin-top: 7px; padding-top: 6px; border-top: 1px dashed color-mix(in srgb, var(--accent) 35%, var(--rule)); font-size: 8px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; color: var(--accent); }
.bk-flex { display: flex; align-items: center; justify-content: space-between; gap: 18px 24px; flex-wrap: wrap; margin-top: 18px; padding: 15px 18px; border: 1px solid var(--rule); border-radius: 6px; background: var(--cream-2); transition: border-color .15s, background .15s; }
.bk-flex.active { border-color: color-mix(in srgb, var(--accent) 42%, var(--rule)); background: color-mix(in srgb, var(--accent) 4%, #fff); }
.bk-flex.idle { opacity: .9; }
.bk-flex-txt { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.bk-flex .lbl { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); font-weight: 700; }
.bk-flex .hint { font-size: 12px; line-height: 1.45; color: var(--ink-soft); letter-spacing: .01em; max-width: 470px; }
.bk-flex .opts { display: flex; gap: 6px; flex-shrink: 0; }
.bk-flex .opt { border: 1px solid var(--rule); background: #fff; border-radius: 999px; padding: 8px 15px; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; cursor: pointer; transition: border-color .12s, background .12s, color .12s; }
.bk-flex .opt:hover { border-color: var(--accent); }
.bk-flex .opt.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.bk-reqdate { margin-top: 18px; border: 1px dashed color-mix(in srgb, var(--accent) 45%, var(--rule)); border-radius: 6px; background: var(--cream-2); padding: 18px 20px; transition: border-color .15s, background .15s, box-shadow .15s; }
.bk-reqdate.on { border-style: solid; border-color: var(--accent); background: color-mix(in srgb, var(--accent) 5%, #fff); box-shadow: 0 0 0 1.5px var(--accent); }
.bk-reqdate .hd .kick { font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); font-weight: 700; }
.bk-reqdate .hd p { font-size: 12.5px; line-height: 1.55; color: var(--ink-soft); margin: 8px 0 0; max-width: 560px; letter-spacing: .01em; }
.bk-reqdate .row { display: flex; align-items: center; gap: 12px; margin-top: 14px; }
.bk-reqdate .row label { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.bk-reqdate .row input { font: 600 13px/1 'JetBrains Mono', monospace; color: var(--ink); border: 1px solid var(--rule); border-radius: 4px; padding: 10px 12px; background: #fff; letter-spacing: .04em; }
.bk-reqdate .row input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1.5px var(--accent); }
.bk-reqdate .ok { display: flex; align-items: flex-start; gap: 8px; margin-top: 14px; font-size: 12px; line-height: 1.5; color: var(--ink); letter-spacing: .01em; }
.bk-reqdate .ok .c { color: var(--green); font-weight: 700; }
.bk-dates-layout { display: grid; grid-template-columns: minmax(0, 1fr) 326px; gap: 28px; align-items: start; }
.bk-dates-main { min-width: 0; }
.bk-dates-side { position: sticky; top: 0; height: 100cqh; display: flex; }
.bk-itin-prev { flex: 1; display: flex; flex-direction: column; min-height: 0; border: 1px solid var(--rule); border-radius: 6px; background: var(--cream-2); overflow: hidden; }
.bk-itin-prev .ip-hd { flex-shrink: 0; padding: 15px 16px 13px; border-bottom: 1px solid var(--rule); background: #fff; display: flex; flex-direction: column; gap: 5px; }
.ip-hd .kick { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); font-weight: 700; }
.ip-hd .range { font-size: 17px; font-weight: 700; letter-spacing: -.01em; }
.ip-hd .meta { font-size: 8.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.bk-itin-prev .ip-days { flex: 1; min-height: 0; display: flex; flex-direction: column; padding: 4px 16px 12px; overflow: hidden; }
.ip-day { flex: 1 1 auto; min-height: min-content; display: grid; grid-template-columns: 28px 1fr; align-content: center; gap: 11px 11px; padding: 10px 0; border-bottom: 1px dashed var(--rule); }
.ip-day:last-child { border-bottom: 0; }
.ip-rail .n { width: 26px; height: 26px; border-radius: 50%; background: var(--violet); color: #fff; display: grid; place-items: center; font: 700 10px/1 'JetBrains Mono', monospace; }
.ip-body { min-width: 0; }
.ip-body .dt { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); font-weight: 700; }
.ip-body .ti { font-size: 13px; font-weight: 600; letter-spacing: -.01em; margin: 3px 0; }
.ip-body .leg { font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.ip-body .leg .ar { color: var(--accent); margin: 0 2px; }
.ip-body .stay { font-size: 10.5px; color: var(--ink-soft); margin-top: 5px; letter-spacing: .01em; }
.ip-body .stay.end { color: var(--accent); font-weight: 700; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; }
.bk-itin-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; border: 1px dashed var(--rule); border-radius: 6px; background: var(--cream-2); padding: 30px 22px; text-align: center; color: var(--ink-soft); }
.bk-itin-empty .ic { font-size: 22px; color: var(--ink-faint); display: block; margin-bottom: 10px; }
.bk-itin-empty p { font-size: 12px; line-height: 1.5; margin: 0; letter-spacing: .01em; }
@media (max-width: 880px) {
  .bk-dates-layout { grid-template-columns: 1fr; gap: 18px; }
  .bk-dates-side { position: static; height: auto; display: block; }
  .ip-day { flex: 0 0 auto; padding: 12px 0; }
}

/* party */
.bk-party-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
.bk-stepper { background: #fff; border: 1px solid var(--rule); border-radius: 5px; padding: 26px 28px; display: flex; flex-direction: column; gap: 18px; align-items: center; text-align: center; }
.bk-stepper .lbl { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); }
.bk-stepper .ctl { display: flex; align-items: center; gap: 22px; }
.bk-stepper .pm { width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--ink); background: var(--cream); color: var(--ink); font-size: 22px; line-height: 1; display: grid; place-items: center; }
.bk-stepper .pm[disabled] { opacity: .3; pointer-events: none; }
.bk-stepper .num { font-size: 56px; font-weight: 700; letter-spacing: -.03em; min-width: 80px; }
.bk-stepper .who { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); }
.bk-party-note { background: var(--cream-2); border: 1px solid var(--rule); border-radius: 5px; padding: 20px 22px; display: flex; flex-direction: column; gap: 12px; }
.bk-party-note .row { display: flex; justify-content: space-between; align-items: baseline; font-size: 12px; padding: 8px 0; border-bottom: 1px dashed var(--rule); }
.bk-party-note .row:last-child { border-bottom: 0; }
.bk-party-note .row .k { letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-size: 9.5px; }
.bk-party-note .row .v { font-weight: 600; }
.bk-party-note .row .v.big { font-size: 18px; }
.bk-party-note .hint { font-size: 11px; line-height: 1.5; color: var(--ink-soft); letter-spacing: .01em; }
.bk-party-note .hint b { color: var(--ink); }

/* addons */
.bk-addons { display: flex; flex-direction: column; gap: 9px; }
.bk-addon { display: flex; align-items: center; gap: 16px; padding: 14px 18px; background: #fff; border: 1px solid var(--rule); border-radius: 4px; cursor: pointer; transition: border-color .15s; }
.bk-addon:hover { border-color: var(--ink-soft); }
.bk-addon.on { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 4%, #fff); }
.bk-addon .box { width: 22px; height: 22px; border-radius: 4px; border: 1.5px solid var(--rule); display: grid; place-items: center; flex-shrink: 0; color: #fff; font-size: 13px; }
.bk-addon.on .box { background: var(--accent); border-color: var(--accent); }
.bk-addon .tx { flex: 1; min-width: 0; }
.bk-addon .tx .n { font-size: 13px; font-weight: 600; }
.bk-addon .tx .m { font-size: 10.5px; color: var(--ink-soft); margin-top: 2px; letter-spacing: .01em; }
.bk-addon .rq { font-size: 9px; letter-spacing: .16em; text-transform: uppercase; font-weight: 700; white-space: nowrap; color: var(--ink-soft); border: 1px solid var(--rule); border-radius: 999px; padding: 6px 12px; }
.bk-addon.on .rq.on { color: #fff; background: var(--accent); border-color: var(--accent); }
.bk-addon-note { display: flex; align-items: center; gap: 9px; margin-top: 14px; padding: 12px 16px; border: 1px dashed var(--rule); border-radius: 5px; background: var(--cream-2); font-size: 11.5px; line-height: 1.45; color: var(--ink-soft); letter-spacing: .01em; }
.bk-addon-note svg { flex-shrink: 0; color: var(--ink-soft); }
.bk-extras { margin: 0; padding: 12px 20px; border-top: 1px dashed var(--rule); }
.bk-extras .eh { font-size: 8.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); font-weight: 700; margin-bottom: 8px; }
.bk-extras .el { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; padding: 4px 0; font-size: 12px; }
.bk-extras .el .l { color: var(--ink); }
.bk-extras .el .r { font-size: 8.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 700; white-space: nowrap; }

/* forms (details + custom) */
.bk-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 16px; }
.bk-field { display: flex; flex-direction: column; gap: 6px; }
.bk-field.full { grid-column: 1 / -1; }
.bk-field label { font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink); font-weight: 500; }
.bk-field label .req { color: var(--accent); }
.bk-field input, .bk-field select, .bk-field textarea { width: 100%; border: 1px solid var(--rule); border-radius: 3px; padding: 11px 12px; background: #fff; color: var(--ink); font: 500 13px/1.4 'JetBrains Mono', monospace; outline: none; }
.bk-field input:focus, .bk-field select:focus, .bk-field textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent); }
.bk-field input::placeholder, .bk-field textarea::placeholder { color: var(--ink-faint); }
.bk-field textarea { resize: none; min-height: 64px; }
.bk-consent { grid-column: 1 / -1; display: flex; align-items: flex-start; gap: 10px; font-size: 11px; line-height: 1.5; color: var(--ink-soft); letter-spacing: .01em; }
.bk-consent .box { width: 18px; height: 18px; border: 1.5px solid var(--rule); border-radius: 3px; flex-shrink: 0; display: grid; place-items: center; color: #fff; font-size: 11px; cursor: pointer; margin-top: 1px; }
.bk-consent .box.on { background: var(--accent); border-color: var(--accent); }
.bk-consent a { color: var(--accent); }
.bk-scale { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.bk-scale .lvl { border: 1px solid var(--rule); background: #fff; padding: 11px 4px; text-align: center; border-radius: 3px; cursor: pointer; }
.bk-scale .lvl .n { font-size: 16px; font-weight: 700; }
.bk-scale .lvl .l { font-size: 8px; letter-spacing: .16em; color: var(--ink-soft); text-transform: uppercase; margin-top: 3px; }
.bk-scale .lvl.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.bk-scale .lvl.on .l { color: rgba(255,255,255,.85); }
.bk-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.bk-chip { border: 1px solid var(--rule); border-radius: 999px; padding: 7px 12px; font-size: 9.5px; letter-spacing: .16em; text-transform: uppercase; background: #fff; color: var(--ink); font-weight: 500; cursor: pointer; }
.bk-chip.on { background: var(--ink); color: #fff; border-color: var(--ink); }

/* payment */
.bk-pay { display: grid; grid-template-columns: 1fr 360px; gap: 22px; align-items: start; }
.bk-summary { background: #fff; border: 1px solid var(--rule); border-radius: 5px; overflow: hidden; }
.bk-summary .sh { padding: 14px 20px; border-bottom: 1px solid var(--rule-soft); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; display: flex; justify-content: space-between; }
.bk-summary .sh .edit { color: var(--accent); cursor: pointer; }
.bk-line { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; padding: 11px 20px; border-bottom: 1px solid var(--rule-soft); font-size: 12.5px; }
.bk-line .l { color: var(--ink); }
.bk-line .l small { display: block; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); margin-top: 3px; }
.bk-line .r { font-weight: 600; white-space: nowrap; }
.bk-line.tot { background: var(--cream-2); font-size: 14px; }
.bk-line.tot .r { font-size: 16px; font-weight: 700; }
.bk-checkout { background: #fff; border: 1px solid var(--rule); border-radius: 5px; padding: 22px; display: flex; flex-direction: column; gap: 16px; }
.bk-checkout .due { text-align: center; }
.bk-checkout .due .k { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); }
.bk-checkout .due .v { font-size: 38px; font-weight: 700; letter-spacing: -.02em; margin: 6px 0 4px; }
.bk-checkout .due .pct { font-size: 18px; color: var(--accent); }
.bk-checkout .due .sub { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); }
.bk-balance { background: var(--cream-2); border-radius: 4px; padding: 12px 14px; display: flex; flex-direction: column; gap: 6px; }
.bk-balance .row { display: flex; justify-content: space-between; font-size: 11px; }
.bk-balance .row .k { letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); font-size: 9.5px; }
.bk-balance .row .v { font-weight: 600; }
.bk-stripe-btn { display: flex; align-items: center; justify-content: center; gap: 10px; height: 56px; border: 0; border-radius: 5px; background: var(--stripe); color: #fff; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; box-shadow: 0 10px 24px -10px color-mix(in srgb, var(--stripe) 70%, transparent); }
.bk-stripe-btn:hover { filter: brightness(1.06); }
.bk-secure-note { font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); text-align: center; line-height: 1.6; }
.bk-secure-note .cards { display: inline-flex; gap: 6px; margin-left: 4px; vertical-align: middle; }
.bk-secure-note .cards span { background: var(--cream-2); border: 1px solid var(--rule); border-radius: 3px; padding: 1px 5px; font-size: 8px; font-weight: 600; letter-spacing: .05em; color: var(--ink-soft); }
/* Stripe Payment Element host */
.bk-card-wrap { border: 1px solid var(--rule); border-radius: 5px; background: var(--cream-2); padding: 14px; min-height: 56px; }
#bk-card-element { min-height: 20px; }
.bk-card-status { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); text-align: center; padding: 8px 4px; }
.bk-card-status[data-act] { cursor: pointer; color: var(--accent); text-decoration: underline; }
.bk-pay-error { font-size: 11px; line-height: 1.45; color: #b23b1e; letter-spacing: .01em; min-height: 0; }
.bk-pay-error:empty { display: none; }

/* confirmation */
.bk-confirm { display: flex; flex-direction: column; align-items: center; text-align: center; justify-content: center; height: 100%; gap: 6px; overflow-y: auto; }
.bk-confirm .seal { width: 64px; height: 64px; border-radius: 50%; background: var(--ok); color: #fff; display: grid; place-items: center; font-size: 30px; margin-bottom: 10px; box-shadow: 0 0 0 8px color-mix(in srgb, var(--ok) 16%, transparent); }
.bk-confirm .kick { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ok); font-weight: 600; }
.bk-confirm h2 { font-size: 32px; font-weight: 600; letter-spacing: -.02em; margin: 6px 0 4px; }
.bk-confirm .ref { font-size: 12px; letter-spacing: .14em; color: var(--ink-soft); }
.bk-confirm .ref b { color: var(--ink); }
.bk-confirm .card2 { margin-top: 18px; width: min(560px, 100%); background: #fff; border: 1px solid var(--rule); border-radius: 5px; text-align: left; overflow: hidden; }
.bk-confirm .card2 .row { display: flex; justify-content: space-between; gap: 12px; padding: 12px 18px; border-bottom: 1px solid var(--rule-soft); font-size: 12.5px; }
.bk-confirm .card2 .row:last-child { border-bottom: 0; }
.bk-confirm .card2 .row .k { letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-size: 9.5px; }
.bk-confirm .card2 .row .v { font-weight: 600; text-align: right; }
.bk-confirm .next { margin-top: 18px; width: min(560px, 100%); display: flex; gap: 10px; }
.bk-confirm .next a, .bk-confirm .next button { flex: 1; height: 48px; }
.bk-confirm .whatsnext { margin-top: 16px; font-size: 12px; line-height: 1.6; color: var(--ink-soft); max-width: 560px; letter-spacing: .01em; }
.bk-confirm .whatsnext b { color: var(--ink); }

/* floating whatsapp */
.bk-wa-float { position: absolute; right: 18px; bottom: 96px; z-index: 6; display: inline-flex; align-items: center; gap: 9px; height: 46px; padding: 0 18px; border: 0; border-radius: 999px; background: #1f8a4d; color: #fff; font-size: 9.5px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; box-shadow: 0 12px 28px -10px rgba(31,138,77,.6); }
.bk-wa-float svg { width: 16px; height: 16px; }

/* ── journey: explore / library / route detail ─────────────────────────── */
.jn, .rd { height: 100%; display: flex; flex-direction: column; }
.jn-scroll, .rd-scroll { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; scroll-behavior: smooth; }
.jn .em, .rd .em { color: var(--accent); }
.rd-label { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--ink-soft); }
.rd-label.o { color: var(--accent); }
.rd-ph { position: relative; border-radius: 4px; overflow: hidden; background: repeating-linear-gradient(135deg, rgba(31,12,42,.05) 0 1px, transparent 1px 11px), var(--cream-2); border: 1px solid var(--rule); display: grid; place-items: center; }
.rd-ph span { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-faint); font-weight: 600; padding: 8px 12px; }
.rd-ph.sm span { font-size: 9px; }
.jn-foot { flex-shrink: 0; padding: 22px 28px; background: #14081d; color: rgba(255,255,255,.45); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; display: flex; align-items: center; gap: 26px; }
.jn-foot .sp { flex: 1; }
.jn-lede { font-size: 16px; line-height: 1.55; color: var(--ink-soft); max-width: 560px; margin: 0 0 30px; letter-spacing: .01em; }
.jn-lede b { color: var(--ink); font-weight: 600; }

/* route cards (library) */
.jn-route-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 18px; }
.jn-route { background: #fff; border: 1px solid var(--rule); border-radius: 4px; overflow: hidden; display: flex; flex-direction: column; cursor: pointer; transition: border-color .15s, box-shadow .15s, transform .15s; }
.jn-route:hover { border-color: var(--accent); box-shadow: 0 14px 34px -18px rgba(31,12,42,.45); transform: translateY(-3px); }
.jn-route .img { height: 180px; position: relative; overflow: hidden; background: var(--cream-2); }
.jn-route .img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.jn-route .ribbon { position: absolute; top: 12px; left: 12px; background: var(--violet); color: #fff; font-size: 8.5px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; padding: 5px 9px; border-radius: 2px; }
.jn-route .id { position: absolute; top: 12px; right: 12px; background: rgba(255,255,255,.92); color: var(--ink); font-size: 8.5px; letter-spacing: .16em; padding: 5px 9px; border-radius: 2px; font-weight: 600; }
.jn-route .body { padding: 20px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.jn-route h3 { font-size: 22px; font-weight: 600; letter-spacing: -.01em; margin: 0; }
.jn-route .tag { font-size: 13px; line-height: 1.5; color: var(--ink-soft); margin: 0; }
.jn-route .specs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding-top: 14px; border-top: 1px solid var(--rule-soft); margin-top: auto; }
.jn-route .specs .k { font-size: 8px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 4px; }
.jn-route .specs .v { font-size: 12px; font-weight: 600; }
.jn-route .foot { padding: 14px 20px; border-top: 1px solid var(--rule-soft); background: var(--cream); display: flex; align-items: center; justify-content: space-between; }
.jn-route .foot .price { font-size: 17px; font-weight: 700; }
.jn-route .foot .price small { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); margin-left: 4px; font-weight: 500; }
.jn-route .foot .view { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--accent); }

/* explore header + library */
.jn-explore-hd { padding: 48px 48px 30px; }
.jn-explore-hd h1 { font-family: 'JetBrains Mono', monospace; font-weight: 600; font-size: 42px; letter-spacing: -.02em; margin: 12px 0 16px; }
.jn-library { padding: 12px 48px 64px; }
.jn-custom { background: var(--cream-2); border: 1px dashed var(--rule); border-radius: 4px; padding: 26px 24px; display: flex; flex-direction: column; gap: 12px; cursor: pointer; transition: border-color .15s, background .15s; justify-content: center; }
.jn-custom:hover { border-color: var(--accent); background: #fff; }
.jn-custom .ic { width: 44px; height: 44px; border-radius: 4px; border: 1px solid var(--rule); display: grid; place-items: center; color: var(--violet); background: #fff; }
.jn-custom h3 { font-size: 22px; font-weight: 600; letter-spacing: -.01em; margin: 0; }
.jn-custom p { font-size: 13px; line-height: 1.55; color: var(--ink-soft); margin: 0; }
.jn-custom .go { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--accent); margin-top: auto; }

/* route detail */
.rd-bookbar { flex-shrink: 0; display: flex; align-items: center; gap: 16px; height: 76px; padding: 0 28px; background: #14081d; color: #fff; border-top: 1px solid rgba(255,255,255,.1); box-shadow: 0 -10px 30px -16px rgba(0,0,0,.4); }
.rd-bookbar .info .nm { font-size: 15px; font-weight: 600; letter-spacing: -.01em; }
.rd-bookbar .info .nm .id { font-size: 9px; letter-spacing: .16em; color: rgba(255,255,255,.45); margin-left: 8px; }
.rd-bookbar .info .meta { font-size: 9.5px; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-top: 4px; }
.rd-bookbar .info .meta b { color: #ff8a5e; font-weight: 700; }
.rd-bookbar .spacer { flex: 1; }
.rd-bookbar .ghost-btn { display: inline-flex; align-items: center; gap: 8px; height: 46px; padding: 0 18px; border: 1px solid rgba(255,255,255,.3); border-radius: 3px; color: #fff; font: 600 10px/1 'JetBrains Mono', monospace; letter-spacing: .16em; text-transform: uppercase; }
.rd-bookbar .book-btn { display: inline-flex; align-items: center; height: 46px; padding: 0 26px; border: 0; border-radius: 3px; background: var(--accent); color: #fff; font: 700 12px/1 'JetBrains Mono', monospace; letter-spacing: .18em; text-transform: uppercase; }
.rd-bookbar .book-btn:hover { filter: brightness(1.06); }
.rd-hero { position: relative; height: 460px; overflow: hidden; }
.rd-hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.rd-hero-shade { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,8,29,.36) 0%, rgba(20,8,29,.15) 38%, rgba(20,8,29,.82) 100%); }
.rd-hero-in { position: absolute; left: 0; right: 0; bottom: 0; padding: 0 48px 32px; color: #fff; }
.rd-crumb { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.7); margin-bottom: 18px; }
.rd-crumb a { cursor: pointer; color: rgba(255,255,255,.7); } .rd-crumb a:hover { color: #fff; }
.rd-crumb i { color: rgba(255,255,255,.4); margin: 0 8px; font-style: normal; }
.rd-crumb b { color: #fff; }
.rd-ribbon { display: inline-block; background: var(--accent); color: #fff; font-size: 9px; letter-spacing: .2em; text-transform: uppercase; font-weight: 700; padding: 6px 11px; border-radius: 2px; }
.rd-hero h1 { font-family: 'JetBrains Mono', monospace; font-weight: 600; font-size: 56px; line-height: 1; letter-spacing: -.025em; margin: 14px 0 10px; }
.rd-sub { font-size: 16px; line-height: 1.5; color: rgba(255,255,255,.82); max-width: 640px; margin: 0 0 22px; letter-spacing: .01em; }
.rd-hero-specs { display: flex; flex-wrap: wrap; gap: 0; border: 1px solid rgba(255,255,255,.18); border-radius: 4px; overflow: hidden; background: rgba(20,8,29,.4); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); width: fit-content; }
.rd-hero-specs .sp { padding: 12px 20px; border-right: 1px solid rgba(255,255,255,.14); }
.rd-hero-specs .sp:last-child { border-right: 0; }
.rd-hero-specs .k { font-size: 8.5px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-bottom: 5px; }
.rd-hero-specs .v { font-size: 14px; font-weight: 700; letter-spacing: .02em; white-space: nowrap; }
.rd-sec { padding: 56px 48px; border-top: 1px solid var(--rule); }
.rd-overview { display: grid; grid-template-columns: 1fr 360px; gap: 56px; align-items: start; border-top: 0; }
.rd-ov-main .rd-lede { font-size: 17px; line-height: 1.6; color: var(--ink); margin: 14px 0 28px; letter-spacing: .01em; }
.rd-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.rd-highlights .hl { display: grid; grid-template-columns: 28px 1fr; gap: 10px; font-size: 13px; line-height: 1.5; color: var(--ink); letter-spacing: .01em; }
.rd-highlights .hl .n { font: 700 11px/1.4 'JetBrains Mono', monospace; color: var(--accent); letter-spacing: .1em; }
.rd-gtk { background: var(--cream-2); border: 1px solid var(--rule); border-radius: 5px; padding: 22px; }
.rd-gtk .hd { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; padding-bottom: 14px; border-bottom: 1px solid var(--rule); }
.rd-gtk .rows { display: flex; flex-direction: column; }
.rd-gtk .row { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; padding: 11px 0; border-bottom: 1px dashed var(--rule); font-size: 12px; }
.rd-gtk .row .k { letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-size: 9.5px; }
.rd-gtk .row .v { font-weight: 600; text-align: right; }
.rd-gtk .row .v small { font-size: 9px; letter-spacing: .12em; color: var(--ink-soft); font-weight: 500; }
.rd-gtk .wa { display: flex; align-items: center; justify-content: center; gap: 9px; height: 46px; margin-top: 18px; border-radius: 3px; background: #1f8a4d; color: #fff; font: 700 9.5px/1.2 'JetBrains Mono', monospace; letter-spacing: .16em; text-transform: uppercase; text-align: center; }
.rd-gtk .foot { font-size: 10px; line-height: 1.5; color: var(--ink-soft); margin: 12px 0 0; letter-spacing: .01em; }
.rd-gallery-sec .rd-deps-hd { margin-bottom: 22px; }
.rd-gal { display: flex; flex-direction: column; gap: 12px; }
.rd-gal-stage { position: relative; border-radius: 6px; overflow: hidden; border: 1px solid var(--rule); aspect-ratio: 16 / 9; background: var(--cream-2); }
.rd-gal-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rd-gal-ph { position: absolute; inset: 0; display: grid; place-items: center; padding: 24px; text-align: center; background: repeating-linear-gradient(135deg, rgba(31,12,42,.05) 0 1px, transparent 1px 12px), var(--cream-2); }
.rd-gal-ph span { font: 600 11px/1.5 'JetBrains Mono', monospace; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); }
.rd-gal-cap { position: absolute; left: 16px; bottom: 14px; background: rgba(20,8,29,.74); color: #fff; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; font-weight: 600; padding: 7px 12px; border-radius: 3px; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.rd-gal-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%; border: 0; background: rgba(20,8,29,.55); color: #fff; font-size: 24px; line-height: 1; display: grid; place-items: center; cursor: pointer; transition: background .15s; }
.rd-gal-arrow:hover { background: var(--accent); }
.rd-gal-arrow.prev { left: 14px; } .rd-gal-arrow.next { right: 14px; }
.rd-gal-strip { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 2px; }
.rd-gal-thumb { position: relative; flex: 1 0 96px; aspect-ratio: 4 / 3; border-radius: 4px; overflow: hidden; border: 1px solid var(--rule); cursor: pointer; padding: 0; display: grid; place-items: center; transition: border-color .15s, transform .12s, box-shadow .15s; background: repeating-linear-gradient(135deg, rgba(31,12,42,.05) 0 1px, transparent 1px 9px), var(--cream-2); }
.rd-gal-thumb:hover { transform: translateY(-2px); }
.rd-gal-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.rd-gal-thumb .ph-n { font: 700 13px/1 'JetBrains Mono', monospace; color: var(--ink-faint); letter-spacing: .1em; }
.rd-gal-thumb.on { border-color: var(--accent); box-shadow: 0 0 0 1.5px var(--accent); }
.rd-body { padding-top: 40px; }
.rd-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--rule); margin-bottom: 32px; }
.rd-tab { background: none; border: 0; padding: 12px 18px; font: 600 11px/1 'JetBrains Mono', monospace; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); position: relative; }
.rd-tab.on { color: var(--ink); }
.rd-tab.on::after { content: ''; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--accent); }
.rd-itin { display: flex; flex-direction: column; }
.rd-day { display: grid; grid-template-columns: 56px 1fr; gap: 18px; }
.rd-day-rail { display: flex; flex-direction: column; align-items: center; }
.rd-day-rail .node { width: 40px; height: 40px; border-radius: 50%; background: var(--violet); color: #fff; display: grid; place-items: center; font: 700 16px/1 'JetBrains Mono', monospace; flex-shrink: 0; }
.rd-day-rail .track { flex: 1; width: 2px; background: var(--rule); margin: 6px 0; }
.rd-day-card { padding-bottom: 26px; }
.rd-day-hd { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.rd-day-hd .dl { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.rd-day-hd h3 { font-size: 20px; font-weight: 600; letter-spacing: -.01em; margin: 5px 0 0; }
.rd-day-hd .leg { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink); font-weight: 600; text-align: right; padding-top: 4px; white-space: nowrap; }
.rd-day-hd .leg .arr { color: var(--accent); margin: 0 4px; }
.rd-day-stats { display: flex; align-items: center; gap: 14px; margin: 12px 0; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); flex-wrap: wrap; }
.rd-day-stats b { color: var(--ink); font-weight: 700; font-size: 13px; }
.rd-day-stats i { width: 1px; height: 12px; background: var(--rule); }
.rd-day-desc { font-size: 13.5px; line-height: 1.6; color: var(--ink-soft); margin: 0 0 12px; letter-spacing: .01em; max-width: 760px; }
.rd-day-stay { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.rd-day-stay .k { color: var(--ink-soft); } .rd-day-stay .v { color: var(--ink); font-weight: 600; margin-left: 6px; }
.rd-day-stay .end { color: var(--accent); font-weight: 700; }
.rd-incl { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.rd-incl .col { border: 1px solid var(--rule); border-radius: 5px; padding: 24px 26px; background: #fff; }
.rd-incl .col.yes { background: color-mix(in srgb, var(--green) 5%, #fff); border-color: color-mix(in srgb, var(--green) 30%, var(--rule)); }
.rd-incl .ch { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; margin-bottom: 16px; }
.rd-incl .col.yes .ch { color: var(--green); }
.rd-incl .col.no .ch { color: var(--ink-soft); }
.rd-incl ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 12px; }
.rd-incl li { font-size: 13px; line-height: 1.5; color: var(--ink); letter-spacing: .01em; padding-left: 18px; position: relative; }
.rd-incl .col.yes li::before { content: '✓'; position: absolute; left: 0; color: var(--green); font-weight: 700; }
.rd-incl .col.no li { color: var(--ink-soft); }
.rd-incl .col.no li::before { content: '—'; position: absolute; left: 0; color: var(--ink-faint); }
.rd-incl-wrap { display: flex; flex-direction: column; gap: 26px; }
.rd-board { border: 1px solid var(--rule); border-radius: 5px; background: #fff; overflow: hidden; }
.rd-board-hd { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 20px 24px 14px; }
.rd-board-hd .ch { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--ink); }
.rd-board-hd .leg { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); }
.rd-board-tbl { display: flex; flex-direction: column; }
.rd-board-tbl .thr, .rd-board-tbl .tr { display: grid; grid-template-columns: 88px 1.3fr 1.6fr 40px 40px 40px; align-items: center; gap: 12px; padding: 0 24px; }
.rd-board-tbl .thr { height: 34px; background: var(--cream-2); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); font-size: 9px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.rd-board-tbl .tr { min-height: 48px; border-bottom: 1px dashed var(--rule); font-size: 12px; }
.rd-board-tbl .tr:last-child { border-bottom: 0; }
.rd-board-tbl .tr .d { font-weight: 700; letter-spacing: .1em; font-size: 10px; color: var(--violet); }
.rd-board-tbl .tr .w { font-weight: 600; letter-spacing: .01em; }
.rd-board-tbl .tr .a { font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.rd-board-tbl .c { text-align: center; font-size: 13px; }
.rd-board-tbl .thr .c { font-size: 9px; }
.rd-board-tbl .tr .c.y { color: var(--green); font-weight: 700; }
.rd-board-tbl .tr .c.n { color: var(--ink-faint); }
.rd-board-note { font-size: 12px; line-height: 1.6; color: var(--ink-soft); margin: 0; padding: 14px 24px 20px; letter-spacing: .01em; max-width: 820px; }
.rd-terms-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(228px, 1fr)); gap: 18px; }
.rd-term { border: 1px solid var(--rule); border-radius: 5px; background: #fff; padding: 22px 22px 24px; }
.rd-term .n { font: 700 11px/1 'JetBrains Mono', monospace; letter-spacing: .14em; color: var(--accent); }
.rd-term .k { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--ink); margin: 14px 0 9px; }
.rd-term p { font-size: 12.5px; line-height: 1.55; color: var(--ink-soft); margin: 0; letter-spacing: .01em; }
.rd-map { display: flex; flex-direction: column; gap: 14px; }
.rd-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.rd-gallery .rd-ph { height: 140px; }
.rd-deps { background: var(--cream-2); }
.rd-deps-hd { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.rd-deps-hd h2 { font-family: 'JetBrains Mono', monospace; font-weight: 600; font-size: 30px; letter-spacing: -.02em; margin: 10px 0 0; }
.rd-deps-hd .note { font-size: 9.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); text-align: right; }
.rd-deps-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
.rd-dep { background: #fff; border: 1px solid var(--rule); border-radius: 4px; padding: 16px 18px; cursor: pointer; transition: border-color .15s, transform .12s; }
.rd-dep:hover { border-color: var(--accent); transform: translateY(-2px); }
.rd-dep .dow { font-size: 8.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-soft); }
.rd-dep .dd { font-size: 20px; font-weight: 700; letter-spacing: -.01em; margin: 5px 0 8px; }
.rd-dep .spots { font-size: 8.5px; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; display: inline-flex; align-items: center; gap: 5px; }
.rd-dep .spots .sd { width: 5px; height: 5px; border-radius: 50%; }
.rd-dep .spots.low { color: #8a6314; } .rd-dep .spots.low .sd { background: #c9892a; }
.rd-dep .spots.ok { color: var(--green); } .rd-dep .spots.ok .sd { background: var(--green); }
.rd-dep.flex { border-style: dashed; border-color: color-mix(in srgb, var(--accent) 45%, var(--rule)); background: color-mix(in srgb, var(--accent) 4%, #fff); display: flex; flex-direction: column; }
.rd-dep.flex .dow { color: var(--accent); }
.rd-dep.flex .dd { font-size: 16px; line-height: 1.15; }
.rd-dep.flex .spots.req { color: var(--accent); margin-top: auto; }
.rd-dep.flex .spots.req .sd { background: var(--accent); }
.rd-band { background: var(--violet); color: #e8dde9; padding: 56px 48px; }
.rd-band h2 { font-family: 'JetBrains Mono', monospace; font-weight: 600; font-size: 32px; letter-spacing: -.02em; color: #fff; margin: 12px 0 28px; }
.rd-band .em { color: #ff8a5e; }
.rd-band-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.14); }
.rd-band-row .b .k { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: #ff8a5e; font-weight: 600; margin-bottom: 10px; }
.rd-band-row .b p { font-size: 13px; line-height: 1.55; color: #c2afc8; margin: 0; letter-spacing: .01em; }

/* ── journey responsive ─────────────────────────────────────────────── */
@media (max-width: 1040px) {
  .jn-library, .jn-explore-hd { padding-left: 28px; padding-right: 28px; }
  .rd-overview { grid-template-columns: 1fr; gap: 32px; }
  .rd-sec, .rd-band { padding-left: 28px; padding-right: 28px; }
  .rd-hero-in { padding-left: 28px; padding-right: 28px; }
  .rd-hero h1 { font-size: 42px; }
  .rd-incl { grid-template-columns: 1fr; }
  .rd-terms-grid { grid-template-columns: 1fr 1fr; }
  .rd-board-tbl .thr, .rd-board-tbl .tr { grid-template-columns: 64px 1fr 1.2fr 28px 28px 28px; gap: 8px; padding: 0 14px; }
  .rd-board-hd { padding: 16px 14px 12px; }
  .rd-board-note { padding: 12px 14px 16px; }
  .rd-band-row { grid-template-columns: 1fr; gap: 20px; }
  .rd-gallery { grid-template-columns: repeat(2, 1fr); }
}

/* ── booking-flow mobile pass (HANDOFF §3) ──────────────────────────── */
@media (max-width: 760px) {
  .bk-stage { padding: 18px 16px; }
  /* compact stepper: hide the labelled segments, show "STEP n / N" */
  .bk-pipe { padding: 0; }
  .bk-pipe .seg { display: none; }
  .bk-pipe-compact { display: flex; align-items: center; width: 100%; padding: 12px 16px; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; font-weight: 700; color: var(--accent); }
  /* single-column step layouts */
  .bk-pay, .bk-party-wrap, .bk-form-grid { grid-template-columns: 1fr; }
  .bk-routes { grid-template-columns: 1fr; }
  /* condensed summary bar: total + primary CTA only */
  .bk-bar { height: auto; padding: 12px 16px; gap: 12px; flex-wrap: wrap; }
  .bk-bar .facts .fact { display: none; }
  .bk-bar .facts .fact:first-child,
  .bk-bar .facts .fact:last-child { display: flex; }
  .bk-bar .facts .vr { display: none; }
  .bk-bar .acts { width: 100%; }
  .bk-bar .acts .btn { flex: 1; }
  .bk-step-head h2 { font-size: 24px; }
  /* ≥44px tap targets */
  .bk-datechip { padding: 13px 12px; }
  .bk-addon .box { width: 28px; height: 28px; }
  .bk-consent .box { width: 26px; height: 26px; }
  .bk-wa-float { bottom: 84px; }
  .rd-hero { height: 380px; }
  .rd-hero h1 { font-size: 34px; }
  .rd-bookbar { flex-wrap: wrap; height: auto; padding: 12px 16px; gap: 10px; }
  .rd-bookbar .ghost-btn { display: none; }
  .rd-bookbar .book-btn { flex: 1; justify-content: center; }
  .rd-terms-grid { grid-template-columns: 1fr; }
}
