/* 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; }
.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: 600px;
  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;
}
.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(3, 1fr); gap: 10px;
  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; }
}
