/* ================================================================
   Growthhive — Chicken Republic Case Study
   chicken-republic.css
   Campaign: "Still Yours" · Activation: "What's Your Order?"
   Depends on: shared.css (loaded first)
   Co-brand: CR scarlet × Growthhive navy/chartreuse
================================================================ */

:root {
  /* ── The fuller chord — red as lead, not the whole page ── */
  --cr-red:    #D81E2C;   /* CR scarlet — lead voice */
  --cr-red-d:  #8E1019;   /* deep scarlet */
  --cr-red-dd: #4A0810;   /* darkest red, used sparingly */
  --cr-gold:   #E8A317;   /* CR golden-amber — the true brand accent */
  --cr-gold-d: #B87B0A;   /* deep gold */
  --cr-clay:   #9C4A2E;   /* terracotta/clay — mosaic heritage mid-tone */
  --cr-clay-d: #6B3220;   /* deep clay */
  --cr-cream:  #F5EDE2;   /* warm cream — breathing space */
  --cr-cream2: #FBF6EE;   /* lightest cream */
  --cr-warm-w: #FFF9EA;   /* warm white (from final files) — problem bg */
  --cr-green:  #05B86F;   /* fresh CR green — insight counterpoint */
  --cr-green-d:#006B46;   /* deep green */
  --cr-bone:   #F5EDE2;   /* warm bone (alias, kept for compatibility) */
  --cr-ink:    #1A0C0A;   /* warm near-black base — lifted slightly so bees read */
  --cr-ink2:   #241210;   /* lifted warm panel */
  --cr-dim:    #C9B3A6;   /* muted warm text on dark */
  --cr-faint:  rgba(245,237,226,.08);
  /* light-section tokens */
  --cr-ink-t:  #1A0C0A;   /* dark text on cream sections */
  --cr-body-t: #4A352E;   /* body text on cream sections */
  --cr-rule-l: rgba(26,12,10,.12); /* hairline on cream sections */
}

body.case-cr { background: var(--cr-ink); }

/* The bee colony canvas now reads — lifted opacity, sits above the
   deep base but below content. Red no longer washes over it. */
#c { position: fixed; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; opacity: .72; }

/* ── Evoked African mosaic motif ─────────────────────────────
   A subtle, slightly grungy geometric texture drawn from CR's
   heritage pattern. Used quietly behind select sections. */
.cr-mosaic-bg { position: relative; }
.cr-mosaic-bg::before {
  content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  opacity: .05;
  background-image:
    repeating-linear-gradient(45deg, var(--cr-gold) 0 1px, transparent 1px 14px),
    repeating-linear-gradient(-45deg, var(--cr-clay) 0 1px, transparent 1px 14px),
    repeating-linear-gradient(0deg, var(--cr-red) 0 1px, transparent 1px 28px);
  background-size: 28px 28px, 28px 28px, 28px 28px;
}
.cr-mosaic-bg > * { position: relative; z-index: 1; }

/* ── Fluid curved section dividers ───────────────────────────
   Organic flow between sections instead of hard rigid edges. */
.cr-flow-divider { position: relative; height: 0; line-height: 0; z-index: 2; }
.cr-flow-divider svg { display: block; width: 100%; height: 80px; }

/* ════════════════════════════════════════════════════════════
   HERO — you arrive mid-campaign, orders streaming
════════════════════════════════════════════════════════════ */
.cr-hero {
  position: relative; z-index: 1;
  min-height: 100vh; display: flex; flex-direction: column;
  padding: 7rem 3rem 0; overflow: hidden;
}
.cr-hero::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse 65% 55% at 18% 12%, rgba(216,30,44,.13) 0%, transparent 55%),
    radial-gradient(ellipse 50% 55% at 88% 20%, rgba(232,163,23,.10) 0%, transparent 58%),
    radial-gradient(ellipse 60% 70% at 90% 88%, rgba(74,8,16,.32) 0%, transparent 62%);
}
.cr-hero-head { flex: 0 0 auto; }
.cr-client-row {
  display: flex; align-items: center; gap: 1.2rem; margin-bottom: 3.5rem;
  opacity: 0; transform: translateY(-8px);
}
.cr-client-badge {
  display: flex; align-items: center; gap: .6rem;
  font-family: 'Space Mono', monospace; font-size: .58rem;
  letter-spacing: .2em; text-transform: uppercase; color: var(--cr-bone);
}
.cr-client-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--cr-red); box-shadow: 0 0 0 3px rgba(216,30,44,.22); }
.cr-divider { width: 1px; height: 13px; background: rgba(245,237,226,.2); }

.cr-hero-mid {
  flex: 1; display: grid; grid-template-columns: 1.25fr .75fr;
  gap: 4rem; align-items: center; padding: 2rem 0;
}
.cr-hero-left {}
.cr-kicker {
  font-family: 'Space Mono', monospace; font-size: .66rem;
  letter-spacing: .26em; text-transform: uppercase; color: var(--ch);
  margin-bottom: 2rem; opacity: 0; transform: translateY(12px);
}
.cr-hero-title {
  font-size: clamp(3.2rem, 9vw, 9.5rem); font-weight: 200;
  line-height: .85; letter-spacing: -.05em; color: var(--cr-bone);
  margin-bottom: 2.5rem;
}
.cr-hero-title .l { display: block; overflow: hidden; }
.cr-hero-title .w { display: inline-block; transform: translateY(115%); }
.cr-hero-title .q { color: var(--cr-bone); font-style: italic; }
.cr-hero-title .o { color: var(--cr-gold); }
.cr-hero-sub {
  font-size: clamp(1rem, 1.6vw, 1.25rem); font-weight: 300;
  line-height: 1.55; color: rgba(245,237,226,.7); max-width: 480px;
  opacity: 0; transform: translateY(12px);
}
.cr-hero-sub em { color: var(--cr-gold); font-style: normal; }

/* Live order ticker — the atmospheric spine */
.cr-ticker-frame {
  position: relative;
  border: 1px solid var(--cr-faint);
  background: linear-gradient(180deg, rgba(33,11,13,.6) 0%, rgba(22,7,8,.3) 100%);
  border-radius: 6px; overflow: hidden;
  height: 440px;
  opacity: 0; transform: translateX(20px);
}
.cr-ticker-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.2rem; border-bottom: 1px solid var(--cr-faint);
  background: rgba(22,7,8,.5);
}
.cr-ticker-live {
  display: flex; align-items: center; gap: .55rem;
  font-family: 'Space Mono', monospace; font-size: .56rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--cr-bone);
}
.cr-live-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--cr-red);
  animation: crpulse 1.6s ease-in-out infinite;
}
@keyframes crpulse { 0%,100% { opacity: 1; box-shadow: 0 0 0 0 rgba(216,30,44,.5); } 50% { opacity: .6; box-shadow: 0 0 0 5px rgba(216,30,44,0); } }
.cr-ticker-loc {
  font-family: 'Space Mono', monospace; font-size: .52rem;
  letter-spacing: .12em; text-transform: uppercase; color: var(--cr-dim);
}
.cr-ticker-feed { position: relative; height: calc(100% - 52px); overflow: hidden; }
.cr-ticker-track { position: absolute; top: 0; left: 0; right: 0; padding: .5rem 0; }
.cr-order-row {
  display: flex; align-items: flex-start; gap: .8rem;
  padding: .85rem 1.2rem;
  border-bottom: 1px solid rgba(245,237,226,.05);
}
.cr-order-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--cr-gold);
  margin-top: .35rem; flex-shrink: 0;
}
.cr-order-row.fresh .cr-order-dot { background: var(--cr-red); box-shadow: 0 0 8px rgba(216,30,44,.8); }
.cr-order-body { flex: 1; min-width: 0; }
.cr-order-who {
  font-family: 'Space Mono', monospace; font-size: .62rem;
  letter-spacing: .06em; color: var(--cr-red); margin-bottom: .2rem;
}
.cr-order-row.fresh .cr-order-who { color: var(--cr-gold); }
.cr-order-what { font-size: .82rem; color: var(--cr-bone); line-height: 1.35; }
.cr-ticker-fade {
  position: absolute; left: 0; right: 0; height: 60px; pointer-events: none; z-index: 2;
}
.cr-ticker-fade.top { top: 52px; background: linear-gradient(to bottom, rgba(22,7,8,.9), transparent); }
.cr-ticker-fade.bot { bottom: 0; background: linear-gradient(to top, rgba(22,7,8,.9), transparent); }

.cr-hero-foot {
  flex: 0 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 2rem 0 2.5rem; gap: 2rem; flex-wrap: wrap;
  border-top: 1px solid var(--cr-faint); margin-top: 1rem;
}
.cr-counter-block { display: flex; align-items: baseline; gap: 1rem; opacity: 0; }
.cr-counter {
  font-size: clamp(2rem, 4vw, 3.5rem); font-weight: 200;
  letter-spacing: -.04em; color: var(--cr-gold); line-height: 1;
  font-variant-numeric: tabular-nums;
}
.cr-counter-label {
  font-family: 'Space Mono', monospace; font-size: .58rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--cr-dim);
  max-width: 180px; line-height: 1.5;
}
.cr-hero-meta { display: flex; gap: 2.5rem; }
.cr-meta-item { opacity: 0; }
.cr-meta-label {
  font-family: 'Space Mono', monospace; font-size: .52rem;
  letter-spacing: .16em; text-transform: uppercase; color: rgba(245,237,226,.4);
  margin-bottom: .4rem;
}
.cr-meta-value { font-size: .86rem; font-weight: 300; color: var(--cr-bone); }

/* ════════════════════════════════════════════════════════════
   SECTIONS
════════════════════════════════════════════════════════════ */
.cr-section { position: relative; z-index: 1; padding: 8rem 3rem; }
.cr-num {
  font-family: 'Space Mono', monospace; font-size: .6rem;
  letter-spacing: .2em; color: var(--cr-red); margin-bottom: 1.5rem;
}
.cr-num.ch { color: var(--ch); }
.cr-eyebrow {
  font-family: 'Space Mono', monospace; font-size: .62rem;
  letter-spacing: .22em; text-transform: uppercase; color: var(--ch);
  margin-bottom: 2rem;
}
.reveal { opacity: 0; transform: translateY(24px); }

/* ── The problem ───────────────────────────────────────────── */
.cr-problem {
  border-top: 1px solid var(--cr-rule-l);
  background: var(--cr-warm-w);
}
.cr-problem .cr-num { color: var(--cr-red); }
.cr-problem-statement {
  font-size: clamp(2.2rem, 5vw, 4.5rem); font-weight: 200;
  line-height: 1.05; letter-spacing: -.035em; color: var(--cr-ink-t);
  max-width: 1000px; margin-bottom: 3rem;
}
.cr-problem-statement .red { color: var(--cr-red); font-style: italic; }
.cr-problem-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4rem;
  margin-top: 4rem; padding-top: 3rem; border-top: 1px solid var(--cr-rule-l);
}
.cr-problem-col p { font-size: .98rem; line-height: 1.8; color: var(--cr-body-t); margin-bottom: 1.2rem; }
.cr-problem-col p:last-child { margin-bottom: 0; }
.cr-stat-inline { color: var(--cr-red); font-weight: 400; }

/* ── Insight band ──────────────────────────────────────────── */
.cr-insight {
  text-align: center; border-top: 1px solid var(--cr-faint);
  border-bottom: 1px solid var(--cr-faint);
  background:
    radial-gradient(ellipse 70% 80% at 50% 50%, rgba(5,184,111,.12) 0%, transparent 66%),
    radial-gradient(ellipse 45% 55% at 78% 68%, rgba(232,163,23,.07) 0%, transparent 60%);
}
.cr-insight-line {
  font-size: clamp(1.8rem, 4vw, 3.4rem); font-weight: 200;
  line-height: 1.18; letter-spacing: -.025em; color: var(--cr-bone);
  max-width: 1100px; margin: 0 auto;
}
.cr-insight-line .em { color: var(--cr-green); font-style: italic; }
.cr-insight-foot {
  margin-top: 3rem; font-family: 'Space Mono', monospace;
  font-size: .62rem; letter-spacing: .14em; color: var(--cr-green);
}

/* ════════════════════════════════════════════════════════════
   THE MICROSITE MOCK — interactive centerpiece
════════════════════════════════════════════════════════════ */
.cr-activation { border-top: 1px solid var(--cr-faint); }
.cr-activation-head { max-width: 700px; margin-bottom: 4rem; }
.cr-activation-title {
  font-size: clamp(2.5rem, 6vw, 5.5rem); font-weight: 200;
  letter-spacing: -.04em; line-height: .92; color: var(--cr-bone);
  margin-bottom: 1.5rem;
}
.cr-activation-title .q { font-style: italic; }
.cr-activation-title .o { color: var(--cr-gold); }
.cr-activation-desc { font-size: 1rem; line-height: 1.7; color: rgba(245,237,226,.65); }

.cr-mock {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2px;
  border: 1px solid var(--cr-faint); border-radius: 10px; overflow: hidden;
  min-height: 580px;
}
/* Left: the form */
.cr-mock-form {
  padding: 3rem; background: var(--cr-ink2);
  display: flex; flex-direction: column;
}
.cr-mock-phone-label {
  display: flex; align-items: center; gap: .6rem;
  font-family: 'Space Mono', monospace; font-size: .54rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--cr-dim);
  margin-bottom: 2.5rem;
}
.cr-mock-q {
  font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 200;
  letter-spacing: -.03em; color: var(--cr-bone); margin-bottom: 2.5rem;
  line-height: 1.1;
}
.cr-mock-q .o { color: var(--cr-red); font-style: italic; }
.cr-field { margin-bottom: 1.5rem; }
.cr-field-label {
  display: block; font-family: 'Space Mono', monospace;
  font-size: .54rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--cr-dim); margin-bottom: .6rem;
}
.cr-input, .cr-select {
  width: 100%; padding: .9rem 1rem;
  background: rgba(22,7,8,.6); border: 1px solid var(--cr-faint);
  border-radius: 5px; color: var(--cr-bone);
  font-family: 'DM Sans', sans-serif; font-size: .92rem;
  transition: border-color .3s, box-shadow .3s; cursor: none;
}
.cr-input::placeholder { color: rgba(194,165,156,.5); }
.cr-input:focus, .cr-select:focus {
  outline: none; border-color: var(--cr-red);
  box-shadow: 0 0 0 3px rgba(216,30,44,.12);
}
.cr-select { appearance: none; -webkit-appearance: none; cursor: none; }
.cr-submit {
  margin-top: auto; width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 1.4rem; border: none; border-radius: 5px;
  background: var(--cr-gold); color: var(--cr-ink-t);
  font-family: 'Space Mono', monospace; font-size: .64rem;
  letter-spacing: .14em; text-transform: uppercase; cursor: none;
  transition: background .3s, transform .3s, box-shadow .3s;
}
.cr-submit:hover { background: var(--cr-gold-d); transform: translateY(-2px); box-shadow: 0 12px 28px rgba(232,163,23,.3); }
.cr-submit .arr { font-size: 1rem; }

/* Right: the shareable output */
.cr-mock-output {
  padding: 3rem; background: var(--cr-ink);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.cr-mock-output::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(245,237,226,.03) 1px, transparent 1px);
  background-size: 22px 22px;
}
/* The 9:16 shareable card */
.cr-share-card {
  position: relative; z-index: 1;
  width: 280px; aspect-ratio: 9/16;
  background: linear-gradient(155deg, var(--cr-gold) 0%, var(--cr-gold-d) 50%, var(--cr-red) 100%);
  border-radius: 14px; padding: 2.2rem 1.8rem;
  display: flex; flex-direction: column;
  box-shadow: 0 30px 60px rgba(0,0,0,.45);
  overflow: hidden;
  transition: transform .6s var(--ease);
}
.cr-share-card::after {
  content: '?'; position: absolute; right: -2rem; bottom: -3rem;
  font-family: Georgia, serif; font-style: italic; font-weight: 700;
  font-size: 16rem; color: rgba(181,18,27,.18); line-height: 1;
}
.cr-share-brand {
  font-family: 'Space Mono', monospace; font-size: .54rem;
  letter-spacing: .18em; text-transform: uppercase; color: rgba(26,12,10,.66);
  margin-bottom: auto; position: relative; z-index: 1;
}
.cr-share-gh {
  display: flex; align-items: center; gap: .4rem;
  margin-top: .5rem; z-index: 2; justify-content: flex-end;
}
.cr-share-gh img {
  width: 13px; height: 13px; object-fit: contain; opacity: .55;
}
.cr-share-gh span {
  font-family: 'Space Mono', monospace; font-size: .42rem;
  letter-spacing: .1em; text-transform: uppercase;
  color: rgba(26,12,10,.45);
}
.cr-share-name {
  font-size: 1.5rem; font-weight: 400; color: var(--cr-ink-t);
  margin-bottom: .4rem; position: relative; z-index: 1; line-height: 1.1;
  word-break: break-word;
}
.cr-share-order-label {
  font-family: 'Space Mono', monospace; font-size: .5rem;
  letter-spacing: .14em; text-transform: uppercase; color: rgba(26,12,10,.55);
  margin-bottom: .5rem; position: relative; z-index: 1;
}
.cr-share-order {
  font-size: 1.05rem; line-height: 1.35; color: var(--cr-ink-t);
  font-weight: 300; margin-bottom: 1.5rem; position: relative; z-index: 1;
  word-break: break-word;
}
.cr-share-tag {
  font-family: 'Space Mono', monospace; font-size: .72rem;
  letter-spacing: .06em; color: var(--cr-red-d); font-weight: 700;
  position: relative; z-index: 1;
}
.cr-share-still {
  font-family: 'Space Mono', monospace; font-size: .5rem;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(26,12,10,.55); margin-top: .3rem; position: relative; z-index: 1;
}
.cr-share-placeholder {
  text-align: center; color: var(--cr-dim);
  font-family: 'Space Mono', monospace; font-size: .58rem;
  letter-spacing: .1em; line-height: 1.8; max-width: 220px;
}
.cr-share-card.empty {
  background: rgba(33,11,13,.5);
  border: 1px dashed var(--cr-faint);
  align-items: center; justify-content: center;
  box-shadow: none;
}
.cr-share-card.empty::after { display: none; }
.cr-share-card.pop { animation: cardpop .6s var(--ease); }
@keyframes cardpop { 0% { transform: scale(.92); opacity: .5; } 60% { transform: scale(1.03); } 100% { transform: scale(1); opacity: 1; } }

/* ── Share buttons ──────────────────────────────────────── */
.cr-mock-output-inner {
  display: flex; flex-direction: column; align-items: center; gap: 1.4rem;
  position: relative; z-index: 1;
}
.cr-share-btns {
  display: none; flex-direction: column; align-items: center; gap: .8rem;
  width: 280px;
}
.cr-share-btns.visible { display: flex; }
.cr-share-btns-label {
  font-family: 'Space Mono', monospace; font-size: .52rem;
  letter-spacing: .18em; text-transform: uppercase; color: var(--cr-dim);
}
.cr-share-btns-row {
  display: flex; gap: .6rem; width: 100%;
}
.cr-share-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  gap: .3rem; padding: .65rem .4rem;
  border: 1px solid var(--cr-rule); background: rgba(26,12,10,.35);
  color: var(--cr-cream); cursor: pointer; border-radius: 8px;
  font-family: 'Space Mono', monospace; font-size: .44rem;
  letter-spacing: .1em; text-transform: uppercase;
  transition: background .25s, border-color .25s, transform .2s;
}
.cr-share-btn:hover { background: rgba(26,12,10,.6); transform: translateY(-2px); }
.cr-share-btn:active { transform: scale(.96); }
.cr-share-btn svg { width: 18px; height: 18px; }
.cr-share-btn.loading { opacity: .5; pointer-events: none; }
.cr-share-wa  { border-color: rgba(37,211,102,.4); color: #25d366; }
.cr-share-wa:hover  { background: rgba(37,211,102,.08); border-color: #25d366; }
.cr-share-x   { border-color: rgba(255,255,255,.25); }
.cr-share-dl  { border-color: rgba(212,245,60,.3); color: #D4F53C; }
.cr-share-dl:hover  { background: rgba(212,245,60,.08); border-color: #D4F53C; }
.cr-share-native { border-color: var(--cr-gold); color: var(--cr-gold); }
.cr-share-native:hover { background: rgba(232,163,23,.1); }

/* ════════════════════════════════════════════════════════════
   HUNGER MAP moment
════════════════════════════════════════════════════════════ */
.cr-map {
  border-top: 1px solid var(--cr-rule-l);
  background: var(--cr-cream2);
  text-align: center;
}
.cr-map .cr-num { color: var(--cr-red); }
.cr-map-title {
  font-size: clamp(2.2rem, 5vw, 4.5rem); font-weight: 200;
  letter-spacing: -.04em; color: var(--cr-ink-t); margin-bottom: 1.5rem; line-height: .95;
}
.cr-map-title .acc { color: var(--cr-clay); font-style: italic; }
.cr-map-desc { font-size: 1rem; line-height: 1.7; color: var(--cr-body-t); max-width: 620px; margin: 0 auto 4rem; }
.cr-map-viz {
  position: relative; max-width: 860px; margin: 0 auto;
  border-radius: 12px; overflow: hidden;
  background: linear-gradient(160deg, #1a0a0c 0%, #120608 60%, #0e0405 100%);
  border: 1px solid var(--cr-rule);
  box-shadow: 0 40px 80px rgba(0,0,0,.45);
}
.cr-nigeria-svg {
  width: 100%; height: auto; display: block;
}

/* ── Land + borders ──────────────────────────────────────── */
.cr-ng-land {
  fill: #2a0f0f;
  stroke: #5a1a1a;
  stroke-width: 1.5;
}
.cr-ng-borders {
  stroke: #8b3030;
  stroke-width: 0.8;
  fill: none;
}
.cr-ng-water {
  fill: #1a3a4a;
}

/* ── City dots ───────────────────────────────────────────── */
.cr-city-dot {
  stroke-width: 2;
}
.cr-dot-primary {
  fill: #D81E2C;
  stroke: rgba(216,30,44,.4);
  filter: drop-shadow(0 0 6px rgba(216,30,44,.7));
}
.cr-dot-secondary {
  fill: #E8A317;
  stroke: rgba(232,163,23,.4);
  filter: drop-shadow(0 0 5px rgba(232,163,23,.6));
}

/* ── Pulse rings ─────────────────────────────────────────── */
.cr-city-pulse {
  fill: none;
  stroke: #D81E2C;
  stroke-width: 1;
  opacity: 0;
  animation: crPulse 3s ease-out infinite;
}
.cr-city-group[data-city="Kano"] .cr-city-pulse,
.cr-city-group[data-city="Kaduna"] .cr-city-pulse,
.cr-city-group[data-city="Ibadan"] .cr-city-pulse,
.cr-city-group[data-city="Enugu"] .cr-city-pulse,
.cr-city-group[data-city="Benin City"] .cr-city-pulse {
  stroke: #E8A317;
}
.cr-pulse-delay-1 { animation-delay: 1s; }
.cr-pulse-delay-2 { animation-delay: 2s; }
.cr-pulse-delay-3 { animation-delay: 0.5s; }
@keyframes crPulse {
  0%   { opacity: .8; r: 8;  }
  100% { opacity: 0;  r: 28; }
}

/* ── City names ──────────────────────────────────────────── */
.cr-city-name {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  fill: rgba(242,230,220,.9);
  letter-spacing: .06em;
  text-transform: uppercase;
  dominant-baseline: middle;
}
.cr-name-left {
  text-anchor: end;
}

/* ── Callout bubbles ─────────────────────────────────────── */
.cr-callout-bg {
  fill: rgba(20,6,6,.82);
  stroke: rgba(216,30,44,.3);
  stroke-width: 1;
}
.cr-city-group[data-city="Kano"] .cr-callout-bg,
.cr-city-group[data-city="Kaduna"] .cr-callout-bg,
.cr-city-group[data-city="Ibadan"] .cr-callout-bg,
.cr-city-group[data-city="Enugu"] .cr-callout-bg,
.cr-city-group[data-city="Benin City"] .cr-callout-bg {
  stroke: rgba(232,163,23,.3);
}
.cr-callout-order {
  font-family: 'Space Mono', monospace;
  font-size: 9.5px;
  fill: rgba(242,220,200,.75);
  letter-spacing: .02em;
}

/* ── Legend + data label ─────────────────────────────────── */
.cr-legend-text {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  fill: rgba(242,220,200,.5);
  letter-spacing: .05em;
  dominant-baseline: middle;
}
.cr-map-data-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  fill: rgba(242,220,200,.3);
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* ════════════════════════════════════════════════════════════
   PHASES — vertical timeline
════════════════════════════════════════════════════════════ */
.cr-phases {
  border-top: 1px solid var(--cr-rule-l);
  background: var(--cr-cream2);
}
.cr-phases .cr-num { color: var(--cr-red); }
.cr-phase {
  display: grid; grid-template-columns: 90px 1fr; gap: 2.5rem;
  padding: 3rem 0; border-bottom: 1px solid var(--cr-rule-l);
  position: relative;
}
.cr-phase:last-child { border-bottom: none; }
.cr-phase-num {
  font-family: 'Space Mono', monospace; font-size: 1.6rem; font-weight: 700;
  color: rgba(22,7,8,.12); line-height: 1;
}
.cr-phase:last-child .cr-phase-num { color: var(--cr-red); }
.cr-phase-name {
  font-size: 1.7rem; font-weight: 200; letter-spacing: -.02em;
  color: var(--cr-ink-t); margin-bottom: .8rem; line-height: 1.05;
}
.cr-phase-meta {
  font-family: 'Space Mono', monospace; font-size: .56rem;
  letter-spacing: .12em; text-transform: uppercase; color: var(--cr-red);
  margin-bottom: 1rem;
}
.cr-phase-body { font-size: .95rem; line-height: 1.75; color: var(--cr-body-t); max-width: 760px; }

/* ════════════════════════════════════════════════════════════
   REVEAL — Nigeria's Order
════════════════════════════════════════════════════════════ */
.cr-reveal-sec {
  border-top: 1px solid var(--cr-faint); text-align: center;
  background:
    radial-gradient(ellipse 60% 70% at 50% 40%, rgba(216,30,44,.16) 0%, transparent 60%),
    radial-gradient(ellipse 30% 40% at 50% 45%, rgba(232,163,23,.08) 0%, transparent 55%);
}
.cr-reveal-label {
  font-family: 'Space Mono', monospace; font-size: .6rem;
  letter-spacing: .24em; text-transform: uppercase; color: var(--cr-gold); margin-bottom: 2rem;
}
.cr-reveal-title {
  font-size: clamp(2.8rem, 7vw, 7rem); font-weight: 200;
  letter-spacing: -.045em; line-height: .9; color: var(--cr-bone); margin-bottom: 2rem;
}
.cr-reveal-title .red { color: var(--cr-gold); font-style: italic; }
.cr-reveal-body { font-size: 1.05rem; line-height: 1.7; color: rgba(245,237,226,.65); max-width: 640px; margin: 0 auto; }

/* ── Download ──────────────────────────────────────────────── */
.cr-download { border-top: 1px solid var(--cr-faint); }
.cr-download-inner { display: grid; grid-template-columns: 1.3fr 1fr; gap: 5rem; align-items: center; }
.cr-download-title { font-size: clamp(2.2rem, 5vw, 4.2rem); font-weight: 200; letter-spacing: -.04em; line-height: .95; color: var(--cr-bone); margin-bottom: 1.5rem; }
.cr-download-title .acc { color: var(--cr-gold); font-style: italic; }
.cr-download-body { font-size: .98rem; line-height: 1.75; color: rgba(245,237,226,.65); max-width: 440px; margin-bottom: 2.5rem; }
.cr-download-card {
  position: relative; padding: 2.5rem;
  background: linear-gradient(135deg, rgba(232,163,23,.12) 0%, rgba(156,74,46,.16) 100%);
  border: 1px solid var(--cr-faint); border-radius: 8px; overflow: hidden;
}
.cr-download-card::before {
  content: '?'; position: absolute; top: -1rem; right: -.5rem;
  font-family: Georgia, serif; font-style: italic; font-weight: 700;
  font-size: 9rem; color: rgba(232,163,23,.10); line-height: 1;
}
.cr-deck-icon {
  width: 56px; height: 56px; border-radius: 8px; background: var(--cr-red);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem; margin-bottom: 1.5rem; box-shadow: 0 10px 30px rgba(216,30,44,.3);
}
.cr-deck-name { font-size: 1.2rem; font-weight: 400; color: var(--cr-bone); margin-bottom: .4rem; position: relative; z-index: 1; }
.cr-deck-meta { font-family: 'Space Mono', monospace; font-size: .56rem; letter-spacing: .12em; text-transform: uppercase; color: var(--cr-dim); margin-bottom: 2rem; position: relative; z-index: 1; }
.cr-download-btn {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  width: 100%; font-family: 'Space Mono', monospace; font-size: .64rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--cr-ink);
  background: var(--ch); padding: 1.1rem 1.6rem; text-decoration: none; border-radius: 4px;
  transition: transform .3s var(--ease), box-shadow .3s; position: relative; z-index: 1;
}
.cr-download-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(212,245,60,.25); }

/* ── Closer ────────────────────────────────────────────────── */
.cr-closer { border-top: 1px solid var(--cr-faint); text-align: center; padding: 9rem 3rem; position: relative; overflow: hidden; }
.cr-closer-glow { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 80%; height: 500px; background: radial-gradient(ellipse at bottom, rgba(232,163,23,.07) 0%, transparent 65%); pointer-events: none; }
.cr-closer-label { font-family: 'Space Mono', monospace; font-size: .6rem; letter-spacing: .24em; text-transform: uppercase; color: var(--cr-gold); margin-bottom: 2rem; }
.cr-closer-title { font-size: clamp(2.5rem, 6vw, 6rem); font-weight: 200; letter-spacing: -.04em; line-height: .92; color: var(--cr-bone); margin-bottom: 3rem; }
.cr-closer-title .acc { color: var(--cr-gold); font-style: italic; }
.cr-closer-btns { display: flex; gap: 1.2rem; justify-content: center; flex-wrap: wrap; }

/* ── Footer ────────────────────────────────────────────────── */
.cr-footer { position: relative; z-index: 1; padding: 3rem; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1.5rem; border-top: 1px solid var(--cr-faint); }
.cr-footer-logo { font-family: 'Space Mono', monospace; font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--cr-bone); }
.cr-footer-logo em { color: var(--ch); font-style: normal; }
.cr-footer-meta { font-family: 'Space Mono', monospace; font-size: .56rem; letter-spacing: .1em; color: rgba(245,237,226,.4); }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .cr-hero-mid { grid-template-columns: 1fr; }
  .cr-ticker-frame { height: 340px; }
  .cr-problem-grid { grid-template-columns: 1fr; gap: 2rem; }
  .cr-mock { grid-template-columns: 1fr; }
  .cr-download-inner { grid-template-columns: 1fr; gap: 2.5rem; }
}
@media (max-width: 768px) {
  .cr-hero { padding: 6rem 1.5rem 0; }
  .cr-section { padding: 5rem 1.5rem; }
  .cr-hero-meta { gap: 1.5rem; }
  .cr-phase { grid-template-columns: 50px 1fr; gap: 1.2rem; }
  .cr-footer { flex-direction: column; text-align: center; }
}

/* ── OOH carousel / campaign canvas ───────────────────────── */
.cr-ooh {
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(232,163,23,.14);
  background:
    radial-gradient(ellipse 70% 80% at 18% 14%, rgba(232,163,23,.10), transparent 60%),
    radial-gradient(ellipse 62% 78% at 88% 92%, rgba(5,184,111,.10), transparent 66%),
    linear-gradient(180deg, #160708 0%, #241210 55%, #110507 100%);
}
.cr-flow-ribbon {
  position: absolute;
  width: 82vw;
  height: 82vw;
  right: -32vw;
  top: -22vw;
  border-radius: 47% 53% 61% 39% / 42% 48% 52% 58%;
  border: 1px solid rgba(232,163,23,.12);
  background:
    radial-gradient(ellipse at 30% 30%, rgba(232,163,23,.11), transparent 50%),
    radial-gradient(ellipse at 66% 62%, rgba(241,50,58,.14), transparent 58%);
  filter: blur(.2px);
  animation: crLiquid 18s ease-in-out infinite alternate;
  pointer-events: none;
}
@keyframes crLiquid {
  0% { transform: rotate(-8deg) scale(1); border-radius: 47% 53% 61% 39% / 42% 48% 52% 58%; }
  100% { transform: rotate(8deg) scale(1.06); border-radius: 58% 42% 44% 56% / 52% 36% 64% 48%; }
}
.cr-ooh-head {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.15fr .85fr; gap: 4rem; align-items: end;
  margin-bottom: 4rem;
}
.cr-ooh-title {
  font-size: clamp(2.4rem, 5.6vw, 5.6rem);
  font-weight: 200; line-height: .94; letter-spacing: -.045em;
  color: var(--cr-bone);
}
.cr-ooh-title .sun { color: var(--cr-gold); font-style: italic; }
.cr-ooh-desc { font-size: 1rem; line-height: 1.75; color: rgba(245,237,226,.68); max-width: 540px; }
.cr-ooh-shell {
  position: relative; z-index: 1;
  border: 1px solid rgba(232,163,23,.15);
  border-radius: 18px;
  background: rgba(20,6,7,.38);
  box-shadow: 0 36px 120px rgba(0,0,0,.36), inset 0 1px 0 rgba(245,237,226,.04);
  overflow: hidden;
}
.cr-ooh-stage { position: relative; min-height: 560px; }
.cr-ooh-slide {
  position: absolute; inset: 0;
  display: grid; grid-template-columns: .82fr 1.18fr; gap: 3rem; align-items: center;
  padding: 3rem;
  opacity: 0; pointer-events: none; transform: translateX(36px) scale(.985);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.cr-ooh-slide.is-active { opacity: 1; pointer-events: auto; transform: translateX(0) scale(1); }
.cr-ooh-kicker {
  font-family: 'Space Mono', monospace; font-size: .58rem; letter-spacing: .17em; text-transform: uppercase;
  color: var(--cr-gold); margin-bottom: 1.2rem;
}
.cr-ooh-copy h3 {
  font-size: clamp(2rem, 4vw, 4.2rem); font-weight: 200; line-height: .95; letter-spacing: -.04em;
  color: var(--cr-bone); margin-bottom: 1.4rem;
}
.cr-ooh-copy p { font-size: .98rem; line-height: 1.75; color: rgba(245,237,226,.66); max-width: 440px; }
.cr-ooh-frame {
  position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden;
  border: 1px solid rgba(245,237,226,.12);
  background:
    linear-gradient(135deg, rgba(232,163,23,.96) 0%, rgba(232,163,23,.86) 28%, rgba(241,50,58,.95) 28%, rgba(181,18,27,.98) 100%);
  box-shadow: 0 24px 80px rgba(0,0,0,.38);
}
.cr-ooh-landscape { aspect-ratio: 16/9; border-radius: 12px; }
.cr-ooh-poster { width: min(380px, 100%); aspect-ratio: 4/5; border-radius: 16px; margin-left: auto; margin-right: auto; }
.cr-ooh-shelter { width: min(360px, 100%); aspect-ratio: 9/16; border-radius: 20px; margin-left: auto; margin-right: auto; background: linear-gradient(180deg, var(--cr-gold) 0%, #F5EDE2 50%, var(--cr-red) 100%); }
.cr-ooh-placeholder {
  position: absolute; top: 1rem; left: 1rem;
  font-family: 'Space Mono', monospace; font-size: .52rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(27,9,8,.55); background: rgba(255,249,234,.7); padding: .45rem .55rem; border-radius: 999px;
  backdrop-filter: blur(8px);
}
.cr-ooh-artmark {
  position: absolute; right: -1rem; bottom: -2.8rem;
  font-family: Georgia, serif; font-weight: 700; font-style: italic; line-height: .84;
  font-size: clamp(8rem, 18vw, 16rem); color: rgba(27,9,8,.12); letter-spacing: -.08em;
}
.cr-ooh-boardline {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: .9rem 1.2rem; background: rgba(20,6,7,.92); color: var(--cr-gold);
  font-family: 'Space Mono', monospace; font-size: .66rem; letter-spacing: .12em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cr-ooh-poster-type {
  position: relative; z-index: 1; color: var(--cr-ink-t);
  font-size: clamp(2rem, 4vw, 4.6rem); line-height: .82; letter-spacing: -.055em; font-weight: 700; text-align: center;
}
.cr-ooh-cardgrid {
  position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: .65rem; padding: 2rem; width: 100%;
}
.cr-ooh-cardgrid span {
  min-height: 84px; border-radius: 12px; background: rgba(255,249,234,.72); color: var(--cr-ink-t);
  display: flex; align-items: center; justify-content: center; text-align: center; padding: .8rem;
  font-size: .78rem; font-weight: 700; box-shadow: 0 10px 28px rgba(27,9,8,.12);
}
.cr-ooh-controls {
  display: flex; align-items: center; gap: 1rem;
  padding: 1rem 1.2rem 1.2rem; border-top: 1px solid rgba(232,163,23,.12);
}
.cr-ooh-btn {
  width: 42px; height: 42px; border-radius: 50%; border: 1px solid rgba(232,163,23,.22);
  background: rgba(232,163,23,.08); color: var(--cr-gold);
  font-family: 'Space Mono', monospace; cursor: none;
  transition: transform .25s var(--ease), background .25s;
}
.cr-ooh-btn:hover { transform: translateY(-2px); background: rgba(232,163,23,.16); }
.cr-ooh-progress { flex: 1; height: 2px; background: rgba(245,237,226,.12); overflow: hidden; border-radius: 99px; }
.cr-ooh-progress span { display: block; height: 100%; width: 33.333%; background: linear-gradient(90deg, var(--cr-gold), var(--cr-green)); transition: transform .55s var(--ease); }

/* ── Form: selfie upload + activation prompt (grafted, recoloured) ──
*/
.cr-activation-prompt {
  position: relative;
  max-width: 680px;
  margin-top: 1.25rem;
  margin-bottom: 3rem;
  padding-left: 1.35rem;
  border-left: 2px solid var(--cr-gold);
}
.cr-activation-prompt .cr-activation-desc {
  margin: 0;
  font-size: clamp(.98rem, 1.25vw, 1.12rem);
  line-height: 1.68;
  font-weight: 300;
  letter-spacing: -.005em;
  color: rgba(245,237,226,.76);
}
.cr-activation-path {
  position: absolute;
  left: .95rem;
  bottom: -2.55rem;
  width: 160px;
  height: 46px;
  overflow: visible;
  opacity: .9;
  pointer-events: none;
}
.cr-activation-path path {
  fill: none;
  stroke: var(--cr-gold);
  stroke-width: 1.4;
  stroke-linecap: round;
  stroke-dasharray: 4 7;
}

/* ── Selfie upload: campaign mechanic, not a file field ────── */
.cr-selfie-field { margin-top: -.1rem; }
.cr-selfie-upload {
  position: relative;
  display: flex;
  align-items: center;
  gap: .85rem;
  width: 100%;
  padding: .9rem .95rem;
  border: 1px dashed rgba(232,163,23,.44);
  border-radius: 999px;
  background:
    radial-gradient(circle at 12% 50%, rgba(232,163,23,.16), transparent 34%),
    linear-gradient(90deg, rgba(232,163,23,.07), rgba(216,30,44,.045));
  color: var(--cr-bone);
  cursor: none;
  transition: border-color .3s var(--ease), background .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.cr-selfie-upload:hover {
  transform: translateY(-2px);
  border-color: var(--cr-gold);
  box-shadow: 0 14px 34px rgba(0,0,0,.2);
  background:
    radial-gradient(circle at 12% 50%, rgba(232,163,23,.24), transparent 36%),
    linear-gradient(90deg, rgba(232,163,23,.11), rgba(216,30,44,.06));
}
.cr-selfie-upload input[type="file"] {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.cr-selfie-plus {
  width: 2.15rem;
  height: 2.15rem;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--cr-gold);
  color: var(--cr-ink-t);
  font-family: 'Space Mono', monospace;
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 700;
}
.cr-selfie-copy {
  display: flex;
  flex-direction: column;
  gap: .12rem;
  min-width: 0;
}
.cr-selfie-copy strong {
  font-size: .9rem;
  font-weight: 400;
  color: var(--cr-bone);
  letter-spacing: -.01em;
}
.cr-selfie-copy small {
  font-size: .72rem;
  font-weight: 300;
  color: rgba(245,237,226,.58);
}
.cr-selfie-tag {
  margin-left: auto;
  flex-shrink: 0;
  font-family: 'Space Mono', monospace;
  font-size: .48rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(232,163,23,.86);
  border: 1px solid rgba(232,163,23,.3);
  border-radius: 999px;
  padding: .32rem .5rem;
}
.cr-selfie-thumb {
  display: none;
  width: 2.15rem;
  height: 2.15rem;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 2px solid var(--cr-gold);
  box-shadow: 0 0 0 3px rgba(232,163,23,.12);
}
.cr-selfie-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.cr-selfie-upload.has-file {
  border-style: solid;
  border-color: rgba(232,163,23,.78);
}
.cr-selfie-upload.has-file .cr-selfie-plus {
  background: var(--cr-red);
  color: var(--cr-bone);
  font-size: 0;
}
.cr-selfie-upload.has-file .cr-selfie-plus::before {
  content: '✓';
  font-size: .95rem;
}
.cr-selfie-upload.has-file .cr-selfie-tag {
  color: var(--cr-ink-t);
  background: var(--cr-gold);
  border-color: var(--cr-gold);
}
.cr-selfie-upload.has-file .cr-selfie-thumb { display: block; }

.cr-share-selfie {
  position: relative;
  z-index: 1;
  width: 4.5rem;
  height: 4.5rem;
  margin-bottom: 1rem;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 3px solid rgba(27,9,8,.82);
  box-shadow: 0 12px 30px rgba(27,9,8,.22), 0 0 0 5px rgba(245,237,226,.18);
}

/* ── Grafted form/carousel — mobile refinements ───────────── */
@media (max-width: 768px) {
  .cr-activation-path { width: 130px; }
  .cr-selfie-tag { display: none; }
  .cr-ooh-head { grid-template-columns: 1fr; gap: 1.5rem; }
  .cr-ooh-slide { grid-template-columns: 1fr; gap: 1.5rem; padding: 1.5rem; }
  .cr-ooh-stage { min-height: 720px; }
  /* Hide desktop nav on mobile */
  .nlinks { display: none !important; }
  .ncta   { display: none !important; }
  /* Show hamburger */
  .nav-burger { display: flex !important; }
}

/* ── Hamburger button ──────────────────────────────────────── */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  z-index: 1003;
  position: relative;
  margin-left: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.nav-burger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transform-origin: center;
}
.nav-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Mobile menu overlay ───────────────────────────────────── */
.nav-mobile {
  position: fixed;
  inset: 0;
  background: var(--navy);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}
.nav-mobile.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.nav-mobile-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  text-align: center;
}
.nav-mobile-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.nav-mobile-links li a {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(2.2rem, 10vw, 3.5rem);
  font-weight: 200;
  color: var(--white);
  text-decoration: none;
  letter-spacing: -0.03em;
  line-height: 1.15;
  transition: color 0.2s;
}
.nav-mobile-links li a.active { color: var(--ch); }
.nav-mobile-links li a:hover  { color: var(--ch); }
.nav-mobile-cta {
  font-family: 'Space Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--navy);
  background: var(--ch);
  padding: 0.9rem 2rem;
  text-decoration: none;
  border-radius: 2px;
  transition: opacity 0.2s;
}
.nav-mobile-cta:hover { opacity: 0.88; }
.nav-mobile-foot {
  font-family: 'Space Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dim);
}