/* Voltaic "Un-Stuck" campaign hub — scoped case-brand styles; zero Lofty tokens.
   Campaign voice is deliberately louder than corporate: Volt Yellow on Asphalt. */
:root {
  --yl: #f5c518;
  --as: #2a2a2e;
  --ik: #161618;
  --gy: #8a8a92;
}
* { box-sizing: border-box; margin: 0; }
body {
  font-family: -apple-system, "Segoe UI", "Helvetica Neue", sans-serif;
  background: #f4f4f2;
  color: var(--ik);
  line-height: 1.55;
}
h1, h2 { font-weight: 900; letter-spacing: 0.01em; text-transform: uppercase; }
:focus-visible { outline: 3px solid var(--as); outline-offset: 2px; }

.vm-header { background: var(--as); color: #fff; text-align: center; padding: 42px 24px 30px; }
.vm-mark { width: 96px; display: block; margin: 0 auto 10px; }
.vm-header h1 { font-size: 26px; color: var(--yl); }
.vm-sub { font-size: 14px; opacity: 0.85; }

.vm-section { max-width: 880px; margin: 0 auto; padding: 40px 24px; border-bottom: 2px solid var(--as); }
.vm-section h2 { font-size: 19px; margin-bottom: 10px; }
.vm-note { font-size: 13.5px; max-width: 58ch; margin-top: 12px; }
.vm-tag { font-size: 11px; letter-spacing: 0.1em; border: 1.5px solid var(--as); padding: 3px 8px; vertical-align: middle; font-weight: 700; }

/* ---------- ad units (true IAB pixel sizes) ---------- */
.vm-ads { display: flex; flex-wrap: wrap; gap: 26px; align-items: flex-start; }
.vm-ad-fig { margin: 0; }
.vm-ad-fig figcaption { font-size: 12px; margin-top: 6px; }
.vm-ad { position: relative; background: var(--as); overflow: hidden; border: 1px solid var(--ik); }
.vm-ad-cta {
  position: absolute;
  background: var(--yl);
  color: var(--ik);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 7px 12px;
  text-transform: uppercase;
}

.vm-ad-mrec { width: 300px; height: 250px; }
.vm-jam { position: absolute; inset: 12px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; align-content: start; }
.vm-jam span { height: 26px; background: var(--gy); border-radius: 4px; opacity: 0.45; }
.vm-ad-mrec .vm-ad-line1, .vm-ad-mrec .vm-ad-line2 {
  position: relative;
  font-weight: 900;
  font-size: 30px;
  line-height: 1.04;
  color: #fff;
  padding: 0 16px;
  text-transform: uppercase;
}
.vm-ad-mrec .vm-ad-line1 { margin-top: 116px; animation: vm-rise 0.6s 0.5s backwards; }
.vm-ad-mrec .vm-ad-line2 { color: var(--yl); animation: vm-rise 0.6s 0.9s backwards; }
.vm-ad-mrec .vm-ad-cta { left: 16px; bottom: 14px; animation: vm-rise 0.5s 1.4s backwards; }
.vm-ad-arrow { position: absolute; right: 10px; bottom: 8px; width: 64px; animation: vm-arrow 1.1s 0.2s backwards; }
@keyframes vm-rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes vm-arrow { from { transform: translate(-40px, 30px); opacity: 0; } to { transform: none; opacity: 1; } }

.vm-ad-leader { width: 728px; max-width: 100%; height: 90px; display: flex; align-items: center; gap: 18px; padding: 0 18px; }
.vm-ad-leader .vm-ad-line1 { font-weight: 900; font-size: 24px; color: #fff; text-transform: uppercase; white-space: nowrap; animation: vm-slide 0.7s 0.3s backwards; }
.vm-ad-leader .vm-ad-line1 span { color: var(--yl); }
.vm-ad-brand { color: #b0b0b8; /* AA on asphalt */ font-weight: 700; font-size: 13px; letter-spacing: 0.14em; margin-left: auto; }
.vm-ad-leader .vm-ad-cta { position: static; animation: vm-rise 0.5s 1s backwards; }
@keyframes vm-slide { from { opacity: 0; transform: translateX(-24px); } to { opacity: 1; transform: none; } }

.vm-ad-mobile { width: 320px; height: 50px; display: flex; align-items: center; gap: 10px; padding: 0 10px; }
.vm-ad-mobile p { color: #fff; font-size: 12.5px; }
.vm-ad-mobile strong { color: var(--yl); }
.vm-ad-mobile .vm-ad-cta { position: static; padding: 5px 10px; }

.vm-ad-sky { width: 160px; height: 600px; }
.vm-jam-v { grid-template-columns: repeat(2, 1fr); }
.vm-ad-sky .vm-ad-line1, .vm-ad-sky .vm-ad-line2 { position: relative; font-weight: 900; font-size: 22px; line-height: 1.05; color: #fff; padding: 0 14px; text-transform: uppercase; }
.vm-ad-sky .vm-ad-line1 { margin-top: 210px; }
.vm-ad-sky .vm-ad-line2 { color: var(--yl); }
.vm-ad-sky .vm-ad-cta { left: 14px; bottom: 16px; }

@media (prefers-reduced-motion: reduce) {
  .vm-ad *, .vm-ad { animation: none !important; }
}

/* ---------- transit shelter ---------- */
.vm-shelter { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
.vm-poster {
  width: 250px;
  aspect-ratio: 1 / 1.4;
  background: var(--as);
  border: 10px solid #515158;
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
}
.vm-poster p { font-weight: 900; font-size: 38px; line-height: 1.02; text-transform: uppercase; color: #fff; }
.vm-poster-l3 { color: var(--yl); }
.vm-poster-foot { margin-top: auto; display: flex; justify-content: space-between; align-items: end; gap: 10px; }
.vm-poster-foot span:first-child { color: #b0b0b8; font-size: 10px; font-weight: 700; letter-spacing: 0.08em; }
.vm-qr {
  width: 44px; height: 44px; background:
    conic-gradient(#fff 25%, var(--as) 0 50%, #fff 0 75%, var(--as) 0) 0 0 / 22px 22px;
  border: 4px solid #fff;
}

/* ---------- copy platform ---------- */
.vm-btnrow { display: flex; gap: 8px; flex-wrap: wrap; }
.vm-btn { font: 700 13px inherit; padding: 10px 16px; background: #fff; border: 2px solid var(--as); cursor: pointer; }
.vm-btn.is-on { background: var(--as); color: var(--yl); }
.vm-copy { margin: 18px 0 0; border-left: 6px solid var(--yl); background: #fff; padding: 18px 22px; }
.vm-copy blockquote { font-weight: 900; font-size: 26px; text-transform: uppercase; }
.vm-copy figcaption { font-size: 13.5px; margin-top: 8px; }

/* ---------- dashboard ---------- */
.vm-dash { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; margin: 16px 0 22px; }
.vm-dash div { background: #fff; border: 2px solid var(--as); padding: 14px 16px; }
.vm-dash dt { font-size: 11.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: #63636b; /* AA on white */ }
.vm-dash dd { font-size: 28px; font-weight: 900; margin: 2px 0 0; }
.vm-dash dd span { font-size: 12px; font-weight: 600; color: #63636b; }
.vm-chart { display: flex; gap: 8px; align-items: end; height: 140px; background: #fff; border: 2px solid var(--as); padding: 14px; }
.vm-chart div { flex: 1; height: var(--h); background: var(--yl); border: 1.5px solid var(--ik); position: relative; min-height: 12px; }
.vm-chart span { position: absolute; bottom: -20px; left: 50%; translate: -50% 0; font-size: 10px; }

.vm-footer { text-align: center; padding: 26px; font-size: 12px; opacity: 0.8; }
@media (max-width: 480px) { .vm-ad-sky { display: none; } }

/* family consistency: static units get one quiet entrance (reduced-motion already collapses all) */
.vm-ad-mobile { animation: vm-rise 0.5s 0.6s backwards; }
.vm-ad-sky .vm-ad-line1 { animation: vm-rise 0.5s 0.8s backwards; }
.vm-ad-sky .vm-ad-line2 { animation: vm-rise 0.5s 1.0s backwards; }
