/* ────────────────────────────────────────────────────────────────
   Policy issuance demo — Typeform-style, 5 focused screens.
   Visuals: Relief design system (DESIGN.md).
   ──────────────────────────────────────────────────────────────── */

:root {
  /* Colors — Relief */
  --color-sky-canvas: #f9f7f0;
  --color-arctic-mist: #ffffff;
  --color-deep-ocean: #13426f;
  --color-hope-blue: #2e96ff;
  --color-subtle-gray: #616c8a;
  --color-slate-text: #333333;
  --color-powder-blue: #bde1f9;
  --color-cerulean-link: #0254a5;
  --color-shadow-tint: #cde7fb;
  --color-dim-gray: #d0d5dd;

  /* Typography */
  --font-gilroy: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system,
    BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --text-caption: 12px;     --tracking-caption: -0.22px;
  --text-body-sm: 14px;     --tracking-body-sm: -0.25px;
  --text-body: 16px;        --tracking-body: -0.29px;
  --text-subheading: 18px;  --tracking-subheading: -0.32px;
  --text-heading-sm: 20px;  --tracking-heading-sm: -0.36px;
  --text-heading: 32px;     --tracking-heading: -0.58px;
  --text-heading-lg: 40px;  --tracking-heading-lg: -0.72px;
  --text-display: 58px;     --tracking-display: -1.04px;

  /* Radius / shadow */
  --radius-cards: 18px;
  --radius-cards-lg: 26px;
  --radius-buttons: 70px;
  --shadow-subtle: rgba(154, 207, 246, 0.5) 0px 7px 0px 0px;
  --shadow-subtle-2: rgba(0, 0, 0, 0.05) 0px 3px 0px 0px;
  --shadow-subtle-3: rgba(154, 207, 246, 0.5) 0px 5px 0px 0px;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--color-sky-canvas);
  color: var(--color-slate-text);
  font-family: var(--font-gilroy);
  font-size: var(--text-body);
  line-height: 1.6;
  letter-spacing: var(--tracking-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
ol, ul { list-style: none; padding: 0; margin: 0; }
button { font-family: inherit; cursor: pointer; }
a { text-decoration: none; color: inherit; }
kbd {
  font-family: inherit;
  background: var(--color-arctic-mist);
  border: 1px solid var(--color-dim-gray);
  border-radius: 6px;
  padding: 1px 6px;
  font-size: 12px;
  color: var(--color-deep-ocean);
}

/* ─── Topbar ─── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(249, 247, 240, 0.85);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid rgba(208, 213, 221, 0.5);
}
.topbar {
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid rgba(208, 213, 221, 0.6);
  position: sticky;
  top: 0;
  z-index: 20;
}
.topbar__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 64px;
}

/* Left — brand cluster */
.topbar__brand-group {
  display: inline-flex;
  align-items: center;
  gap: 18px;
}
.brandmark {
  display: inline-flex;
  align-items: center;
}
.brandmark__logo {
  height: 32px;
  width: auto;
  display: block;
  flex: none;
}
.topbar__tag {
  display: inline-flex;
  align-items: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 100px;
  line-height: 1;
}

/* Right — nav links + CTA */
.topbar__nav {
  display: inline-flex;
  align-items: center;
  gap: 36px;
}
.topbar__link {
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-deep-ocean);
  font-weight: 600;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: color .15s ease, border-color .15s ease;
}
.topbar__link:hover {
  color: var(--color-cerulean-link);
  border-bottom-color: var(--color-hope-blue);
}
.topbar__link--with-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-bottom: none;
  padding-bottom: 0;
}
.topbar__link--with-logo:hover { border-bottom: none; }
.topbar__inline-logo {
  height: 22px;
  width: auto;
  display: block;
  flex: none;
}

@media (max-width: 720px) {
  .topbar__inner {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 14px 20px;
    min-height: 0;
  }
  .topbar__brand-group { justify-content: flex-start; }
  .topbar__nav {
    justify-content: space-between;
    width: 100%;
    gap: 12px;
  }
}

/* ─── Stage / screens ─── */
.stage {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 24px 80px;
  position: relative;
}
.screen {
  width: 100%;
  max-width: 880px;
  margin: 0 auto;
}
.screen[hidden] { display: none !important; }
.screen.is-active { animation: fadeUp .4s ease both; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: none; }
}

.screen__inner {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.screen__inner--centered { align-items: flex-start; text-align: left; }

.kicker {
  display: inline-flex;
  align-items: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  font-size: var(--text-caption);
  letter-spacing: 0.4px;
  font-weight: 700;
  padding: 8px 16px;
  border-radius: 100px;
  text-transform: uppercase;
  align-self: flex-start;
}

.display {
  margin: 0;
  font-size: clamp(32px, 5vw, var(--text-display));
  line-height: 1.1;
  letter-spacing: var(--tracking-display);
  color: var(--color-deep-ocean);
  font-weight: 800;
}
.lede {
  margin: 0;
  font-size: var(--text-subheading);
  letter-spacing: var(--tracking-subheading);
  color: var(--color-slate-text);
  max-width: 640px;
}
.lede--muted { color: var(--color-subtle-gray); }
.lede--prelist { margin-bottom: -8px; font-weight: 600; color: var(--color-deep-ocean); }

/* ─── Configuration options list ─── */
.options-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 640px;
}
.option {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--color-arctic-mist);
  border: 1px solid rgba(208, 213, 221, 0.6);
  border-radius: var(--radius-cards);
  padding: 18px 22px;
  box-shadow: var(--shadow-subtle-2);
}
.option__icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  border-radius: 12px;
  flex: none;
}
.option__text {
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-slate-text);
  font-weight: 500;
}
.caption {
  margin: 0;
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-subtle-gray);
}
.caption--focus {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  padding: 12px 20px;
  border-radius: var(--radius-cards);
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  font-weight: 600;
  max-width: 720px;
  text-align: left;
  box-shadow: var(--shadow-subtle-2);
}
.caption--focus strong { font-weight: 800; }
.caption--focus .caption__mark {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  background: var(--color-arctic-mist);
  color: var(--color-hope-blue);
  border-radius: 50%;
  flex: none;
}

/* ─── Buttons ─── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: none;
  background: transparent;
  color: var(--color-deep-ocean);
  font-weight: 700;
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  border-radius: var(--radius-buttons);
  padding: 14px 28px;
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
  white-space: nowrap;
}
.btn--primary {
  background: var(--color-hope-blue);
  color: var(--color-arctic-mist);
  box-shadow: var(--shadow-subtle);
}
.btn--primary:hover { background: #1f86f0; transform: translateY(-1px); }
.btn--primary:active { transform: translateY(2px); box-shadow: rgba(154, 207, 246, 0.5) 0 2px 0 0; }
.btn--primary:focus-visible { outline: 3px solid var(--color-powder-blue); outline-offset: 3px; }
.btn--primary[disabled] { background: #9cc7f3; box-shadow: none; cursor: not-allowed; transform: none; }

.btn--ghost {
  background: transparent;
  color: var(--color-subtle-gray);
}
.btn--ghost:hover { background: rgba(46, 150, 255, 0.06); color: var(--color-deep-ocean); }

.btn--lg { padding: 16px 32px; font-size: var(--text-subheading); }
.btn--xl { padding: 20px 36px; font-size: var(--text-heading-sm); }

.actions {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.actions--secondary { margin-top: 24px; }
.hint {
  font-size: var(--text-body-sm);
  color: var(--color-subtle-gray);
  letter-spacing: var(--tracking-body-sm);
}

/* ─── Screen 2 — Choose your configuration ─── */
.choice-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 4px;
}
@media (max-width: 880px) { .choice-grid { grid-template-columns: 1fr; } }

.choice {
  background: var(--color-arctic-mist);
  border: 1.5px solid rgba(208, 213, 221, 0.7);
  border-radius: var(--radius-cards);
  padding: 24px 24px 20px;
  text-align: left;
  font-family: inherit;
  cursor: pointer;
  box-shadow: var(--shadow-subtle-2);
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
  display: flex;
  flex-direction: column;
  gap: 14px;
  color: var(--color-slate-text);
}
.choice:hover {
  border-color: var(--color-hope-blue);
  transform: translateY(-2px);
}
.choice.is-selected {
  border-color: var(--color-hope-blue);
  box-shadow: 0 0 0 4px rgba(46, 150, 255, 0.12), var(--shadow-subtle-2);
}

.choice__head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
}
.choice__icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  border-radius: 12px;
  flex: none;
}
.choice__title {
  font-size: var(--text-heading-sm);
  letter-spacing: var(--tracking-heading-sm);
  color: var(--color-deep-ocean);
  font-weight: 800;
}
.choice__check {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: transparent;
  border: 2px solid var(--color-dim-gray);
  display: grid; place-items: center;
  color: transparent;
  transition: all .18s ease;
}
.choice.is-selected .choice__check {
  background: var(--color-hope-blue);
  border-color: var(--color-hope-blue);
  color: var(--color-arctic-mist);
}

.choice__sub {
  margin: 0;
  color: var(--color-subtle-gray);
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
}

.flow {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 1px dashed var(--color-dim-gray);
  padding-top: 14px;
  margin-top: 2px;
}
.flow li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-slate-text);
}
.flow__num {
  flex: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--color-sky-canvas);
  color: var(--color-deep-ocean);
  border: 1px solid var(--color-dim-gray);
  display: grid; place-items: center;
  font-size: 11px;
  font-weight: 800;
}
.choice.is-selected .flow__num {
  background: var(--color-powder-blue);
  border-color: var(--color-powder-blue);
}

/* ─── (legacy) Screen 2 — signers ─── */
.signer-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 4px;
}
@media (max-width: 720px) { .signer-list { grid-template-columns: 1fr; } }

.signer {
  background: var(--color-arctic-mist);
  border: 1px solid rgba(208, 213, 221, 0.6);
  border-radius: var(--radius-cards);
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 18px;
  box-shadow: var(--shadow-subtle-2);
}
.signer__icon {
  width: 48px; height: 48px;
  display: grid; place-items: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  border-radius: 14px;
  flex: none;
}
.signer__title {
  margin: 0 0 2px;
  font-size: var(--text-heading-sm);
  letter-spacing: var(--tracking-heading-sm);
  color: var(--color-deep-ocean);
  font-weight: 800;
}
.signer__sub {
  margin: 0;
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-subtle-gray);
}
.signer__sub strong { color: var(--color-deep-ocean); font-weight: 700; }

/* ─── Screen 3 — Customer browser mockup ─── */
.browser {
  background: var(--color-arctic-mist);
  border-radius: 14px;
  border: 1px solid var(--color-dim-gray);
  box-shadow:
    0 24px 60px -20px rgba(19, 66, 111, 0.18),
    0 8px 24px -8px rgba(19, 66, 111, 0.10);
  overflow: hidden;
  max-width: 760px;
  margin: 4px auto 0;
  width: 100%;
}
.browser__chrome {
  background: #f1eee5;
  border-bottom: 1px solid var(--color-dim-gray);
  padding: 12px 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
}
.browser__dots {
  display: inline-flex;
  gap: 8px;
}
.browser__dots span {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: #d0d5dd;
}
.browser__dots span:nth-child(1) { background: #f56565; }
.browser__dots span:nth-child(2) { background: #f6c152; }
.browser__dots span:nth-child(3) { background: #58c27d; }
.browser__url {
  background: var(--color-arctic-mist);
  border: 1px solid var(--color-dim-gray);
  border-radius: 100px;
  padding: 6px 14px;
  font-size: 12px;
  color: var(--color-subtle-gray);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  justify-self: center;
}

.browser__viewport {
  min-height: 420px;
  display: flex;
  flex-direction: column;
}

.webapp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  border-bottom: 1px solid rgba(208, 213, 221, 0.5);
  background: var(--color-arctic-mist);
}
.webapp-header__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  color: var(--color-deep-ocean);
  letter-spacing: -0.3px;
  font-size: 15px;
}
.webapp-header__mark {
  width: 22px; height: 22px;
  border-radius: 7px;
  background: var(--color-hope-blue);
  box-shadow: 0 2px 0 0 var(--color-shadow-tint);
}
.webapp-header__user {
  font-size: 12px;
  color: var(--color-subtle-gray);
  font-weight: 600;
}

.webapp-body {
  flex: 1;
  padding: 32px 36px 36px;
  background: var(--color-sky-canvas);
  position: relative;
}
@media (max-width: 540px) {
  .webapp-body { padding: 24px 20px 28px; }
}

.app-state {
  display: none;
  flex-direction: column;
  gap: 16px;
  animation: appFade .35s ease both;
}
.app-state.is-active { display: flex; }
.app-state[hidden] { display: none; }
@keyframes appFade {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: none; }
}

.app-state__title {
  margin: 0;
  font-size: 22px;
  letter-spacing: -0.4px;
  color: var(--color-deep-ocean);
  font-weight: 800;
}
.app-state__sub {
  margin: 0;
  color: var(--color-subtle-gray);
  font-size: 14px;
  letter-spacing: -0.2px;
}
.app-state__fineprint {
  margin: 4px 0 0;
  font-size: 11px;
  color: var(--color-subtle-gray);
  letter-spacing: 0.1px;
}

.payment-summary {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--color-arctic-mist);
  border: 1px solid rgba(208, 213, 221, 0.6);
  border-radius: 14px;
  padding: 4px 18px;
  margin: 6px 0 4px;
}
.payment-summary li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  font-size: 14px;
  border-bottom: 1px dashed var(--color-dim-gray);
  letter-spacing: -0.2px;
}
.payment-summary li:last-child { border-bottom: none; }
.payment-summary li span { color: var(--color-subtle-gray); }
.payment-summary li strong { color: var(--color-deep-ocean); font-weight: 700; }
.payment-summary__total span,
.payment-summary__total strong {
  font-size: 16px !important;
  color: var(--color-deep-ocean) !important;
  font-weight: 800 !important;
}

.app-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--color-hope-blue);
  color: var(--color-arctic-mist);
  border: none;
  border-radius: 12px;
  padding: 14px 22px;
  font-family: inherit;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -0.2px;
  cursor: pointer;
  margin-top: 6px;
  box-shadow: 0 4px 0 0 var(--color-shadow-tint);
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.app-cta:hover { background: #1f86f0; transform: translateY(-1px); }
.app-cta:active { transform: translateY(2px); box-shadow: 0 1px 0 0 var(--color-shadow-tint); }

/* Loader */
.app-loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 50px 0;
  text-align: center;
}
.app-loader__title {
  margin: 0;
  font-size: 20px;
  font-weight: 800;
  color: var(--color-deep-ocean);
  letter-spacing: -0.3px;
}
.app-loader__sub {
  margin: 0;
  font-size: 13px;
  color: var(--color-subtle-gray);
}
.loader-ring {
  position: relative;
  width: 56px;
  height: 56px;
}
.loader-ring span {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 4px solid transparent;
  border-top-color: var(--color-hope-blue);
  animation: ringSpin 1s linear infinite;
}
.loader-ring span:nth-child(2) { animation-delay: -0.25s; opacity: .7; }
.loader-ring span:nth-child(3) { animation-delay: -0.5s; opacity: .45; }
.loader-ring span:nth-child(4) { animation-delay: -0.75s; opacity: .25; }
@keyframes ringSpin { to { transform: rotate(360deg); } }

/* Success */
.app-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 36px 0 24px;
  text-align: center;
}
.app-success__tick {
  width: 68px; height: 68px;
  border-radius: 50%;
  background: var(--color-hope-blue);
  color: var(--color-arctic-mist);
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 8px rgba(46, 150, 255, 0.12);
  animation: pop .45s cubic-bezier(.2, 1.4, .5, 1) both;
}
@keyframes pop {
  0% { transform: scale(.4); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}
.app-success__title {
  margin: 0;
  font-size: 22px;
  font-weight: 800;
  color: var(--color-deep-ocean);
  letter-spacing: -0.4px;
}
.app-success__sub {
  margin: 0;
  font-size: 15px;
  color: var(--color-slate-text);
  letter-spacing: -0.2px;
}
.app-success__caption {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--color-subtle-gray);
}
.app-success .app-cta { margin-top: 14px; }

/* ─── Agent dashboard mockup ─── */
.browser--agent .webapp-header__brand { color: var(--color-deep-ocean); }

.agent-body {
  flex: 1;
  padding: 26px 32px 28px;
  background: var(--color-sky-canvas);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
@media (max-width: 540px) {
  .agent-body { padding: 22px 18px 22px; }
}

.agent-case {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  background: var(--color-arctic-mist);
  border: 1px solid rgba(208, 213, 221, 0.6);
  border-radius: 14px;
  padding: 14px 18px;
}
.agent-case__avatar {
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.4px;
}
.agent-case__name {
  margin: 0;
  font-weight: 800;
  color: var(--color-deep-ocean);
  font-size: 15px;
  letter-spacing: -0.3px;
}
.agent-case__meta {
  margin: 2px 0 0;
  color: var(--color-subtle-gray);
  font-size: 12px;
  letter-spacing: -0.1px;
}
.agent-case__amount {
  font-weight: 800;
  color: var(--color-deep-ocean);
  font-size: 16px;
  letter-spacing: -0.3px;
}

.agent-journey {
  background: var(--color-arctic-mist);
  border: 1px solid rgba(208, 213, 221, 0.6);
  border-radius: 14px;
  padding: 18px 20px;
}
.agent-journey__title {
  margin: 0 0 14px;
  font-size: 12px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--color-subtle-gray);
}
.agent-journey__steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
}
.agent-journey__steps li {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 8px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-subtle-gray);
  padding: 0 4px;
}
.agent-journey__steps li::before {
  content: "";
  position: absolute;
  top: 7px;
  left: 50%;
  width: 100%;
  height: 2px;
  background: var(--color-dim-gray);
  z-index: 0;
}
.agent-journey__steps li:last-child::before { display: none; }
.agent-journey__steps li.is-done::before { background: var(--color-hope-blue); }
.agent-journey__steps li.is-current::before {
  background: linear-gradient(to right, var(--color-hope-blue) 50%, var(--color-dim-gray) 50%);
}
.agent-journey__dot {
  position: relative;
  z-index: 1;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--color-arctic-mist);
  border: 2px solid var(--color-dim-gray);
  transition: all .25s ease;
}
.agent-journey__steps li.is-done {
  color: var(--color-deep-ocean);
}
.agent-journey__steps li.is-done .agent-journey__dot {
  background: var(--color-hope-blue);
  border-color: var(--color-hope-blue);
}
.agent-journey__steps li.is-current {
  color: var(--color-deep-ocean);
}
.agent-journey__steps li.is-current .agent-journey__dot {
  border-color: var(--color-hope-blue);
  background: var(--color-arctic-mist);
  animation: pulse 1.1s ease-in-out infinite;
}

.agent-journey__status {
  margin: 14px 0 0;
  font-size: 13px;
  color: var(--color-deep-ocean);
  font-weight: 600;
  letter-spacing: -0.2px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.agent-journey__pulse {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-hope-blue);
  animation: blink 1s ease-in-out infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: .35; }
}
.agent-journey[data-payment="done"] .agent-journey__pulse { display: none; }

.agent-action {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
  margin-top: 4px;
}
.agent-action__pane[hidden] { display: none; }
.agent-action__pane {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
  animation: appFade .3s ease both;
}
.agent-action__hint {
  margin: 0;
  font-size: 12px;
  color: var(--color-subtle-gray);
}
#issuePolicyBtn:disabled {
  background: #d0d5dd;
  color: #ffffff;
  box-shadow: none;
  cursor: not-allowed;
  opacity: 1;
}
.agent-action__pane[data-pane="issuing"] .app-loader { padding: 22px 0; }
.agent-action__pane[data-pane="issued"] .app-success { padding: 16px 0; align-items: flex-start; text-align: left; }

.agent-body__fineprint {
  margin: 4px 0 0;
  font-size: 11px;
  color: var(--color-subtle-gray);
  letter-spacing: 0.1px;
}

/* ─── Screen 4 — Leegality at work tracks ─── */
.tracks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 8px;
}
@media (max-width: 880px) { .tracks { grid-template-columns: 1fr; } }

.track {
  background: var(--color-arctic-mist);
  border: 1px solid rgba(208, 213, 221, 0.6);
  border-radius: var(--radius-cards);
  padding: 26px 24px;
  box-shadow: var(--shadow-subtle-2);
  position: relative;
  overflow: hidden;
  transition: border-color .25s ease, box-shadow .25s ease;
}
.track[data-state="active"] {
  border-color: var(--color-hope-blue);
  box-shadow: 0 0 0 4px rgba(46, 150, 255, 0.10), var(--shadow-subtle-2);
}
.track[data-state="done"] {
  border-color: rgba(46, 150, 255, 0.35);
}
.track__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.track__label {
  font-size: var(--text-heading-sm);
  letter-spacing: var(--tracking-heading-sm);
  font-weight: 800;
  color: var(--color-deep-ocean);
}
.track__badge {
  display: inline-flex;
  align-items: center;
  background: var(--color-powder-blue);
  color: var(--color-deep-ocean);
  font-size: 11px;
  letter-spacing: 0.3px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 100px;
  text-transform: uppercase;
}

.track__steps {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.track__steps li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-subtle-gray);
  padding: 8px 4px;
  transition: color .25s ease;
}
.track__steps li.is-active {
  color: var(--color-deep-ocean);
  font-weight: 700;
}
.track__steps li.is-done {
  color: var(--color-deep-ocean);
}
.track__steps li.is-pending {
  opacity: 0.55;
}
.dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 2px solid var(--color-dim-gray);
  background: var(--color-arctic-mist);
  flex: none;
  position: relative;
}
.track__steps li.is-active .dot {
  border-color: var(--color-hope-blue);
  background: var(--color-arctic-mist);
  animation: pulse 1s ease-in-out infinite;
}
.track__steps li.is-done .dot {
  border-color: var(--color-hope-blue);
  background: var(--color-hope-blue);
}
.track__steps li.is-done .dot::after {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  background: var(--color-arctic-mist);
  clip-path: polygon(15% 50%, 40% 75%, 85% 25%, 75% 15%, 40% 55%, 25% 40%);
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(46, 150, 255, 0.4); }
  50% { box-shadow: 0 0 0 6px rgba(46, 150, 255, 0); }
}

/* ─── Screen 5 — outcome ─── */
.outcome {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.explainer {
  background: var(--color-arctic-mist);
  border-radius: var(--radius-cards);
  padding: 18px 22px;
  border: 1px solid rgba(208, 213, 221, 0.6);
  box-shadow: var(--shadow-subtle-2);
  margin-top: 8px;
  max-width: 720px;
}
.explainer summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--color-deep-ocean);
  font-size: var(--text-body);
  list-style: none;
}
.explainer summary::-webkit-details-marker { display: none; }
.explainer summary::after {
  content: "+";
  float: right;
  color: var(--color-hope-blue);
  font-weight: 800;
  transition: transform .2s;
}
.explainer[open] summary::after { content: "−"; }
.explainer p {
  margin: 14px 0 0;
  color: var(--color-subtle-gray);
  font-size: var(--text-body-sm);
  line-height: 1.7;
  letter-spacing: var(--tracking-body-sm);
}

.cta-card {
  background: var(--color-deep-ocean);
  color: var(--color-arctic-mist);
  border-radius: var(--radius-cards-lg);
  padding: 28px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-top: 24px;
  width: 100%;
}
.cta-card__title {
  margin: 0 0 4px;
  font-size: var(--text-heading-sm);
  letter-spacing: var(--tracking-heading-sm);
  font-weight: 800;
}
.cta-card__sub {
  margin: 0;
  color: rgba(255, 255, 255, 0.75);
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
}

/* ─── Page foot ─── */
.page-foot {
  border-top: 1px solid rgba(208, 213, 221, 0.5);
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: var(--text-caption);
  color: var(--color-subtle-gray);
  letter-spacing: var(--tracking-caption);
}
@media (max-width: 720px) { .page-foot { flex-direction: column; gap: 6px; } }
