/* Daring Strategy — Brief Edition
   Ink black + royal blue + saturated gold.
   Palette lifted directly from the book-mark logo:
   document field, DARING in royal, STRATEGY in gold underline.
   Montserrat display · Inter body.
*/

.ds-site {
  /* Color — Brief Edition */
  --bg: #0B0F18;           /* Ink Black (field) */
  --bg-deep: #06090F;      /* Deep Ink */
  --bg-panel: #131C2E;     /* Panel surface */
  --bg-panel-2: #1A2439;   /* Panel hover */
  --rule: #1F2A42;
  --rule-2: #2A3853;

  --ink: #FFFFFF;          /* Page White */
  --ink-2: #C6CEDC;        /* Ink-2 */
  --ink-3: #8691A8;        /* Ink-3 muted */

  /* A1 Royal Blue (logo wordmark), A2 Banana Yellow (logo underline), A3 Deep Cobalt */
  --cyan: #FFD93D;         /* Banana Yellow */
  --mint: #8FB4FF;         /* soft royal tint */
  --coral: #2347B8;        /* Royal Blue (primary) */
  --magenta: #142B73;      /* Deep Cobalt gradient tail */
  --accent: var(--coral);  /* Royal Blue is the hero accent */
  --cta: var(--coral);     /* reserved for THE button */

  --grad-ds: linear-gradient(135deg, #2347B8 0%, #1E3FA6 45%, #FFD93D 100%);
  --grad-sweep: linear-gradient(90deg, #142B73 0%, #1E3FA6 25%, #2347B8 55%, #FFD93D 100%);

  /* Button text color — flips on inverse */
  --btn-primary-ink: #FFFFFF;

  /* Type */
  --display: 'Montserrat', 'Inter', system-ui, sans-serif;
  --body: 'Inter', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;

  /* Spacing — 8pt base */
  --s-1: 4px;   --s-2: 8px;   --s-3: 16px;  --s-4: 24px;
  --s-5: 32px;  --s-6: 48px;  --s-7: 64px;  --s-8: 96px;
  --s-9: 128px; --s-10: 160px;

  /* Layout */
  --max: 1280px;
  --gutter: 40px;

  background: var(--bg);
  color: var(--ink);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.ds-site * , .ds-site *::before, .ds-site *::after { box-sizing: border-box; }
.ds-site[data-mobile="true"] { --gutter: 20px; }

/* ── Inverse colorway ──────────────────────────────────────────────────────
   Royal blue field. Banana yellow is promoted to primary CTA.
   Everything still reads because ink is pure white and panels shift deeper. */
.ds-site--inverse {
  --bg: #2347B8;            /* Royal Blue field */
  --bg-deep: #1B3896;       /* deeper panel ground */
  --bg-panel: #1A3DA8;      /* panel surface */
  --bg-panel-2: #234AC2;    /* panel hover */
  --rule: #3D5FC9;          /* hairline */
  --rule-2: #5777D4;

  --ink: #FFFFFF;           /* Page White */
  --ink-2: #DCE3F7;         /* 86% white w/ blue tint */
  --ink-3: #9CAFE1;         /* muted */

  /* Flip accents: yellow becomes hero (primary CTA), blue becomes supporting */
  --cyan: #0B0F18;          /* deep ink for secondary button fills */
  --mint: #FFF4B0;          /* soft banana tint */
  --coral: #FFD93D;         /* Banana Yellow primary */
  --magenta: #FFB800;       /* deep banana tail */
  --accent: var(--coral);
  --cta: var(--coral);

  /* On banana primary we need dark ink for AA contrast */
  --btn-primary-ink: #0B0F18;
}

/* Inverse: hero glow swaps to banana halo */
.ds-site--inverse .ds-hero__glow {
  background: radial-gradient(circle at center, rgba(255,217,61,0.22) 0%, rgba(255,217,61,0) 70%);
}
.ds-site--inverse .ds-hero__glow2 {
  background: radial-gradient(circle at center, rgba(255,184,0,0.18) 0%, rgba(255,184,0,0) 70%);
}

/* Inverse: primary button hover keeps the banana family */
.ds-site--inverse .ds-btn--primary:hover {
  background: #FFE770; border-color: #FFE770;
  box-shadow: 0 0 0 3px rgba(255,217,61,.4);
}

/* Inverse: secondary (was banana) becomes dark ink plate */
.ds-site--inverse .ds-btn--cyan { background: #0B0F18; color: #FFD93D; border-color: #0B0F18; }
.ds-site--inverse .ds-btn--cyan:hover { background: #1B213A; border-color: #1B213A; box-shadow: 0 0 0 3px rgba(11,15,24,.4); }

/* Inverse: ghost button gets a lighter border so it reads on blue */
.ds-site--inverse .ds-btn--ghost { border-color: rgba(255,255,255,.38); color: #FFFFFF; }
.ds-site--inverse .ds-btn--ghost:hover { border-color: #FFD93D; color: #FFD93D; }

/* Inverse: cards — solid plates, no gradient */
.ds-site--inverse .ds-card { background: #1A3DA8; border-color: #3D5FC9; }
.ds-site--inverse .ds-card--feature { background: #1A3DA8; border: 1px solid #FFD93D; }
.ds-site--inverse .ds-card--quiet { background: #142B73; border-color: #FFD93D; }

/* Inverse: Brief feature card — pull the whole pricing block onto banana */
.ds-site--inverse .ds-card--feature .ds-h3 { color: #FFD93D; }
.ds-site--inverse .ds-card--feature::before { background: #FFD93D; }

/* Inverse: price + section labels pop in banana */
.ds-site--inverse .ds-price__amount { color: #FFD93D; }
.ds-site--inverse .ds-section__label .ds-num { color: #FFD93D; }
.ds-site--inverse .ds-hero__eyebrow { color: #FFD93D; }
.ds-site--inverse .ds-dot { background: #FFD93D; box-shadow: 0 0 10px rgba(255,217,61,.8); }
.ds-site--inverse .ds-timeline__phase { color: #FFD93D; }
.ds-site--inverse .ds-pull { color: #FFD93D; }
.ds-site--inverse .ds-compare__price span { color: #FFD93D; }
.ds-site--inverse .ds-toc__n { color: #FFD93D; }
.ds-site--inverse .ds-faq__icon { color: #FFD93D; }
.ds-site--inverse .ds-tags span { color: #FFD93D; border-color: rgba(255,217,61,.4); }
.ds-site--inverse strong { color: #FFD93D; }

/* Inverse: card top rule pops in banana */
.ds-site--inverse .ds-card__rule {
  background: #FFD93D; box-shadow: 0 0 12px rgba(255,217,61,.7);
}

/* Inverse: highlights/emphasis already resolve via --cyan (banana) */
/* Inverse: hairlines on comparison + timeline */
.ds-site--inverse .ds-compare__row { border-color: #3D5FC9; }
.ds-site--inverse .ds-timeline__row::before {
  background: #FFD93D; box-shadow: 0 0 10px rgba(255,217,61,.8);
}

/* Inverse: final CTA glow swaps to banana */
.ds-site--inverse .ds-final::before {
  background: radial-gradient(ellipse at 50% 100%, rgba(255,217,61,0.25) 0%, rgba(255,217,61,0) 60%);
}

/* Inverse: footer keeps its darker ground for anchor */
.ds-site--inverse .ds-footer { background: #1B3896; border-color: #3D5FC9; }

/* Inverse: nav ground tint */
.ds-site--inverse .ds-nav { background: rgba(27,56,150,.9); border-color: #3D5FC9; }

/* Inverse: hero rule sweep — keep the gradient but more blue-weighted */
.ds-site--inverse .ds-hero__rule {
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, #FFD93D 40%, #FFFFFF 100%);
}

.ds-container { max-width: var(--max); margin: 0 auto; padding: 0 var(--gutter); }

/* ─── Type ──────────────────────────────────────────────────────────────── */
.ds-site h1, .ds-site h2, .ds-site h3, .ds-site h4 {
  font-family: var(--display);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--ink);
  text-wrap: balance;
}

.ds-h2 {
  font-size: 56px; line-height: 1.05; letter-spacing: -0.025em;
  font-weight: 700; max-width: 20ch;
}
.ds-site[data-mobile="true"] .ds-h2 { font-size: 34px; letter-spacing: -0.02em; }

.ds-h2--center { margin-left: auto; margin-right: auto; text-align: center; max-width: 22ch; }

.ds-h3 { font-size: 22px; line-height: 1.2; font-weight: 700; letter-spacing: -0.01em; }

.ds-highlight { color: var(--cyan); }
.ds-gradient { color: var(--cyan); }

.ds-prose p {
  font-size: 18px; line-height: 1.65; color: var(--ink-2);
  margin: 0 0 var(--s-4); max-width: 62ch;
}
.ds-prose p strong { color: var(--ink); font-weight: 600; }

.ds-lede {
  font-size: 22px; line-height: 1.55; color: var(--ink-2);
  max-width: 60ch; margin: var(--s-5) 0 var(--s-6);
  font-weight: 300;
}
.ds-site[data-mobile="true"] .ds-lede { font-size: 18px; }
.ds-lede--narrow { max-width: 56ch; }
.ds-lede strong { color: var(--ink); font-weight: 600; }

.ds-pull {
  font-family: var(--display);
  font-size: 32px; line-height: 1.25;
  color: var(--ink); font-weight: 600; letter-spacing: -0.02em;
  border-left: 2px solid var(--cyan);
  padding-left: var(--s-4);
  margin: var(--s-6) 0;
  max-width: 32ch;
}
.ds-pull--small { font-size: 22px; max-width: 40ch; }

.ds-section__label {
  display: flex; align-items: center; gap: var(--s-3);
  font-family: var(--body); font-weight: 600;
  font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: var(--s-5);
}
.ds-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 2px;
  border: 1px solid var(--cyan);
  font-size: 10px; color: var(--cyan);
  font-family: var(--mono); font-weight: 500;
}

/* ─── Nav ───────────────────────────────────────────────────────────────── */
.ds-nav {
  border-bottom: 1px solid var(--rule);
  padding: 32px 0;
  background: rgba(22, 24, 26, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 5;
}
.ds-nav__inner { display: flex; align-items: center; justify-content: space-between; }

.ds-wordmark { display: inline-flex; align-items: center; gap: 14px; text-decoration: none; color: var(--ink); }
.ds-wordmark__mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  font-family: var(--display); font-weight: 900;
  font-size: 22px; letter-spacing: -0.04em;
  color: var(--cyan);
  line-height: 1;
}
.ds-wordmark__mark-svg {
  width: 88px; height: 64px; display: block;
  object-fit: contain;
}
.ds-wordmark__text {
  display: flex; flex-direction: column; line-height: 1;
}
.ds-wordmark__name {
  font-family: var(--display); font-weight: 800;
  font-size: 22px; letter-spacing: 0.02em; text-transform: uppercase;
  color: var(--ink);
}
.ds-wordmark__tag {
  font-family: var(--body); font-weight: 600;
  font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--cyan); margin-top: 6px;
}

.ds-nav__links {
  display: flex; align-items: center; gap: var(--s-6);
  font-size: 14px; font-weight: 500;
}
.ds-nav__links a {
  color: var(--ink-2); text-decoration: none;
  position: relative; padding: 4px 0;
  transition: color .15s;
}
.ds-nav__links a:not(.ds-btn):hover { color: var(--cyan); }
.ds-nav__links a:not(.ds-btn)::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px;
  height: 1px; background: var(--cyan);
  transform: scaleX(0); transform-origin: left;
  transition: transform .2s ease;
}
.ds-nav__links a:not(.ds-btn):hover::after { transform: scaleX(1); }

.ds-nav__menu {
  background: none; border: 1px solid var(--rule-2); border-radius: 6px;
  padding: 10px 14px; display: none; flex-direction: column; gap: 4px; cursor: pointer;
}
.ds-nav__menu span { display: block; width: 18px; height: 1.5px; background: var(--ink); }
@media (max-width: 720px) {
  .ds-nav__menu { display: inline-flex; }
  .ds-nav__links { display: none; }
}

/* ─── Buttons ───────────────────────────────────────────────────────────── */
.ds-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  font-family: var(--body); font-weight: 600; font-size: 14px;
  text-decoration: none; cursor: pointer; border: 1.5px solid transparent;
  padding: 15px 24px; border-radius: 4px;
  transition: background .18s, color .18s, border-color .18s, box-shadow .2s, transform .12s;
  letter-spacing: 0.02em; text-transform: uppercase;
}
.ds-btn--sm { padding: 13px 22px; font-size: 13px; letter-spacing: 0.06em; }
.ds-btn--lg { padding: 19px 32px; font-size: 15px; }
.ds-btn--block { display: flex; width: 100%; }

/* Primary = Sky Blue (the single most important element) */
.ds-btn--primary { background: var(--coral); color: var(--btn-primary-ink); border-color: var(--coral); }
.ds-btn--primary:hover { background: #2E5AD8; border-color: #2E5AD8; box-shadow: 0 0 0 3px rgba(35,71,184,.32); }
.ds-btn--primary .ds-btn__price {
  font-family: var(--mono); font-size: 11px; font-weight: 500; opacity: .85;
  border-left: 1px solid rgba(255,255,255,.35);
  padding-left: 12px; margin-left: 4px; letter-spacing: 0.05em; text-transform: none;
}

/* Gold secondary */
.ds-btn--cyan { background: var(--cyan); color: #1A1100; border-color: var(--cyan); }
.ds-btn--cyan:hover { background: #FFE770; border-color: #FFE770; box-shadow: 0 0 0 3px rgba(255,217,61,.38); }

.ds-btn--ghost { background: transparent; color: var(--ink); border-color: var(--rule-2); }
.ds-btn--ghost:hover { border-color: var(--cyan); color: var(--cyan); }

.ds-btn--text {
  border: none; padding: 15px 4px; color: var(--ink);
  border-bottom: 1px solid var(--rule-2); border-radius: 0;
  letter-spacing: 0.02em;
}
.ds-btn--text:hover { color: var(--cyan); border-color: var(--cyan); }

/* ─── Hero ──────────────────────────────────────────────────────────────── */
.ds-hero {
  padding: var(--s-9) 0 var(--s-8);
  position: relative; overflow: hidden;
}
.ds-site[data-mobile="true"] .ds-hero { padding: var(--s-7) 0 var(--s-7); }

.ds-hero__glow {
  position: absolute; top: -200px; right: -200px; width: 700px; height: 700px;
  background: radial-gradient(circle at center, rgba(255,217,61,0.14) 0%, rgba(255,217,61,0) 70%);
  pointer-events: none;
}
.ds-hero__glow2 {
  position: absolute; bottom: -300px; left: -150px; width: 600px; height: 600px;
  background: radial-gradient(circle at center, rgba(35,71,184,0.22) 0%, rgba(35,71,184,0) 70%);
  pointer-events: none;
}
.ds-hero > .ds-container { position: relative; z-index: 1; }

.ds-hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--body); font-weight: 600;
  font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: var(--s-6);
  padding: 8px 14px;
  border: 1px solid var(--rule-2);
  border-radius: 999px;
}
.ds-dot { width: 6px; height: 6px; background: var(--coral); display: inline-block; border-radius: 50%; box-shadow: 0 0 8px var(--coral); }

.ds-hero__title {
  font-family: var(--display); font-weight: 800;
  font-size: 112px; line-height: 0.95; letter-spacing: -0.04em;
  max-width: 14ch; margin: 0 0 var(--s-6);
  color: var(--ink);
}
.ds-hero__title em {
  font-style: normal;
  color: var(--cyan);
}
.ds-site[data-mobile="true"] .ds-hero__title { font-size: 52px; letter-spacing: -0.03em; }

.ds-hero__deck {
  font-size: 22px; line-height: 1.55; max-width: 58ch;
  color: var(--ink-2); margin: 0 0 var(--s-6); font-weight: 300;
}
.ds-hero__deck strong { color: var(--ink); font-weight: 600; }
.ds-site[data-mobile="true"] .ds-hero__deck { font-size: 17px; }

.ds-hero__cta { display: flex; align-items: center; gap: var(--s-4); flex-wrap: wrap; margin-bottom: var(--s-8); }
.ds-site[data-mobile="true"] .ds-hero__cta { gap: var(--s-3); margin-bottom: var(--s-7); }
.ds-site[data-mobile="true"] .ds-hero__cta .ds-btn { flex: 1 1 auto; }

.ds-hero__meta {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid var(--rule); padding-top: var(--s-4);
}
.ds-site[data-mobile="true"] .ds-hero__meta { grid-template-columns: repeat(2, 1fr); gap: var(--s-3) 0; }
.ds-hero__meta > div { display: flex; flex-direction: column; gap: 6px; padding-right: var(--s-4); }
.ds-meta__k {
  font-family: var(--body); font-weight: 600;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3);
}
.ds-meta__v {
  font-family: var(--display); font-weight: 700;
  font-size: 16px; color: var(--ink); letter-spacing: -0.005em;
}

/* ─── Section base ──────────────────────────────────────────────────────── */
.ds-section { padding: var(--s-9) 0; border-top: 1px solid var(--rule); }
.ds-site[data-mobile="true"] .ds-section { padding: var(--s-8) 0; }

.ds-two-col {
  display: grid; grid-template-columns: 220px 1fr; gap: var(--s-7);
  align-items: start;
}
.ds-site[data-mobile="true"] .ds-two-col { grid-template-columns: 1fr; gap: var(--s-5); }
.ds-two-col .ds-section__label { margin-bottom: 0; padding-top: var(--s-2); position: sticky; top: 96px; }

/* Section with a darker backdrop for rhythm */
.ds-section--deep { background: var(--bg-deep); }

/* ─── Brief ─────────────────────────────────────────────────────────────── */
.ds-brief__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--s-5); flex-wrap: wrap;
}
.ds-brief__price { text-align: right; }
.ds-price__amount {
  display: block; font-family: var(--display); font-weight: 800;
  font-size: 60px; line-height: 1; letter-spacing: -0.03em;
  color: var(--cyan);
}
.ds-price__unit {
  font-family: var(--body); font-weight: 600;
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3); margin-top: 10px; display: block;
}

.ds-brief__grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--s-3);
  margin-top: var(--s-6);
}
.ds-site[data-mobile="true"] .ds-brief__grid { grid-template-columns: 1fr; }

.ds-card {
  background: var(--bg-panel);
  border: 1px solid var(--rule);
  padding: var(--s-5);
  position: relative; display: flex; flex-direction: column;
  border-radius: 6px;
  transition: border-color .2s, transform .2s;
}
.ds-card .ds-h3 { margin-bottom: var(--s-4); }

.ds-card--feature {
  background: var(--bg-panel);
  border: 1px solid var(--rule-2);
}
.ds-card--feature::before {
  content: ""; position: absolute; inset: -1px;
  border-radius: 6px;
  padding: 1px;
  background: var(--cyan);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events: none;
}
.ds-card__rule {
  position: absolute; top: 0; left: var(--s-5); height: 3px; width: 48px;
  background: var(--coral); box-shadow: 0 0 10px rgba(35,71,184,.6);
}
.ds-card--quiet { background: var(--bg-deep); }

.ds-list { list-style: none; padding: 0; margin: 0; }
.ds-list li {
  position: relative; padding-left: var(--s-4);
  font-size: 15px; line-height: 1.55; color: var(--ink-2);
  margin-bottom: var(--s-3);
}
.ds-list li::before {
  content: ""; position: absolute; left: 0; top: 10px;
  width: 8px; height: 1.5px; background: var(--cyan);
}
.ds-list li strong { color: var(--ink); font-weight: 600; }

.ds-toc { list-style: none; padding: 0; margin: 0; }
.ds-toc li {
  display: grid; grid-template-columns: 28px 1fr auto; gap: var(--s-2);
  padding: var(--s-2) 0;
  border-bottom: 1px solid var(--rule);
  font-size: 14px; color: var(--ink-2);
}
.ds-toc li:last-child { border-bottom: none; }
.ds-toc__n { font-family: var(--mono); font-size: 11px; color: var(--cyan); }
.ds-toc__pages { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }

.ds-tags { display: flex; flex-wrap: wrap; gap: var(--s-2); margin: var(--s-3) 0 var(--s-5); }
.ds-tags span {
  font-family: var(--body); font-weight: 600;
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  border: 1px solid var(--rule-2);
  padding: 7px 11px; color: var(--ink-2); border-radius: 999px;
}

/* ─── Process / Timeline ────────────────────────────────────────────────── */
.ds-timeline { list-style: none; padding: 0; max-width: 920px; margin: var(--s-7) auto 0; }
.ds-timeline__row {
  display: grid; grid-template-columns: 200px 1fr; gap: var(--s-6);
  padding: var(--s-5) 0; border-top: 1px solid var(--rule); position: relative;
}
.ds-timeline__row:last-child { border-bottom: 1px solid var(--rule); }
.ds-timeline__row::before {
  content: ""; position: absolute; left: 192px; top: var(--s-5);
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--coral); box-shadow: 0 0 8px rgba(35,71,184,.7);
}
.ds-site[data-mobile="true"] .ds-timeline__row { grid-template-columns: 1fr; gap: var(--s-2); padding: var(--s-4) 0; }
.ds-site[data-mobile="true"] .ds-timeline__row::before { display: none; }

.ds-timeline__when { display: flex; flex-direction: column; gap: 4px; }
.ds-timeline__phase {
  font-family: var(--display); font-weight: 700;
  font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--cyan);
}
.ds-timeline__date {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3);
}
.ds-timeline__what h4 {
  font-family: var(--display); font-size: 22px; font-weight: 700;
  margin: 0 0 8px; letter-spacing: -0.015em; color: var(--ink);
}
.ds-timeline__what p {
  font-size: 16px; line-height: 1.6; color: var(--ink-2); margin: 0;
  max-width: 58ch; font-weight: 300;
}
.ds-timeline__what p em { color: var(--cyan); font-style: normal; font-weight: 500; }

/* ─── Comparison ────────────────────────────────────────────────────────── */
.ds-compare__table {
  margin-top: var(--s-7);
  border-top: 1px solid var(--cyan);
  border-bottom: 1px solid var(--cyan);
}
.ds-compare__row {
  display: grid; grid-template-columns: 180px 1fr 1fr; gap: var(--s-5);
  padding: var(--s-4) 0; border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.ds-compare__row:last-child { border-bottom: none; }
.ds-site[data-mobile="true"] .ds-compare__row {
  grid-template-columns: 1fr 1fr; padding: var(--s-3) 0;
}
.ds-site[data-mobile="true"] .ds-compare__row > div:first-child {
  grid-column: 1 / -1; font-family: var(--body); font-weight: 600;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cyan);
}

.ds-compare__row--head {
  padding: var(--s-5) 0;
  align-items: end;
}
.ds-compare__row--head .ds-h3 { margin-bottom: var(--s-2); }
.ds-compare__row--cta { padding: var(--s-5) 0; }

.ds-compare__k {
  font-family: var(--body); font-weight: 600;
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3);
}
.ds-compare__row > div { font-size: 16px; color: var(--ink); }
.ds-compare__retainer { color: var(--ink-2); }
.ds-compare__price {
  font-family: var(--body); font-size: 12px; color: var(--ink-3);
  margin-top: 4px; font-weight: 500; letter-spacing: 0.04em;
}
.ds-compare__price span {
  font-family: var(--display); font-weight: 800; font-size: 22px; color: var(--ink);
  letter-spacing: -0.02em;
}

/* ─── Why / Resume ──────────────────────────────────────────────────────── */
.ds-resume { list-style: none; padding: 0; margin: var(--s-6) 0; }
.ds-resume li {
  display: grid; grid-template-columns: 120px 1fr 2fr; gap: var(--s-4);
  padding: var(--s-4) 0; border-top: 1px solid var(--rule);
  align-items: baseline;
}
.ds-resume li:last-child { border-bottom: 1px solid var(--rule); }
.ds-site[data-mobile="true"] .ds-resume li { grid-template-columns: 100px 1fr; }
.ds-site[data-mobile="true"] .ds-resume__detail { grid-column: 1 / -1; padding-top: var(--s-1); }

.ds-resume__years {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--cyan);
}
.ds-resume__role { font-family: var(--display); font-weight: 600; font-size: 17px; color: var(--ink); }
.ds-resume__role strong { font-weight: 800; }
.ds-resume__detail { font-size: 14px; color: var(--ink-2); line-height: 1.6; font-weight: 300; }

/* ─── FAQ ───────────────────────────────────────────────────────────────── */
.ds-faq__list { list-style: none; padding: 0; margin: var(--s-6) 0 0; max-width: 880px; }
.ds-faq__item {
  border-top: 1px solid var(--rule); padding: var(--s-4) 0; cursor: pointer;
  transition: background .15s;
}
.ds-faq__item:last-child { border-bottom: 1px solid var(--rule); }
.ds-faq__item:hover .ds-faq__q { color: var(--cyan); }
.ds-faq__q {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--s-4);
  background: none; border: none; padding: 0;
  font-family: var(--display); font-weight: 700; font-size: 20px; color: var(--ink);
  text-align: left; cursor: pointer; letter-spacing: -0.01em;
  transition: color .15s;
}
.ds-site[data-mobile="true"] .ds-faq__q { font-size: 17px; }
.ds-faq__icon {
  font-family: var(--mono); font-size: 22px; color: var(--cyan);
  width: 32px; flex-shrink: 0; text-align: right;
}
.ds-faq__a { max-height: 0; overflow: hidden; transition: max-height .25s ease; }
.ds-faq__item.is-open .ds-faq__a { max-height: 400px; }
.ds-faq__a p {
  margin: var(--s-3) 0 0; font-size: 16px; line-height: 1.65; color: var(--ink-2);
  max-width: 62ch; font-weight: 300;
}

/* ─── Final CTA ─────────────────────────────────────────────────────────── */
.ds-final {
  background: var(--bg-deep); border-top: 1px solid var(--rule);
  position: relative; overflow: hidden;
}
.ds-final::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 100%, rgba(35,71,184,0.22) 0%, rgba(35,71,184,0) 60%);
  pointer-events: none;
}
.ds-final__inner { text-align: center; position: relative; z-index: 1; }
.ds-final__eyebrow {
  font-family: var(--body); font-weight: 600;
  font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--cyan); margin: 0 0 var(--s-5);
}
.ds-final__title {
  font-family: var(--display); font-weight: 800;
  font-size: 88px; line-height: 0.98; letter-spacing: -0.035em;
  margin: 0 auto var(--s-7); max-width: 20ch;
}
.ds-final__title em {
  font-style: normal;
  color: var(--cyan);
}
.ds-site[data-mobile="true"] .ds-final__title { font-size: 42px; letter-spacing: -0.025em; }
.ds-final__cta { display: inline-flex; align-items: center; gap: var(--s-4); flex-wrap: wrap; justify-content: center; }

/* ─── Footer ────────────────────────────────────────────────────────────── */
.ds-footer { padding: var(--s-7) 0 var(--s-5); background: var(--bg-deep); border-top: 1px solid var(--rule); }
.ds-footer__top {
  display: grid; grid-template-columns: 1.2fr 2fr; gap: var(--s-7);
  padding-bottom: var(--s-6); border-bottom: 1px solid var(--rule);
}
.ds-site[data-mobile="true"] .ds-footer__top { grid-template-columns: 1fr; gap: var(--s-5); }
.ds-footer__tag {
  font-family: var(--body); font-size: 15px; color: var(--ink-2);
  margin: var(--s-3) 0 0; line-height: 1.6; max-width: 32ch; font-weight: 300;
}
.ds-footer__cols {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5);
}
.ds-footer__cols > div { display: flex; flex-direction: column; gap: var(--s-2); }
.ds-footer__h {
  font-family: var(--body); font-weight: 600;
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--cyan); margin-bottom: var(--s-2);
}
.ds-footer__cols a { color: var(--ink-2); text-decoration: none; font-size: 14px; }
.ds-footer__cols a:hover { color: var(--cyan); }
.ds-footer__bottom {
  display: flex; justify-content: space-between; gap: var(--s-4);
  padding-top: var(--s-4); font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.05em; color: var(--ink-3); flex-wrap: wrap;
}
.ds-footer__bottom a { color: var(--ink-2); }

/* ─── Gradient waveform decoration (Colorway 3 nod) ─────────────────────── */
.ds-wave {
  height: 2px; background: var(--grad-sweep);
  margin: var(--s-6) 0; opacity: 0.55; border-radius: 2px;
}

/* ── Koenig editor classes (required by Ghost theme validation) ──────── */
.kg-width-wide {
    position: relative;
    width: calc(100vw - 40px);
    max-width: calc(var(--max) + 200px);
    margin-left: 50%;
    transform: translateX(-50%);
    margin-top: 32px;
    margin-bottom: 32px;
}
.kg-width-full {
    position: relative;
    width: 100vw;
    margin-left: 50%;
    transform: translateX(-50%);
    margin-top: 32px;
    margin-bottom: 32px;
}
.kg-image {
    max-width: 100%;
    height: auto;
}
.kg-image-card { margin: 32px 0; }
.kg-image-card figcaption {
    font-size: 14px;
    color: var(--ink-3);
    text-align: center;
    margin-top: 12px;
    font-style: italic;
}
.kg-bookmark-card,
.kg-callout-card,
.kg-toggle-card,
.kg-button-card,
.kg-product-card { margin: 32px 0; }
.kg-embed-card { margin: 32px 0; max-width: 100%; }
.kg-gallery-container { margin: 32px 0; }
.kg-gallery-row { display: flex; gap: 8px; }
.kg-gallery-image { flex: 1 1 0%; min-width: 0; }
.kg-gallery-image img { width: 100%; height: auto; display: block; }

/* ── Inverse colorway: keep the NAV dark (matches the logo's dark backdrop) ── */
/* The site uses inverse (Royal Blue field) but the nav stays Ink Black so the
   logo's royal-blue + banana-yellow lockup reads cleanly. Hardcoded values used
   to override the inverse token flips. */
.ds-site--inverse .ds-nav {
  background: rgba(11, 15, 24, 0.92);
  border-bottom: 1px solid #1F2A42;
}
.ds-site--inverse .ds-nav .ds-wordmark__name { color: #FFFFFF; }
.ds-site--inverse .ds-nav .ds-wordmark__tag { color: #FFD93D; }
.ds-site--inverse .ds-nav__links a:not(.ds-btn) { color: #C6CEDC; }
.ds-site--inverse .ds-nav__links a:not(.ds-btn):hover { color: #FFD93D; }
.ds-site--inverse .ds-nav__links a:not(.ds-btn)::after { background: #FFD93D; }

/* Nav button stays the inverse colorway primary (banana yellow) — looks great
   on the dark nav and screams "primary action." Beef up the padding so it
   doesn't feel chip-sized. */
.ds-nav .ds-btn--primary {
  padding: 16px 28px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

/* ── Daring Strategy fixes batch 2 ─────────────────────────────────────── */

/* 1. Force dark ink on the banana yellow primary button (was rendering white) */
.ds-site--inverse .ds-btn--primary,
.ds-site--inverse .ds-btn--primary:visited {
    color: #0B0F18 !important;
}
.ds-site--inverse .ds-btn--primary .ds-btn__price {
    color: #0B0F18 !important;
    border-left-color: rgba(11, 15, 24, 0.25);
}

/* 2. All emphasis in headlines — force banana yellow on inverse (the var(--cyan)
      flips to dark ink in inverse mode, which is unreadable on royal blue) */
.ds-site--inverse .ds-hero__title em,
.ds-site--inverse .ds-final__title em,
.ds-site--inverse .ds-highlight,
.ds-site--inverse .ds-gradient,
.ds-site--inverse h2 em,
.ds-site--inverse h1 em {
    color: #FFD93D;
}

/* 3. Remove the hero radial glows + bottom rule sweep — keeps the blue field
      clean, no gradient artifacts */
.ds-site--inverse .ds-hero__glow,
.ds-site--inverse .ds-hero__glow2,
.ds-site--inverse .ds-hero__rule {
    display: none;
}

/* 4. Bonus: the final CTA also has a radial banana glow rising from the bottom.
      User wants no gradients in the blue section, so kill that too. */
.ds-site--inverse .ds-final::before {
    display: none;
}

/* ── Daring Strategy horizontal logo (replaces icon + text wordmark) ────── */
.ds-wordmark { display: inline-flex; align-items: center; }
.ds-wordmark__logo {
    display: block;
    height: 128px;
    width: auto;
    max-width: 100%;
}
.ds-wordmark__logo--footer {
    height: 160px;
    margin-bottom: 16px;
}
@media (max-width: 720px) {
    .ds-wordmark__logo { height: 96px; }
    .ds-wordmark__logo--footer { height: 120px; }
}

/* ────────────────────────────────────────────────────────────────────────
   MOBILE RESPONSIVENESS
   Real media queries replacing the static prototype's [data-mobile] toggle.
   Breakpoint: 720px (covers all phones + small tablets in portrait).
   Additional refinements for sub-480px screens follow.
   ──────────────────────────────────────────────────────────────────────── */
@media (max-width: 720px) {
    .ds-site { --gutter: 20px; }

    /* Type scaling */
    .ds-h2 { font-size: 34px; letter-spacing: -0.02em; line-height: 1.1; }
    .ds-h3 { font-size: 19px; }
    .ds-lede { font-size: 18px; line-height: 1.55; }
    .ds-prose p { font-size: 16px; line-height: 1.65; }

    /* Hero */
    .ds-hero { padding: var(--s-7) 0 var(--s-7); }
    .ds-hero__title { font-size: 52px; letter-spacing: -0.03em; line-height: 1.05; }
    .ds-hero__eyebrow { font-size: 11px; letter-spacing: 0.18em; }
    .ds-hero__deck { font-size: 17px; line-height: 1.6; }
    .ds-hero__cta { flex-direction: column; gap: var(--s-3); margin-bottom: var(--s-7); align-items: stretch; }
    .ds-hero__cta .ds-btn { flex: 1 1 auto; justify-content: center; }
    .ds-hero__meta { grid-template-columns: repeat(2, 1fr); gap: var(--s-4) var(--s-3); }

    /* Sections */
    .ds-section { padding: var(--s-8) 0; }

    /* Two-column layouts collapse to single */
    .ds-two-col { grid-template-columns: 1fr; gap: var(--s-5); }
    .ds-section__label { margin-bottom: var(--s-3); }

    /* Brief offer cards stack */
    .ds-brief__grid { grid-template-columns: 1fr; gap: var(--s-4); }
    .ds-brief__head { flex-direction: column; align-items: flex-start; gap: var(--s-3); }
    .ds-brief__price { align-items: flex-start; }
    .ds-price__amount { font-size: 48px; }

    /* Timeline */
    .ds-timeline__row {
        grid-template-columns: 1fr;
        gap: var(--s-2);
        padding: var(--s-4) 0;
    }
    .ds-timeline__row::before { display: none; }
    .ds-timeline__when { flex-direction: row; gap: var(--s-3); align-items: baseline; }

    /* Comparison table → stacked rows with full-width row headers */
    .ds-compare__table { display: block; }
    .ds-compare__row {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: var(--s-3);
        padding: var(--s-4) 0;
    }
    .ds-compare__row > div:first-child,
    .ds-compare__row [role="rowheader"] {
        grid-column: 1 / -1;
        font-family: var(--body);
        font-weight: 600;
        font-size: 11px;
        letter-spacing: 0.2em;
        text-transform: uppercase;
        color: var(--cyan);
        opacity: 0.7;
    }
    .ds-compare__row--head { grid-template-columns: 1fr 1fr; padding: var(--s-4) 0 var(--s-3); }
    .ds-compare__row--head > div:first-child { display: none; }
    .ds-compare__row--cta { grid-template-columns: 1fr; gap: var(--s-3); }
    .ds-compare__row--cta > div { grid-column: 1 / -1 !important; }

    /* Resume */
    .ds-resume li { grid-template-columns: 90px 1fr; gap: var(--s-1) var(--s-3); }
    .ds-resume__detail { grid-column: 1 / -1; padding-top: var(--s-1); }

    /* FAQ */
    .ds-faq__q { font-size: 17px; padding: var(--s-3) 0; }

    /* Final CTA */
    .ds-final__title { font-size: 42px; letter-spacing: -0.025em; line-height: 1.05; }
    .ds-final__cta { flex-direction: column; gap: var(--s-3); align-items: stretch; }
    .ds-final__cta .ds-btn--lg { width: 100%; justify-content: center; }

    /* Footer */
    .ds-footer__top {
        grid-template-columns: 1fr;
        gap: var(--s-5);
    }
    .ds-footer__cols {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--s-3);
    }

    /* Logo — readjust the previous override on this breakpoint */
    .ds-wordmark__logo { height: 72px; }
    .ds-wordmark__logo--footer { height: 96px; }

    /* Nav padding tighter on mobile */
    .ds-nav { padding: 16px 0; }

    /* Card padding smaller */
    .ds-card { padding: var(--s-4); }
}

/* ── Very small screens (≤ 480px) — extra tightening ─────────────────── */
@media (max-width: 480px) {
    .ds-hero__title { font-size: 42px; line-height: 1.05; }
    .ds-h2 { font-size: 28px; line-height: 1.1; }
    .ds-final__title { font-size: 34px; }
    .ds-price__amount { font-size: 40px; }

    /* Logo even smaller on tiny phones */
    .ds-wordmark__logo { height: 56px; }
    .ds-wordmark__logo--footer { height: 80px; }

    /* Footer columns stack on smallest screens */
    .ds-footer__cols { grid-template-columns: 1fr; gap: var(--s-4); }

    /* Hero meta single column */
    .ds-hero__meta { grid-template-columns: 1fr; gap: var(--s-3); }

    /* Compare table — full single column */
    .ds-compare__row { grid-template-columns: 1fr; gap: var(--s-2); }
    .ds-compare__row > div:nth-child(2),
    .ds-compare__row > div:nth-child(3) { padding-left: var(--s-3); border-left: 2px solid var(--rule-2); }

    /* Container padding tighter */
    .ds-site { --gutter: 16px; }
}

/* ── Beefier hero CTAs + prominent price chip ──────────────────────────── */
/* The .ds-btn--lg on the hero buttons beefs them up. Override the price chip
   to be much more prominent — was 11px mono at 0.85 opacity (whispered).
   Now: bigger, bolder, full opacity, with stronger separator. */
.ds-btn--lg {
    padding: 22px 36px;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.04em;
}
.ds-btn--lg .ds-btn__price {
    font-size: 15px;
    font-weight: 700;
    opacity: 1;
    margin-left: 14px;
    padding-left: 14px;
    border-left: 2px solid currentColor;
    letter-spacing: 0.03em;
}

/* Hero CTAs row — sensible spacing for the bigger buttons */
.ds-hero__cta { gap: 16px; flex-wrap: wrap; }

/* Footer location line — slightly muted to differentiate from the manifesto */
.ds-footer__location {
    color: var(--ink-3);
    font-size: 13px;
    font-style: italic;
    display: inline-block;
    margin-top: 6px;
}
