/*
 * Context Design Co — Component Primitives
 * Locked: 2026-05-26
 * Version: v3.0
 * Depends on tokens.css.
 *
 * Aesthetic register: navy + orange on brushed stainless steel.
 * See design/README.md and design/brand-photos/ for the reference.
 */

/* -----------------------------------------------------------------
 * TOPBAR — sticky white nav, thin border, two-color wordmark
 * ----------------------------------------------------------------- */
.cdc-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid var(--cdc-line);
  padding: .9rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--cdc-body-sm-size);
  color: var(--cdc-ink-2);
}
.cdc-topbar .brand {
  text-decoration: none;
  letter-spacing: -.015em;
  font-weight: 700;
  font-size: 1.05rem;
  line-height: 1;
  white-space: nowrap;
}
.cdc-topbar .brand .ctx { color: var(--cdc-navy); }
.cdc-topbar .brand .des { color: var(--cdc-copper); }
.cdc-topbar nav { display: flex; gap: 1.6rem; }
.cdc-topbar nav a {
  color: var(--cdc-ink-2);
  text-decoration: none;
  transition: color var(--cdc-dur) var(--cdc-ease);
}
.cdc-topbar nav a:hover { color: var(--cdc-navy); }
.cdc-topbar nav a.cta-link { color: var(--cdc-copper); font-weight: 600; }

/* -----------------------------------------------------------------
 * WORDMARK LOCKUP — the canonical two-color wordmark
 * <span class="cdc-wordmark"><span class="ctx">Context</span> <span class="des">Design Co</span></span>
 * ----------------------------------------------------------------- */
/* Inline wordmark — "Context Design Co" on one line, two colors. */
.cdc-wordmark {
  display: inline-block;
  font-family: var(--cdc-font-display);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1;
  white-space: nowrap;
}
.cdc-wordmark .ctx { color: var(--cdc-navy); }
.cdc-wordmark .des { color: var(--cdc-copper); }
.cdc-wordmark.on-steel .ctx { color: var(--cdc-navy); }
.cdc-wordmark.on-steel .des { color: var(--cdc-copper-deep); }
.cdc-wordmark.on-navy .ctx { color: var(--cdc-copper); }
.cdc-wordmark.on-navy .des { color: #FFFFFF; font-weight: 600; }

/* Stacked wordmark — copper "Context" on top, tracked-out white "DESIGN CO" beneath.
   This is the canonical primary lockup, matching logomark-copper-on-navy.jpg.
   <span class="cdc-wordmark-stack on-navy">
     <span class="ctx">Context</span>
     <span class="des">Design Co</span>
   </span>
   The .des span is auto-uppercased and tracked-out via CSS — keep "Design Co" as written
   in the markup so screen readers and search read the natural string. */
.cdc-wordmark-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .25em;
  font-family: var(--cdc-font-display);
  line-height: 1;
}
.cdc-wordmark-stack .ctx {
  font-weight: 700;
  letter-spacing: -.025em;
  color: var(--cdc-copper);
  font-size: 1em;
}
.cdc-wordmark-stack .des {
  font-weight: 500;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--cdc-ink-2);
  font-size: .34em;
  padding-left: .12em;   /* compensates for tracking pushing left edge inward */
}
.cdc-wordmark-stack.on-navy .ctx,
.cdc-wordmark-stack.on-steel-dark .ctx { color: var(--cdc-copper); }
.cdc-wordmark-stack.on-navy .des,
.cdc-wordmark-stack.on-steel-dark .des { color: #FFFFFF; }
.cdc-wordmark-stack.center { align-items: center; }
.cdc-wordmark-stack.center .des { padding-left: 0; }

/* -----------------------------------------------------------------
 * STEEL SURFACES — the signature brushed-stainless-steel background
 * <div class="cdc-steel">…</div>          (full panel)
 * <div class="cdc-steel cdc-steel-warm">…</div>   (with orange rim light)
 * <div class="cdc-steel cdc-steel-dark">…</div>   (darker brushed variant)
 * ----------------------------------------------------------------- */
.cdc-steel {
  position: relative;
  isolation: isolate;
  background:
    var(--cdc-steel-brush),
    var(--cdc-steel-grad);
  color: var(--cdc-ink-on-steel);
  overflow: hidden;
}
.cdc-steel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--cdc-steel-rim);
  z-index: 0;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: .9;
}
.cdc-steel::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.06 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: .55;
}
.cdc-steel > * { position: relative; z-index: 1; }

.cdc-steel.cdc-steel-warm::before { opacity: 1; }
.cdc-steel.cdc-steel-dark {
  background:
    var(--cdc-steel-brush),
    linear-gradient(90deg,
      var(--cdc-steel-edge) 0%,
      var(--cdc-steel-deep) 35%,
      var(--cdc-steel) 65%,
      var(--cdc-steel-edge) 100%);
}

/* Photo-backed steel — drops a real brand photo behind content with a subtle
   navy scrim so foreground type stays readable. */
.cdc-steel-photo {
  position: relative;
  isolation: isolate;
  background-color: var(--cdc-steel-deep);
  background-size: cover;
  background-position: center;
  color: var(--cdc-ink-on-steel);
  overflow: hidden;
}
.cdc-steel-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(11,20,38,.62) 0%, rgba(11,20,38,.20) 60%, transparent 100%);
  z-index: 0;
  pointer-events: none;
}
.cdc-steel-photo > * { position: relative; z-index: 1; }

/* -----------------------------------------------------------------
 * POLISHED STEEL — smooth, mirror-leaning, no horizontal brushing.
 * Use for cleaner reflective sections (feature panels, deck-style bands).
 * The .cdc-steel primitive above is the BRUSHED variant; this is its sibling.
 * <section class="cdc-section cdc-steel-polished"> … </section>
 * ----------------------------------------------------------------- */
.cdc-steel-polished {
  position: relative;
  isolation: isolate;
  background: var(--cdc-steel-grad-polished);
  color: var(--cdc-ink-on-steel);
  overflow: hidden;
}
.cdc-steel-polished::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--cdc-steel-polish-sheen);
  z-index: 0;
  pointer-events: none;
}
.cdc-steel-polished::after {
  /* Very faint grain so the surface reads as metal, not painted plastic */
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.035 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: .55;
}
.cdc-steel-polished > * { position: relative; z-index: 1; }

/* Polished steel with a warm copper rim light from one corner — premium hero variant */
.cdc-steel-polished.warm {
  background:
    radial-gradient(ellipse 60% 80% at 100% 30%, var(--cdc-copper-glow), transparent 55%),
    var(--cdc-steel-grad-polished);
}

/* Aliases — make the brushed/polished pairing explicit for readers of new HTML.
   .cdc-steel and .cdc-steel-brushed are interchangeable. */
.cdc-steel-brushed { /* same as .cdc-steel */ }

/* -----------------------------------------------------------------
 * SECTION — alternating bg rhythm
 * <section class="cdc-section"> … </section>
 * <section class="cdc-section alt"> … </section>          pale-gray
 * <section class="cdc-section cdc-steel"> … </section>    full steel
 * ----------------------------------------------------------------- */
.cdc-section {
  padding: var(--cdc-space-28) var(--cdc-page-pad);
}
.cdc-section.alt { background: var(--cdc-bg-pale); }
.cdc-section.warm-tint { background: var(--cdc-bg-tint); }
.cdc-section.cdc-steel,
.cdc-section.cdc-steel-photo { padding-block: var(--cdc-space-28); }

.cdc-container {
  max-width: var(--cdc-max-page);
  margin-inline: auto;
  position: relative;
}
.cdc-container.narrow { max-width: var(--cdc-max-narrow); }

@media (max-width: 880px) {
  .cdc-section { padding: var(--cdc-space-16) var(--cdc-page-pad-sm); }
}

/* -----------------------------------------------------------------
 * EYEBROW — small label above headings
 * ----------------------------------------------------------------- */
.cdc-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  font-family: var(--cdc-font-ui);
  font-size: var(--cdc-eyebrow-size);
  letter-spacing: var(--cdc-eyebrow-ls);
  font-weight: var(--cdc-eyebrow-weight);
  color: var(--cdc-copper);
  text-transform: uppercase;
  margin-bottom: 1.4rem;
}
.cdc-eyebrow::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--cdc-copper);
  display: inline-block;
}
.on-steel .cdc-eyebrow,
.cdc-steel .cdc-eyebrow,
.cdc-steel-photo .cdc-eyebrow,
.cdc-steel-polished .cdc-eyebrow,
.on-navy .cdc-eyebrow { color: var(--cdc-copper-hi); }
.on-steel .cdc-eyebrow::before,
.cdc-steel .cdc-eyebrow::before,
.cdc-steel-photo .cdc-eyebrow::before,
.cdc-steel-polished .cdc-eyebrow::before,
.on-navy .cdc-eyebrow::before { background: var(--cdc-copper-hi); }

/* -----------------------------------------------------------------
 * HEADINGS
 * ----------------------------------------------------------------- */
.cdc-h1 {
  font-family: var(--cdc-font-display);
  font-size: var(--cdc-h1-size);
  line-height: var(--cdc-h1-lh);
  letter-spacing: var(--cdc-h1-ls);
  font-weight: var(--cdc-h1-weight);
  color: var(--cdc-navy);
  margin: 0 0 1.4rem;
  max-width: 18ch;
}
.cdc-h1 .accent { color: var(--cdc-copper); font-weight: 600; }
.cdc-steel .cdc-h1,
.cdc-steel-photo .cdc-h1,
.cdc-steel-polished .cdc-h1,
.on-navy .cdc-h1 { color: #FFFFFF; }
.cdc-steel .cdc-h1 .accent,
.cdc-steel-photo .cdc-h1 .accent,
.cdc-steel-polished .cdc-h1 .accent,
.on-navy .cdc-h1 .accent { color: var(--cdc-copper-hi); }

.cdc-h2 {
  font-family: var(--cdc-font-display);
  font-size: var(--cdc-h2-size);
  line-height: var(--cdc-h2-lh);
  letter-spacing: var(--cdc-h2-ls);
  font-weight: var(--cdc-h2-weight);
  color: var(--cdc-navy);
  margin: 0 0 1.2rem;
  max-width: 30ch;
}
.cdc-h3 {
  font-family: var(--cdc-font-display);
  font-size: var(--cdc-h3-size);
  line-height: var(--cdc-h3-lh);
  letter-spacing: var(--cdc-h3-ls);
  font-weight: var(--cdc-h3-weight);
  color: var(--cdc-navy);
  margin: 0 0 .6rem;
}
.cdc-steel .cdc-h2, .cdc-steel-photo .cdc-h2, .cdc-steel-polished .cdc-h2, .on-navy .cdc-h2,
.cdc-steel .cdc-h3, .cdc-steel-photo .cdc-h3, .cdc-steel-polished .cdc-h3, .on-navy .cdc-h3 { color: #FFFFFF; }

.cdc-lede {
  font-size: var(--cdc-lede-size);
  line-height: 1.5;
  color: var(--cdc-ink-2);
  max-width: 56ch;
  margin: 0 0 2rem;
  font-weight: var(--cdc-body-weight);
}
.cdc-steel .cdc-lede,
.cdc-steel-photo .cdc-lede,
.cdc-steel-polished .cdc-lede,
.on-navy .cdc-lede { color: rgba(255,255,255,.88); }

/* -----------------------------------------------------------------
 * CTA — orange primary, navy secondary, ghost text
 * ----------------------------------------------------------------- */
.cdc-cta {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .85rem 1.5rem;
  border-radius: var(--cdc-r);
  border: none;
  cursor: pointer;
  font-family: var(--cdc-font-ui);
  font-weight: 600;
  font-size: var(--cdc-body-size);
  letter-spacing: -.005em;
  text-decoration: none;
  background: var(--cdc-copper);
  color: #FFFFFF;
  box-shadow: var(--cdc-shadow-cta);
  transition: transform var(--cdc-dur) var(--cdc-ease),
              background var(--cdc-dur) var(--cdc-ease),
              box-shadow var(--cdc-dur) var(--cdc-ease);
}
.cdc-cta:hover {
  background: var(--cdc-copper-2);
  transform: translateY(-1px);
}
.cdc-cta::after { content: "→"; font-weight: 500; }

.cdc-cta.secondary {
  background: var(--cdc-navy);
  color: #FFFFFF;
  box-shadow: 0 1px 2px rgba(21,35,63,.2), 0 10px 20px -8px rgba(21,35,63,.3);
}
.cdc-cta.secondary:hover { background: var(--cdc-navy-2); }

.cdc-cta.outline {
  background: transparent;
  color: var(--cdc-navy);
  box-shadow: inset 0 0 0 1.5px var(--cdc-navy);
}
.cdc-cta.outline:hover { background: var(--cdc-navy); color: #FFFFFF; }

.cdc-cta.ghost {
  background: transparent;
  color: var(--cdc-navy);
  box-shadow: none;
  padding-inline: .25rem;
}
.cdc-cta.ghost::after { color: var(--cdc-copper); }
.cdc-cta.ghost:hover { color: var(--cdc-copper); }

.on-steel .cdc-cta.outline,
.cdc-steel .cdc-cta.outline,
.cdc-steel-photo .cdc-cta.outline {
  color: #FFFFFF;
  box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.7);
}
.on-steel .cdc-cta.outline:hover,
.cdc-steel .cdc-cta.outline:hover,
.cdc-steel-photo .cdc-cta.outline:hover { background: rgba(255,255,255,.12); }

/* -----------------------------------------------------------------
 * CARD — white surface for light bg; navy translucent for steel bg
 * ----------------------------------------------------------------- */
.cdc-card {
  background: var(--cdc-bg);
  border: 1px solid var(--cdc-line);
  border-radius: var(--cdc-r-lg);
  padding: 1.8rem 1.6rem;
  box-shadow: var(--cdc-shadow-card);
  display: flex;
  flex-direction: column;
  gap: .55rem;
  transition: transform var(--cdc-dur-slow) var(--cdc-ease),
              box-shadow var(--cdc-dur-slow) var(--cdc-ease);
}
.cdc-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--cdc-shadow-lift);
}
.cdc-card h3 { margin: 0 0 .25rem; }
.cdc-card p { color: var(--cdc-ink-2); font-size: var(--cdc-body-sm-size); margin: 0; line-height: 1.55; }
.cdc-card .more {
  margin-top: auto;
  padding-top: .9rem;
  color: var(--cdc-copper);
  font-weight: 600;
  font-size: var(--cdc-body-sm-size);
}

.cdc-card.feature {
  border-color: var(--cdc-copper);
  border-width: 1px;
  background: linear-gradient(180deg, var(--cdc-copper-veil), var(--cdc-bg) 60%);
  position: relative;
}
.cdc-card.feature::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--cdc-copper-deep), var(--cdc-copper), var(--cdc-copper-hi));
  border-radius: var(--cdc-r-lg) var(--cdc-r-lg) 0 0;
}

.cdc-card.on-navy {
  background: var(--cdc-navy);
  color: var(--cdc-ink-on-navy);
  border: 1px solid var(--cdc-line-on-dark);
}
.cdc-card.on-navy h3 { color: #FFFFFF; }
.cdc-card.on-navy p { color: rgba(255,255,255,.78); }
.cdc-card.on-navy .more { color: var(--cdc-copper-hi); }

/* -----------------------------------------------------------------
 * PILL — small tag
 * ----------------------------------------------------------------- */
.cdc-pill {
  display: inline-flex;
  align-items: center;
  font-family: var(--cdc-font-ui);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 600;
  padding: .25rem .7rem;
  border-radius: var(--cdc-r-pill);
  background: var(--cdc-copper-veil);
  color: var(--cdc-copper-deep);
  border: 1px solid var(--cdc-copper);
}
.cdc-pill.navy {
  background: rgba(21,35,63,.06);
  color: var(--cdc-navy);
  border-color: var(--cdc-navy);
}
.cdc-pill.on-dark {
  background: rgba(255,255,255,.1);
  color: #FFFFFF;
  border-color: rgba(255,255,255,.3);
}

/* -----------------------------------------------------------------
 * DOTS — bullet list with restrained orange dots
 * ----------------------------------------------------------------- */
.cdc-dots {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .85rem 2rem;
}
.cdc-dots li {
  color: var(--cdc-ink-2);
  font-size: var(--cdc-body-size);
  padding-left: 1.5rem;
  position: relative;
  line-height: 1.55;
}
.cdc-dots li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55rem;
  width: .55rem;
  height: .55rem;
  background: var(--cdc-copper);
  border-radius: 2px;
  transform: rotate(45deg);
}
@media (max-width: 720px) { .cdc-dots { grid-template-columns: 1fr; } }

/* -----------------------------------------------------------------
 * WONT-LIST — won't-do bullets
 * ----------------------------------------------------------------- */
.cdc-wontlist { margin: 0; padding: 0; list-style: none; }
.cdc-wontlist li {
  padding: .9rem 0;
  border-top: 1px solid var(--cdc-line);
  font-size: var(--cdc-body-size);
  color: var(--cdc-ink-2);
  line-height: 1.55;
  display: flex;
  gap: .85rem;
  align-items: flex-start;
}
.cdc-wontlist li:first-child { border-top: none; padding-top: 0; }
.cdc-wontlist li::before {
  content: "✕";
  font-weight: 600;
  color: var(--cdc-copper-deep);
  flex: 0 0 1.2rem;
}
.cdc-wontlist li b { color: var(--cdc-navy); font-weight: 600; }

/* -----------------------------------------------------------------
 * CODE WINDOW — light variant
 * ----------------------------------------------------------------- */
.cdc-window {
  background: var(--cdc-bg);
  border: 1px solid var(--cdc-line);
  border-radius: var(--cdc-r-lg);
  padding: 1.6rem;
  font-family: var(--cdc-font-mono);
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--cdc-ink);
  box-shadow: var(--cdc-shadow-card);
  position: relative;
}
.cdc-window .winhead {
  display: flex; gap: .4rem; margin-bottom: 1.1rem; align-items: center;
}
.cdc-window .winhead i {
  width: .55rem; height: .55rem; border-radius: 50%;
  opacity: .8;
}
.cdc-window .winhead i:nth-child(1) { background: #FF5F57; }
.cdc-window .winhead i:nth-child(2) { background: #FEBC2E; }
.cdc-window .winhead i:nth-child(3) { background: #28C840; }
.cdc-window .winhead span {
  margin-left: .55rem;
  font-family: var(--cdc-font-mono);
  font-size: .72rem;
  color: var(--cdc-ink-3);
  letter-spacing: .04em;
}

/* -----------------------------------------------------------------
 * FOOTER
 * ----------------------------------------------------------------- */
.cdc-footer {
  background: var(--cdc-navy-deep);
  color: rgba(255,255,255,.7);
  padding: var(--cdc-space-16) var(--cdc-page-pad) var(--cdc-space-10);
  font-size: var(--cdc-body-sm-size);
}
.cdc-footer .row {
  max-width: var(--cdc-max-page);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--cdc-space-8);
  align-items: end;
}
.cdc-footer a { color: rgba(255,255,255,.78); text-decoration: none; }
.cdc-footer a:hover { color: var(--cdc-copper-hi); }
.cdc-footer .legal { font-size: var(--cdc-body-xs-size); opacity: .6; margin-top: 2rem; }

/* -----------------------------------------------------------------
 * PAGENAV — pill nav between related pages
 * ----------------------------------------------------------------- */
.cdc-pagenav {
  display: inline-flex;
  gap: .25rem;
  padding: .3rem;
  border-radius: var(--cdc-r-pill);
  background: var(--cdc-bg);
  border: 1px solid var(--cdc-line);
  font-family: var(--cdc-font-ui);
  font-size: .8rem;
}
.cdc-pagenav a {
  padding: .42rem .95rem;
  border-radius: var(--cdc-r-pill);
  color: var(--cdc-ink-3);
  text-decoration: none;
  transition: color var(--cdc-dur) var(--cdc-ease);
}
.cdc-pagenav a:hover { color: var(--cdc-navy); }
.cdc-pagenav a.active {
  background: var(--cdc-navy);
  color: #FFFFFF;
}

/* =================================================================
 * v3.2 — BLITZBOX SUB-BRAND PRIMITIVES
 * Used only on /blitzbox/* pages and the BlitzBox Portal.
 * Locked: 2026-05-27 per docs/superpowers/specs/2026-05-27-blitzbox-portal-design.md §4.3
 * ================================================================= */

/* ----- TOPBAR (dark Blitzbox header with copper seam) ----- */
.bb-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bb-header-bg);
  color: rgba(255,255,255,.92);
  padding: .9rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--cdc-body-sm-size);
  isolation: isolate;
}
.bb-topbar::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--bb-header-seam);
  opacity: .55;
  pointer-events: none;
}
.bb-topbar nav { display: flex; gap: 1.6rem; align-items: center; }
.bb-topbar nav a {
  color: rgba(255,255,255,.72);
  text-decoration: none;
  transition: color var(--cdc-dur) var(--cdc-ease);
}
.bb-topbar nav a:hover { color: #fff; }

/* ----- SECTION ----- */
.bb-section {
  padding: var(--cdc-space-28) 0;
  position: relative;
}
.bb-section.alt {
  background:
    linear-gradient(180deg, var(--bb-green-wash) 0%, var(--bb-green-wash-2) 100%);
  border-top: 1px solid rgba(10,94,71,.12);
  border-bottom: 1px solid rgba(10,94,71,.12);
}
@media (max-width: 720px) {
  .bb-section { padding: var(--cdc-space-16) 0; }
}

/* ----- WORDMARK — BLITZBOX (all-caps, two-color) ----- */
.bb-wordmark {
  display: inline-flex;
  align-items: baseline;
  font-family: var(--cdc-font-display);
  font-weight: 800;
  letter-spacing: -.015em;
  line-height: 1;
  white-space: nowrap;
  font-size: clamp(2rem, 5vw, 3.4rem);
}
.bb-wordmark .blitz { color: var(--bb-green-hi); position: relative; }
.bb-wordmark .box   { color: var(--cdc-copper-hi); }
.bb-wordmark.on-light .blitz { color: var(--bb-green-deep); }
.bb-wordmark.on-light .box   { color: var(--cdc-copper-deep); }

/* The small spark/sail glyph positioned above the Z in BLITZ */
.bb-wordmark-mark {
  position: absolute;
  top: -0.6em;
  right: 0;
  width: 0.55em;
  height: 0.55em;
  color: inherit;
  transform: rotate(8deg);
}

/* Stacked variant — wordmark + tagline beneath */
.bb-wordmark-stack { display: inline-flex; flex-direction: column; gap: .55em; align-items: flex-start; }
.bb-wordmark-tag {
  font-family: var(--cdc-font-body);
  font-weight: 500;
  font-size: clamp(.78rem, 1.1vw, .92rem);
  letter-spacing: .06em;
  color: rgba(255,255,255,.78);
}
.bb-wordmark-stack.on-light .bb-wordmark-tag { color: var(--cdc-ink-3); }

/* ----- CTA (primary green metallic + outline variant) ----- */
.bb-cta {
  display: inline-block;
  padding: .85rem 1.4rem;
  border-radius: var(--cdc-r);
  font-family: var(--cdc-font-body);
  font-weight: 600;
  font-size: var(--cdc-body-size);
  color: #fff;
  text-decoration: none;
  border: 1px solid rgba(5,64,53,.6);
  cursor: pointer;
  background: var(--bb-green-grad-brushed);
  box-shadow: var(--bb-shadow-cta);
  transition: transform var(--cdc-dur) var(--cdc-ease), box-shadow var(--cdc-dur) var(--cdc-ease);
}
.bb-cta:hover { transform: translateY(-1px); box-shadow: 0 2px 4px rgba(5,64,53,.32), 0 18px 36px -16px rgba(5,64,53,.45); }
.bb-cta:active { transform: translateY(0); }

.bb-cta.outline {
  background: transparent;
  border: 1px solid var(--bb-green);
  color: var(--bb-green-deep);
  box-shadow: none;
}
.bb-cta.outline:hover { background: rgba(10,94,71,.06); }

.bb-topbar .bb-cta.outline,
.bb-section.dark .bb-cta.outline {
  border-color: var(--bb-green-hi);
  color: var(--bb-green-glint);
}

/* ----- PILL (status indicators) ----- */
.bb-pill {
  display: inline-block;
  padding: .25rem .6rem;
  border-radius: var(--cdc-r-pill);
  font-family: var(--cdc-font-body);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.bb-pill.status-active,
.bb-pill.status-paid,
.bb-pill.status-reserved {
  background: var(--bb-gold-grad-brushed);
  color: var(--cdc-navy-deep);
  text-shadow: 0 1px 0 rgba(255,255,255,.22);
  border: 1px solid rgba(122,88,20,.42);
}
.bb-pill.status-pending {
  background: var(--cdc-bg-pale);
  color: var(--cdc-ink-3);
  border: 1px solid var(--cdc-line);
}

/* ----- H2 ACCENT (one word in green within an .cdc-h2) ----- */
.bb-h2-accent { color: var(--bb-green-deep); }
.bb-section.dark .bb-h2-accent,
.bb-topbar + section .bb-h2-accent { color: var(--bb-green-hi); }

/* ----- CROSSNAV (links back to CDC pages — copper) ----- */
.bb-crossnav {
  display: inline-block;
  padding: .25rem 0;
  color: var(--cdc-copper);
  font-size: .92rem;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px dotted var(--cdc-copper);
  transition: color var(--cdc-dur) var(--cdc-ease);
}
.bb-crossnav:hover { color: var(--cdc-copper-deep); }

/* ----- CARD (Blitzbox card; .tinted variant for alt sections) ----- */
.bb-card {
  background: var(--cdc-bg);
  border: 1px solid var(--cdc-line);
  border-radius: var(--cdc-r-lg);
  padding: 1.25rem 1.4rem;
  box-shadow: var(--cdc-shadow-card);
}
.bb-card.tinted {
  background: rgba(255,255,255,.85);
  border-color: rgba(10,94,71,.20);
}
.bb-card h4 {
  margin: 0 0 .4rem;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--cdc-navy);
}
.bb-card p {
  margin: 0;
  font-size: var(--cdc-body-sm-size);
  color: var(--cdc-ink-3);
}

/* ----- PRODUCT PHOTO WRAPPER ----- */
.bb-product-photo {
  display: block;
  position: relative;
  border-radius: var(--cdc-r-lg);
  overflow: hidden;
  box-shadow: var(--bb-shadow-card);
  aspect-ratio: 1 / 1;
}
.bb-product-photo img,
.bb-product-photo video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bb-product-photo.hero { aspect-ratio: 4 / 5; }
.bb-product-photo.wide { aspect-ratio: 16 / 9; }
.bb-product-photo.dark {
  background: #0B1426;
  box-shadow: var(--cdc-shadow-steel);
}

/* ----- PRODUCT VIDEO — autoplay loop with reduced-motion fallback ----- */
.bb-product-video {
  display: block;
  position: relative;
  border-radius: var(--cdc-r-lg);
  overflow: hidden;
  box-shadow: var(--bb-shadow-card);
  background: #0B1426;
  aspect-ratio: 16 / 9;
}
.bb-product-video video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
@media (prefers-reduced-motion: reduce) {
  .bb-product-video video { display: none; }
  .bb-product-video::after {
    content: "";
    position: absolute; inset: 0;
    background: var(--bb-product-video-poster, var(--cdc-navy-deep)) center / cover no-repeat;
  }
}
