@import url('../../colors_and_type.css');

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--cream); }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
}

.container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }

/* ===== Nav ===== */
.nav {
  position: sticky; top: 0; z-index: 10;
  background: rgba(250, 246, 238, 0.85);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid var(--mid);
}
.nav .row {
  display: flex; align-items: center; gap: 32px;
  height: 64px;
}
.nav .brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--ink); }
.nav .brand .word { font: 400 20px/1 var(--font-display); letter-spacing: -0.01em; }
.nav .brand .word i { font-style: italic; }
.nav .links { display: flex; gap: 24px; }
.nav .links a {
  font: 500 14px var(--font-body); color: var(--slate);
  text-decoration: none; padding: 6px 2px;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease);
}
.nav .links a:hover { color: var(--ink); }
.nav .grow { flex: 1; }
.nav .actions { display: flex; gap: 10px; align-items: center; }

/* ===== Hero ===== */
.hero { padding: 80px 0 100px; }
.hero .eyebrow { font: var(--eyebrow); letter-spacing: var(--track-eyebrow); text-transform: uppercase; color: var(--ochre); }
.hero h1 {
  font: 300 84px/0.96 var(--font-display);
  letter-spacing: -0.025em;
  color: var(--ink);
  margin-top: 18px;
  max-width: 980px;
  text-wrap: balance;
}
.hero h1 i { font-style: italic; }
.hero .lede {
  font: 400 22px/1.5 var(--font-body);
  color: var(--slate);
  margin-top: 28px;
  max-width: 640px;
}
.hero .cta-row { display: flex; gap: 12px; margin-top: 32px; align-items: center; }
.hero .cta-note { font: var(--caption); color: var(--slate-2); margin-left: 8px; }

.hero .preview {
  margin-top: 64px;
  background: var(--linen);
  border: 1px solid var(--mid);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-floating);
}
.hero .preview .frame {
  background: var(--cream);
  border: 1px solid var(--mid);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.hero .preview .row1 {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--mid);
  background: var(--linen);
}
.hero .preview .row1 .ldot { width: 8px; height: 8px; border-radius: 50%; background: var(--mid); }
.hero .preview .row1 .url {
  margin-left: 16px; font: var(--mono-sm); color: var(--slate-2);
}
.hero .preview .chat {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  min-height: 360px;
}
.hero .preview .left-pane {
  padding: 28px 32px; border-right: 1px solid var(--mid);
  display: flex; flex-direction: column; gap: 14px;
}
.hero .preview .right-pane { padding: 28px 32px; background: var(--linen); }

/* ===== Numbers ===== */
.numbers {
  padding: 80px 0;
  border-top: 1px solid var(--mid);
  border-bottom: 1px solid var(--mid);
  background: var(--cream);
}
.numbers .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 56px; }
.numbers .stat .val {
  font: 300 72px/0.95 var(--font-display);
  letter-spacing: -0.02em;
  color: var(--ink);
}
.numbers .stat .val .mono { font: 400 72px/0.95 var(--font-mono); font-variant-numeric: tabular-nums lining-nums; }
.numbers .stat .label {
  font: 500 15px/1.5 var(--font-body);
  color: var(--slate);
  margin-top: 14px;
  max-width: 280px;
}

/* ===== Section heads (shared) ===== */
.section-head { margin-bottom: 56px; max-width: 820px; }
.section-head .eyebrow { font: var(--eyebrow); letter-spacing: var(--track-eyebrow); text-transform: uppercase; }
.section-head h2 {
  font: 300 52px/1.15 var(--font-display);
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-top: 16px;
  text-wrap: pretty;
}
.section-head h2 i { font-style: italic; }

/* ===== Features ===== */
.features { padding: 120px 0; background: var(--cream); }
.feat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--mid);
  border: 1px solid var(--mid);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.feat {
  background: var(--cream);
  padding: 36px 32px;
  display: flex; flex-direction: column; gap: 14px;
  min-height: 280px;
  transition: background var(--dur) var(--ease);
}
.feat:hover { background: var(--linen); }
.feat .num {
  font: 500 11px/1 var(--font-body);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ochre);
}
.feat h3 {
  font: 400 26px/1.2 var(--font-display);
  letter-spacing: -0.01em;
  color: var(--ink);
  text-wrap: balance;
}
.feat p {
  font: 400 15px/1.55 var(--font-body);
  color: var(--slate);
  margin-top: auto;
}

/* ===== Product surfaces (Claude + Slack) ===== */
.surfaces {
  padding: 120px 0;
  background: var(--cream);
  border-top: 1px solid var(--mid);
}
.surfaces .section-head .lede {
  font: 400 18px/1.55 var(--font-body);
  color: var(--slate);
  margin-top: 18px;
  max-width: 640px;
}

.surface-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: stretch;
}

.surface-card {
  background: var(--linen);
  border: 1px solid var(--mid);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  min-height: 0;
}
.surface-meta { padding: 28px 28px 22px; }
.surface-eyebrow {
  font: 600 11px/1 var(--font-body);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ochre);
}
.surface-title {
  font: 400 24px/1.25 var(--font-display);
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-top: 10px;
  text-wrap: pretty;
}
.surface-title i { font-style: italic; }
.surface-body {
  font: 400 15px/1.55 var(--font-body);
  color: var(--slate);
  margin-top: 12px;
}
.surface-link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px;
  font: 600 13px var(--font-body);
  color: var(--ochre-deep);
  text-decoration: none;
}
.surface-link span { transition: transform var(--dur) var(--ease); }
.surface-link:hover span { transform: translateX(3px); }

.surface-frame {
  position: relative;
  margin: 0 22px 22px;
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 864 / 540;
  border: 1px solid var(--mid);
  background: var(--ink);
}
.surface-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  display: block;
  object-fit: cover;
  object-position: top left;
}
.how { padding: 120px 0; background: var(--linen); border-top: 1px solid var(--mid); border-bottom: 1px solid var(--mid); }
.how h2 {
  font: 300 52px/1.15 var(--font-display);
  letter-spacing: -0.02em;
  color: var(--ink);
  max-width: 820px;
  text-wrap: pretty;
}
.how h2 i { font-style: italic; }
.how .grid {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.how .grid.four { grid-template-columns: repeat(4, 1fr); gap: 20px; }
.how .step {
  background: var(--cream);
  border: 1px solid var(--mid);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 240px;
}
.how .step .num {
  font: 400 18px/1 var(--font-display);
  letter-spacing: 0.04em;
  color: var(--ochre);
}
.how .step .num::after { content: ""; display: block; width: 24px; height: 1px; background: var(--ochre); margin-top: 8px; }
.how .step h3 {
  font: 600 19px/1.3 var(--font-body); color: var(--ink); letter-spacing: -0.01em;
}
.how .step p {
  font: var(--body); color: var(--slate); line-height: 1.55;
}

/* ===== Closing CTA ===== */
.closing-cta {
  background: var(--ink);
  color: var(--on-ink);
  padding: 120px 0;
  text-align: center;
}
.closing-cta h2 {
  font: 300 64px/1.1 var(--font-display);
  letter-spacing: -0.025em;
  color: var(--on-ink);
  max-width: 900px;
  margin: 0 auto;
  text-wrap: balance;
}
.closing-cta h2 i { font-style: italic; color: var(--ochre-soft); }
.closing-cta p {
  font: 400 19px/1.55 var(--font-body);
  color: var(--on-ink-2);
  max-width: 600px;
  margin: 24px auto 0;
}
.closing-cta .cta-row {
  display: flex; justify-content: center; gap: 12px;
  margin-top: 40px;
}
.closing-cta .ghost-on-ink {
  color: var(--on-ink) !important;
  border: 1px solid rgba(195, 184, 158, 0.32);
}
.closing-cta .ghost-on-ink:hover {
  background: rgba(242, 235, 220, 0.06);
}

/* ===== Trust slab (deep-ink) ===== */
.trust {
  background: var(--ink);
  color: var(--on-ink);
  padding: 120px 0;
  position: relative;
}
.trust .container { display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: center; }
.trust .eyebrow { font: var(--eyebrow); letter-spacing: var(--track-eyebrow); text-transform: uppercase; color: var(--ochre-soft); }
.trust h2 {
  font: 300 48px/1.1 var(--font-display);
  letter-spacing: -0.02em;
  margin-top: 18px;
  color: var(--on-ink);
  text-wrap: pretty;
}
.trust h2 i { font-style: italic; color: var(--ochre-soft); }
.trust p {
  font: 400 18px/1.6 var(--font-body); color: var(--on-ink-2);
  margin-top: 22px; max-width: 540px;
}
.trust .pills { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.trust .pills span {
  border: 1px solid rgba(195, 184, 158, 0.32);
  border-radius: 6px; padding: 6px 12px;
  font: 500 13px var(--font-body); color: var(--on-ink-2);
}

.trust .right {
  background: rgba(242, 235, 220, 0.04);
  border: 1px solid rgba(195, 184, 158, 0.18);
  border-radius: var(--radius-lg);
  padding: 32px;
}
.trust .log-row {
  display: flex; gap: 18px; padding: 14px 0;
  border-bottom: 1px solid rgba(195, 184, 158, 0.14);
}
.trust .log-row:last-child { border-bottom: 0; }
.trust .log-row .ts { font: var(--mono-sm); color: var(--on-ink-3); min-width: 80px; }
.trust .log-row .ev { font: 500 14px/1.4 var(--font-body); color: var(--on-ink); }
.trust .log-row .ev .meta { font: 400 13px/1.4 var(--font-body); color: var(--on-ink-2); margin-top: 4px; }

/* ===== Pricing ===== */
.pricing { padding: 120px 0; }
.pricing .head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.pricing h2 {
  font: 300 52px/1.15 var(--font-display);
  letter-spacing: -0.02em; color: var(--ink); text-wrap: balance;
}
.pricing h2 i { font-style: italic; }
.pricing .lede {
  font: 400 18px/1.55 var(--font-body); color: var(--slate);
  margin-top: 24px;
}
.pricing .grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 1200px; margin: 0 auto; }
.pricing .tier {
  background: var(--cream);
  border: 1px solid var(--mid);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.pricing .tier.featured {
  background: var(--linen);
  border-color: var(--ochre);
  box-shadow: var(--shadow-resting);
  position: relative;
}
.pricing .tier.featured::before {
  content: "Most firms";
  position: absolute; top: -10px; right: 20px;
  background: var(--ochre); color: #FAF6EE;
  padding: 4px 10px; border-radius: 4px;
  font: 600 11px var(--font-body); letter-spacing: 0.08em; text-transform: uppercase;
}
.pricing .tier .name { font: 600 16px var(--font-body); color: var(--ink); }
.pricing .tier .price {
  font: 300 48px/1 var(--font-display);
  letter-spacing: -0.02em; color: var(--ink);
}
.pricing .tier .price .mono { font: 400 48px/1 var(--font-mono); font-variant-numeric: tabular-nums lining-nums; }
.pricing .tier .price.contact { font: italic 300 40px/1 var(--font-display); color: var(--ink); }
.pricing .tier .price .per { font: 400 16px var(--font-body); color: var(--slate-2); margin-left: 6px; }
.pricing .tier .cap {
  font: 600 13px/1.2 var(--font-body);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ochre-deep);
  margin-top: -6px;
  min-height: 2.4em;
}
.pricing .tier.featured .cap { color: var(--ochre-deep); }
.pricing .tier ul { list-style: none; display: flex; flex-direction: column; gap: 10px; padding-top: 12px; border-top: 1px solid var(--mid); }
.pricing .tier li { font: var(--body); color: var(--slate); display: flex; gap: 10px; align-items: baseline; }
.pricing .tier li::before { content: "—"; color: var(--ochre); font-weight: 500; }

/* ===== Footer ===== */
.footer {
  background: var(--linen);
  border-top: 1px solid var(--mid);
  padding: 64px 0 40px;
}
.footer .grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 56px; }
.footer .col h4 {
  font: 600 12px var(--font-body); letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--slate-2);
}
.footer .col ul { list-style: none; margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.footer .col a {
  font: 500 14px var(--font-body); color: var(--ink);
  text-decoration: none;
}
.footer .col a:hover { color: var(--ochre); }
.footer .word { font: 400 22px/1 var(--font-display); letter-spacing: -0.01em; color: var(--ink); }
.footer .word i { font-style: italic; }
.footer .tag {
  font: 400 15px/1.5 var(--font-body); color: var(--slate); margin-top: 14px; max-width: 280px;
}
.footer .fine {
  margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--mid);
  display: flex; justify-content: space-between; align-items: center;
  font: var(--caption); color: var(--slate-2);
}

/* ─── Mobile (≤768px) — tablets and phones ─────────────────────────── */
@media (max-width: 768px) {
  .container { padding: 0 20px; }

  /* Nav: hide secondary links, keep brand + CTA */
  .nav .links { display: none; }
  .nav .container.row { gap: 12px; }

  /* Hero */
  .hero { padding: 56px 0 72px; }
  .hero h1 { font-size: clamp(32px, 8vw, 48px); line-height: 1.1; }
  .hero .lede { font-size: 16px; }
  .hero .cta-row { flex-wrap: wrap; gap: 12px; align-items: stretch; }
  .hero .cta-note { margin-left: 0; flex-basis: 100%; }

  /* Hero "browser preview" mock — was very wide, scale down + tighten */
  .hero .preview { margin-top: 40px; padding: 12px; }
  .hero .preview .chat { grid-template-columns: 1fr; }
  .hero .preview .left-pane,
  .hero .preview .right-pane { padding: 20px; }

  /* Sections: reduce vertical padding from desktop 120px → 72px */
  .numbers, .features, .surfaces, .how, .trust, .pricing {
    padding: 72px 0;
  }

  /* Section heads: less margin, smaller type */
  .section-head { margin-bottom: 32px; }
  h2 { font-size: clamp(28px, 6vw, 36px); line-height: 1.15; }

  /* Stats: stack the 3-col grid, allow center alignment */
  .numbers .grid { grid-template-columns: 1fr; gap: 32px; }
  .numbers .stat .val .mono { font-size: 56px; }

  /* Features grid — actual class is .feat-grid (was missed by old rule) */
  .feat-grid { grid-template-columns: 1fr; gap: 20px; }

  /* Surfaces — actual class is .surface-grid */
  .surface-grid { grid-template-columns: 1fr; gap: 20px; }
  .surface-img { width: 100%; height: auto; }

  /* How it works */
  .how .grid,
  .how .grid.four { grid-template-columns: 1fr; gap: 24px; }

  /* Trust slab */
  .trust .container { grid-template-columns: 1fr; gap: 32px; }

  /* Pricing 4-tier grid */
  .pricing .grid { grid-template-columns: 1fr; gap: 16px; }

  /* Footer: 4 cols → 2 cols (more compact than full stack) */
  .footer .grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer .fine { flex-direction: column; gap: 8px; align-items: flex-start; }

  /* Buttons full-width on phones for tap-friendliness */
  .ng-btn-lg { width: 100%; justify-content: center; }
}

/* ─── Phone-only (≤480px) — tighten display type further ───────────── */
@media (max-width: 480px) {
  .container { padding: 0 16px; }

  .hero h1 { font-size: clamp(28px, 9vw, 38px); }
  .hero .preview { margin-top: 28px; padding: 10px; }
  .numbers .stat .val .mono { font-size: 48px; }
  h2 { font-size: clamp(26px, 7vw, 32px); }

  /* Footer collapses to single column below 480px */
  .footer .grid { grid-template-columns: 1fr; gap: 28px; }
}
