/* ============================================================
   Cascade — Landing Page Stylesheet
   Direction B-M "Daylight Slate + Mono" (finalist, from Rev 5)
   Shared by cascade_program.html and cascade_workshop.html.
   ------------------------------------------------------------
   • Cool mist-gray ground, Manrope display, Source Sans 3 body.
   • IBM Plex Mono for every label / eyebrow / annotation.
   • Orange (#F2541B) reserved for CTAs + key numbers only.
   • One dark slate band per page = the single dramatic beat.
   • Oversized mono "C" watermark bleeds off the top-right.
   • Logo: transparent SVG, enlarged lockup with hairline divider.
   ============================================================ */

:root {
  --bg: #F2F4F7;            /* mist ground */
  --surface: #FFFFFF;       /* card surface */
  --ink: #333A44;           /* primary text (logo graphite, darkened) */
  --ink-soft: #585F6A;      /* secondary = logo graphite */
  --ink-faint: #7C838D;     /* captions / annotations */
  --slate: #3E454F;         /* the band */
  --slate-deep: #2D333B;    /* footer / deep chrome */
  --accent: #F2541B;        /* CTA / key-number orange */
  --accent-on-dark: #FF8A57;
  --line: #DDE2E8;          /* card border */
  --rule: #C9D0D8;          /* hairline rules */
  --ok: #2E7D5B;
  --no: #C04532;
}

* { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Source Sans 3", system-ui, sans-serif;
  line-height: 1.6;
  position: relative;
  overflow-x: hidden;
}

.wrap { max-width: 1000px; margin: 0 auto; padding: 0 28px; position: relative; }
.narrow { max-width: 760px; }

/* ---------- background watermark ---------- */
.watermark {
  position: absolute;
  top: 110px; right: -190px;
  width: 720px; height: 720px;
  z-index: -1;
  opacity: 0.045;
  color: var(--ink-soft);
  pointer-events: none; user-select: none;
}
.watermark svg { display: block; width: 100%; height: 100%; }
@media (max-width: 700px) {
  .watermark { top: 160px; right: -170px; width: 460px; height: 460px; opacity: 0.05; }
}

/* ---------- mono section label ---------- */
.kicker {
  font: 500 0.72rem/1.4 "IBM Plex Mono", monospace;
  text-transform: uppercase; letter-spacing: 0.16em;
  color: var(--ink-faint);
  display: flex; align-items: center; gap: 12px;
  margin: 0 0 18px;
}
.kicker .idx { color: var(--accent); font-weight: 600; }
.kicker::after { content: ""; flex: 1; height: 1px; background: var(--rule); }

/* ---------- header ---------- */
.site-header { border-bottom: 1px solid var(--rule); position: relative; z-index: 1; background: var(--bg); }
.site-header .wrap {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; padding: 32px 28px;
}
.brand { display: flex; align-items: center; text-decoration: none; }
.brand .lockup { display: flex; align-items: center; gap: 22px; }
.brand img { width: 78px; height: 78px; display: block; }
.brand .divider { width: 1px; height: 44px; background: var(--rule); }
.brand .wordmark { font: 800 2.54rem "Manrope", sans-serif; letter-spacing: -0.015em; color: var(--ink); }
.nav { display: flex; gap: 36px; font-size: 1.08rem; align-items: center; }
.nav a { color: var(--ink-soft); text-decoration: none; }
.nav a:hover { color: var(--ink); }
.nav a.nav-cta {
  font: 600 0.95rem "IBM Plex Mono", monospace; letter-spacing: 0.04em;
  color: var(--accent); border: 1px solid var(--accent);
  padding: 9px 16px; border-radius: 8px;
}
.nav a.nav-cta:hover { background: var(--accent); color: #fff; }
@media (max-width: 760px) {
  .brand .divider { display: none; }
  .brand .lockup { gap: 16px; }
  .brand .wordmark { font-size: 2.05rem; }
  .brand img { width: 66px; height: 66px; }
  .nav { gap: 18px; font-size: 0.98rem; }
  .nav a.nav-only-wide { display: none; }
}

/* ---------- buttons ---------- */
.btn {
  display: inline-block; text-decoration: none;
  background: var(--accent); color: #fff;
  padding: 16px 32px; border-radius: 12px;
  font-weight: 700; font-size: 1.02rem; letter-spacing: 0.01em;
  box-shadow: 0 8px 22px rgba(242,84,27,0.22);
  transition: transform .12s ease, box-shadow .12s ease;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(242,84,27,0.28); }
.btn.ghost {
  background: transparent; color: var(--ink);
  border: 1.5px solid var(--rule); box-shadow: none;
}
.btn.ghost:hover { border-color: var(--accent); transform: none; box-shadow: none; }
.cta-row { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.link-secondary { font-weight: 600; font-size: 0.98rem; color: var(--ink); text-decoration: none; border-bottom: 2px solid var(--rule); padding-bottom: 2px; }
.link-secondary:hover { border-color: var(--accent); }

/* ---------- sections ---------- */
section { padding: 30px 0; }
section.tight { padding: 22px 0; }
h1, h2, h3 { color: var(--ink); }
.section-title {
  margin: 0 0 18px;
  font: 800 clamp(1.9rem, 3.6vw, 2.7rem)/1.12 "Manrope", sans-serif;
  letter-spacing: -0.025em;
}
.section-title .hl { color: var(--accent); }
.lead { font-size: 1.18rem; color: var(--ink-soft); max-width: 680px; margin: 0 0 8px; }
.prose { max-width: 680px; }
.prose p { margin: 0 0 16px; color: var(--ink-soft); font-size: 1.05rem; }
.prose strong { color: var(--ink); }

/* ---------- hero ---------- */
.hero { padding: 66px 0 18px; }
.eyebrow {
  display: inline-block;
  font: 600 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft);
  background: #E7EAEF; border: 1px solid var(--line);
  padding: 8px 13px; border-radius: 6px; margin-bottom: 26px;
}
.hero h1 {
  margin: 0 0 22px;
  font: 800 clamp(2.5rem, 5.6vw, 4rem)/1.06 "Manrope", sans-serif;
  letter-spacing: -0.035em;
}
.hero h1 .hl { color: var(--accent); }
.hero .sub { max-width: 680px; font-size: 1.2rem; color: var(--ink-soft); margin: 0 0 18px; }
.hero .sub.small { font-size: 1.05rem; }
.hero .cta-row { margin-top: 30px; }

/* ---------- the dark slate band (the one dramatic beat) ---------- */
.band {
  margin: 8px 0;
  background: var(--slate);
  border-radius: 16px;
  padding: 48px 48px 50px;
  position: relative; overflow: hidden;
}
.band::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--accent);
}
.band .b-kicker {
  font: 600 0.7rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-on-dark); margin: 0 0 16px;
}
.band .cry {
  margin: 0 0 16px;
  font: 800 clamp(1.7rem, 3.6vw, 2.4rem)/1.18 "Manrope", sans-serif;
  letter-spacing: -0.02em; color: #fff;
}
.band .cry .hl { color: var(--accent-on-dark); }
.band p { margin: 0 0 12px; max-width: 620px; color: #C4CAD3; font-size: 1.06rem; }
.band p:last-child { margin-bottom: 0; }
.band p strong { color: #fff; }

/* ---------- cards / metrics ---------- */
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.grid.two { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 820px) { .grid, .grid.two { grid-template-columns: 1fr; } }
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 16px; padding: 26px;
  box-shadow: 0 4px 16px rgba(62,69,79,0.05);
  position: relative;
}
.card h3 {
  margin: 0 0 14px;
  font: 600 0.7rem/1 "IBM Plex Mono", monospace;
  text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink-faint);
  display: flex; align-items: center; gap: 9px;
}
.card h3 .tag { color: var(--accent); }
.metric { font: 800 2.7rem/1 "Manrope", sans-serif; color: var(--ink); margin: 0 0 4px; letter-spacing: -0.02em; }
.metric .hl { color: var(--accent); }
.metric-label { font: 500 0.64rem/1.4 "IBM Plex Mono", monospace; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); margin: 0 0 12px; }
.card p { margin: 0; font-size: 0.96rem; color: var(--ink-soft); }

/* ---------- fit / not-fit lists ---------- */
.fit-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
@media (max-width: 720px) { .fit-grid { grid-template-columns: 1fr; } }
.fit-list { list-style: none; margin: 8px 0 0; padding: 0; font-size: 0.99rem; }
.fit-list li { display: flex; gap: 11px; align-items: baseline; padding: 7px 0; color: var(--ink-soft); border-bottom: 1px solid var(--line); }
.fit-list li:last-child { border-bottom: none; }
.fit-list .yes::before { content: "\2713"; font-weight: 700; color: var(--ok); }
.fit-list .no::before  { content: "\2715"; font-weight: 700; color: var(--no); }

/* ---------- timeline (90-day cadence) ---------- */
.timeline { list-style: none; margin: 8px 0 0; padding: 0; border-left: 2px solid var(--rule); }
.timeline li { position: relative; padding: 0 0 26px 28px; }
.timeline li:last-child { padding-bottom: 0; }
.timeline li::before {
  content: ""; position: absolute; left: -7px; top: 5px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--surface); border: 2px solid var(--accent);
}
.timeline .when {
  display: inline-block; margin-bottom: 5px;
  font: 600 0.72rem/1 "IBM Plex Mono", monospace;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--accent);
}
.timeline .what { color: var(--ink-soft); font-size: 1.02rem; }
.timeline .what strong { color: var(--ink); }

/* ---------- value-stack table ---------- */
.stack { width: 100%; border-collapse: collapse; margin-top: 6px; }
.stack caption {
  text-align: left; color: var(--ink-faint);
  font: 500 0.74rem/1.5 "IBM Plex Mono", monospace; letter-spacing: 0.04em;
  margin-bottom: 14px;
}
.stack th, .stack td { text-align: left; padding: 13px 4px; border-bottom: 1px solid var(--line); }
.stack td.val, .stack th.val { text-align: right; font-family: "IBM Plex Mono", monospace; font-weight: 500; white-space: nowrap; }
.stack thead th {
  font: 600 0.66rem/1 "IBM Plex Mono", monospace; text-transform: uppercase;
  letter-spacing: 0.14em; color: var(--ink-faint); padding-bottom: 10px;
}
.stack tbody td { color: var(--ink-soft); font-size: 1rem; }
.stack tr.total td { border-top: 2px solid var(--ink); border-bottom: none; padding-top: 16px; font-weight: 800; color: var(--ink); font-size: 1.08rem; }
.stack tr.total td.val { font-size: 1.15rem; }

/* ---------- price ---------- */
.price-wrap { text-align: center; }
.price-tag {
  font: 800 clamp(3rem, 7vw, 4.6rem)/1 "Manrope", sans-serif;
  letter-spacing: -0.03em; color: var(--accent); margin: 8px 0 14px;
}
.price-note { color: var(--ink-soft); max-width: 600px; margin: 0 auto 8px; }

/* ---------- guarantee callout ---------- */
.callout {
  background: var(--surface); border: 1px solid var(--line);
  border-left: 5px solid var(--accent); border-radius: 14px;
  padding: 30px 34px;
}
.callout .c-kicker {
  font: 600 0.7rem/1 "IBM Plex Mono", monospace; text-transform: uppercase;
  letter-spacing: 0.16em; color: var(--accent); margin: 0 0 12px;
}
.callout p { margin: 0 0 14px; color: var(--ink-soft); }
.callout p.statement { font-size: 1.22rem; font-weight: 600; color: var(--ink); line-height: 1.4; }
.callout ul { margin: 0; padding-left: 20px; color: var(--ink-soft); }
.callout li { padding: 4px 0; }

/* ---------- cross-sell band ---------- */
.crosssell {
  background: var(--surface); border: 1px solid var(--line); border-radius: 16px;
  padding: 36px 38px; display: flex; gap: 28px; align-items: center; justify-content: space-between; flex-wrap: wrap;
}
.crosssell .cs-text { max-width: 620px; }
.crosssell h3 { margin: 0 0 8px; font: 800 1.4rem "Manrope", sans-serif; letter-spacing: -0.02em; }
.crosssell p { margin: 0; color: var(--ink-soft); }

/* ---------- final CTA ---------- */
.final { text-align: center; }
.final .section-title { max-width: 760px; margin-left: auto; margin-right: auto; }
.final .lead { margin-left: auto; margin-right: auto; }
.final .cta-row { justify-content: center; margin-top: 28px; }

/* ---------- application modal ---------- */
.modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  display: none;
  align-items: flex-start; justify-content: center;
  padding: 5vh 18px;
  background: rgba(45, 51, 59, 0.55);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  overflow-y: auto;
}
.modal-overlay.open { display: flex; }
body.modal-locked { overflow: hidden; }
.modal-dialog {
  position: relative; width: 100%; max-width: 560px; margin: auto;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 32px 34px 34px;
  box-shadow: 0 30px 80px rgba(45,51,59,0.45);
}
.modal-close {
  position: absolute; top: 14px; right: 14px; z-index: 2;
  width: 36px; height: 36px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--slate-deep); color: #fff; font-size: 1rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(45,51,59,0.3);
  transition: background .12s ease, transform .12s ease;
}
.modal-close:hover { background: var(--accent); transform: scale(1.06); }

/* ---- StaticForms widget themed to house style ---- */
/* widget renders a bare <form> with inline styles; container supplies the panel */
#cascade-form { font-family: "Source Sans 3", system-ui, sans-serif; color: var(--ink); }
#cascade-form h2 {
  font-family: "Manrope", sans-serif !important;
  font-size: 1.4rem !important; font-weight: 800 !important;
  letter-spacing: -0.02em; line-height: 1.2; padding-right: 36px;
}
#cascade-form input,
#cascade-form select,
#cascade-form textarea {
  border-radius: 10px !important;
  padding: 11px 13px !important;
  font-size: 1rem !important;
}
#cascade-form button[type="submit"] {
  background: var(--accent) !important; color: #fff !important;
  padding: 14px 30px !important;
  font-size: 1.02rem !important; font-weight: 700 !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 22px rgba(242,84,27,0.22);
  margin-top: 6px;
  transition: transform .12s ease, box-shadow .12s ease;
}
#cascade-form button[type="submit"]:hover {
  transform: translateY(-1px); box-shadow: 0 12px 28px rgba(242,84,27,0.28);
}

/* ---------- footer (clean) ---------- */
.site-footer { background: var(--slate-deep); color: #AEB5BF; position: relative; z-index: 1; margin-top: 24px; }
.site-footer .wrap { padding: 44px 28px; display: flex; flex-wrap: wrap; gap: 28px 48px; justify-content: space-between; align-items: flex-start; }
.site-footer .f-brand { display: flex; align-items: center; gap: 14px; }
.site-footer .f-brand img { width: 40px; height: 40px; }
.site-footer .f-brand .wordmark { font: 800 1.4rem "Manrope", sans-serif; color: #fff; }
.site-footer .tagline { font: 500 0.78rem/1.6 "IBM Plex Mono", monospace; letter-spacing: 0.04em; color: var(--accent-on-dark); margin: 12px 0 0; max-width: 320px; }
.site-footer nav { display: flex; flex-direction: column; gap: 10px; font-size: 0.98rem; }
.site-footer nav a { color: #C7CDD6; text-decoration: none; }
.site-footer nav a:hover { color: #fff; }
.site-footer .legal { width: 100%; border-top: 1px solid #3C434D; padding-top: 18px; font: 500 0.72rem/1.5 "IBM Plex Mono", monospace; color: #7E8794; letter-spacing: 0.03em; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
