/* ============================================================================
   app.css — Apprenticeship Matcher
   ----------------------------------------------------------------------------
   Layered on top of the NYSDS "full" stylesheet (nysds-full.min.css), which
   provides the reset, base typography, design tokens, and utility classes.
   This file only contains styles for things the design system does NOT own:
   our page chrome, the chat transcript, the profile card, and our buttons.

   THEMING
   - The themeable colors below use the NYSDS theme tokens directly
     (--nys-color-theme, -faint, -weak, etc.). They respond automatically to
     the data-theme="business" attribute set on <body> in base.html, which
     maps the whole ramp to the Business/Labor teal (#084b52). Switch agencies
     by changing that one attribute — no edits here.
   - Each theme token also carries an inline fallback (the concept's teal
     values) so the page still looks right if the stylesheet fails to load.

   NON-THEME TOKENS
   - The :root block below is a thin alias layer over the NYSDS neutral /
     radius / shadow / spacing / font tokens, each with the concept's value as
     a fallback. This keeps the rules readable and means a wrong CDN path or a
     token-name mismatch degrades gracefully instead of breaking the layout.
     Once you've confirmed the live names in the NYSDS token browser, you can
     collapse each alias to the bare nys- token (or drop the fallback).
   ========================================================================== */

:root {
  /* colours */
  --app-ink: var(--nys-color-ink, #1b1b1b);
  --app-text-weak: var(--nys-color-text-weak, #4a4f54);
  --app-surface: var(--nys-color-surface, #ffffff);
  --app-surface-muted: var(--nys-color-surface-muted, #f6f8f9);
  --app-base: var(--nys-color-base, #d0d5d9);
  --app-base-weak: var(--nys-color-base-weak, #e4e8ea);
  --app-link: var(--nys-color-link, #004dd1);
  --app-focus: var(--nys-color-focus, #004dd1);
  --app-accent: var(--nys-color-accent, #face00);
  --app-warning-dark: #7a5c00;
  --app-glass-on-theme: rgba(255, 255, 255, 0.12);

  /* semantic aliases */
  --app-border: var(--app-base);
  --app-border-weak: var(--app-base-weak);
  --app-row-stripe: #fafcfc;
  --app-danger: #b91c1c;
  --app-warning-border: #ecdca0;
  --app-text-on-theme: var(--nys-color-ink-reverse, #ffffff);

  /* common component padding */
  --app-card-padding: 1rem 1.15rem;
  --app-panel-padding: 1.1rem 1.25rem;

  /* reverse (dark footer) */
  --app-surface-reverse: var(--nys-color-surface-reverse, #1b1b1b);
  --app-text-reverse: var(--nys-color-text-reverse, #ffffff);
  --app-link-reverse: var(--nys-color-link-reverse, #9cc3ff);

  /* radius */
  --app-radius-sm: var(--nys-radius-sm, 2px);
  --app-radius-md: var(--nys-radius-md, 6px);
  --app-radius-lg: var(--nys-radius-lg, 12px);
  --app-radius-pill: var(--nys-radius-pill, 999px);

  /* elevation */
  --app-shadow-sm: var(--nys-shadow-sm,
      0 1px 2px rgba(16, 24, 40, 0.06),
      0 1px 3px rgba(16, 24, 40, 0.1));
  --app-shadow-md: var(--nys-shadow-md, 0 4px 12px rgba(16, 24, 40, 0.1));

  /* spacing (NYSDS scale; fallbacks match the concept) */
  --app-space-50: var(--nys-space-50, 0.25rem);
  --app-space-100: var(--nys-space-100, 0.5rem);
  --app-space-150: var(--nys-space-150, 0.75rem);
  --app-space-200: var(--nys-space-200, 1rem);
  --app-space-300: var(--nys-space-300, 1.5rem);
  --app-space-400: var(--nys-space-400, 2rem);
  --app-space-600: var(--nys-space-600, 3rem);

  /* type — body font with a system fallback stack (Proxima Nova ships
     separately under NYS font licensing; see Typography in the docs) */
  --app-font: var(--nys-font-family-body,
      var(--nys-font-family-sans,
        "Proxima Nova",
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        Roboto,
        Helvetica,
        Arial,
        sans-serif));
}

/* ── Page shell ──────────────────────────────────────────────────────────── */
body {
  margin: 0;
  font-family: var(--app-font);
  color: var(--app-ink);
  background: var(--app-surface-muted);
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

a {
  color: var(--nys-color-theme);
}

a[class^="btn"]:hover,
a[class^="btn"]:focus {
  color: currentColor;
}

a.btn--filled:hover,
a.btn--filled:focus {
  color: var(--app-text-on-theme);
}

:focus-visible {
  outline: 3px solid var(--app-focus);
  outline-offset: 2px;
  border-radius: var(--app-radius-sm);
}

ul {
  list-style-type: disc;
}

ol {
  list-style-type: decimal;
}

[hidden] {
  display: none !important;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* Skip link — NYSDS-style accessibility affordance */
.skip-link {
  position: absolute;
  left: var(--app-space-100);
  top: -3rem;
  z-index: 10;
  background: var(--app-surface);
  color: var(--app-link);
  padding: var(--app-space-100) var(--app-space-200);
  border-radius: var(--app-radius-md);
  box-shadow: var(--app-shadow-md);
  text-decoration: none;
  transition: top 0.15s;
}

.skip-link:focus {
  top: var(--app-space-100);
}

.container {
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

.container.container-flex {
  display: flex;
}

.container:after,
.container:before {
  display: table;
  content: " ";
}

.container:after {
  clear: both;
}

.container.container-flex::before,
.container.container-flex::after {
  content: none;
  display: none;
}

.text-meta {
  color: var(--app-text-weak);
  font-size: 0.85rem;
}

@media (min-width: 768px) {
  .container {
    width: 750px;
  }
}

@media (min-width: 992px) {
  .container {
    width: 920px;
  }
}

@media (min-width: 1200px) {
  .container {
    width: 980px;
  }
}

/* ── SURFACES (shared cards / panels) ───────────────────────────────────── */

.surface {
  background: var(--app-surface);
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-md);
}

.surface--muted {
  background: var(--app-surface-muted);
}

.surface--shadow {
  box-shadow: var(--app-shadow-sm);
}

.surface--accent {
  border-left: 4px solid var(--nys-color-theme, #084b52);
}

.surface--clip {
  overflow: hidden;
}

/* ── CHIPS (shared component) ──────────────────────────────────────────── */

.chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: fit-content;
  font-size: 0.83rem;
  padding: 0.1rem 0.55rem;
  border-radius: var(--app-radius-pill);
}

.chip--theme {
  background: var(--nys-color-theme-faint, #eef5f5);
  border: 1px solid var(--nys-color-theme-weak, #a8cccd);
  color: var(--nys-color-theme-stronger, #042a2e);
}

.chip--theme-alt {
  background: var(--app-glass-on-theme);
  border: 1px solid var(--nys-color-business-teal-300);
  color: var(--app-text-on-theme);
}

.chip--strong {
  background: var(--nys-color-success-weak);
  color: var(--nys-color-success);
}

.chip--moderate {
  background: var(--nys-color-warning-weak);
  color: var(--app-warning-dark);
}

.chip--weak {
  background: var(--nys-color-link-reverse-strong);
  color: var(--app-text-weak);
}

.chip--bg-white {
  background: var(--nys-color-ink-reverse);
}

.chip .chip__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.chip .chip--label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── Beta / development notice (replaces the gov strip) ──────────────────── */
.dev-banner {
  padding: 0.4rem 1.25rem;
  font-size: 0.8rem;
  line-height: 1.3;
}

.dev-banner--notice {
  background: var(--nys-color-warning-weak, #fbf1cf);
  color: var(--app-warning-dark);
  border-bottom: 1px solid var(--app-warning-border);
}

.chip--banner-tag {
  color: var(--nys-color-ink-reverse);
  background: var(--app-warning-dark);
  margin-right: 0.75rem;
  border-radius: var(--app-radius-sm, 2px);
  height: max-content;
}

@media (max-width: 520px) {
  .chip--banner-tag {
    padding: 0.15rem 0.65rem
  }
}


/* ── Site header (light chrome) ──────────────────────────────────────────── */
.site-header {
  background: var(--app-surface);
  border-bottom: 1px solid var(--app-base);
  padding: 1rem 0;
}

.site-header>.container-flex {
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

.site-header .app-logo {
  line-height: 0;
  width: 140px;
}

.site-header .app-logo img {
  width: 100%;
}

.app-name {
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.2;
  margin: 0 .75rem;
}

.app-name a {
  color: currentColor;
  text-decoration: none;
}

.chip--phase-tag {
  margin-left: auto;
  color: var(--nys-color-theme);
}

@media (max-width: 520px) {
  .site-header .app-logo {
    max-width: 135px;
    min-width: 125px;
  }

  .site-header .app-name {
    font-size: 1rem;
    margin: 0 .65rem;
  }
}

/* ── Page title band ─────────────────────────────────────────────────────── */
.title-band {
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
  padding: 1.1rem 0;
}

.title-band-h {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: var(--app-text-on-theme);
}

.title-band-sub {
  margin: 0.2rem 0 0;
  font-size: 0.92rem;
  color: var(--nys-color-theme-weaker, #d7e8e9);
}

/* ── Main column ─────────────────────────────────────────────────────────── */
main {
  flex: 1;
  width: 100%;
  margin-top: 2.5rem;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

/* NEW CSS HERE */
/* ── Landing page ───────────────────────────────────────────────────────── */
body:has(.landing-page) {
  background: var(--app-surface);
}

body:has(.landing-page) .site-footer {
  margin-top: 0;
}

#main-content.landing-main {
  width: 100%;
  max-width: none;
  margin-top: 0;
  padding: 0;
  display: block;
}

.landing-main section+section {
  margin: 0;
}

.landing-hero {
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
  padding: 3rem 1.25rem 3.25rem;
  background-image: radial-gradient(circle at 85% 10%, rgba(255, 255, 255, 0.06), transparent 55%);
}

.landing-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 3rem;
  align-items: center;
}

.landing-hero .chip {
  padding: 0.3rem 0.7rem;
  margin-bottom: 1rem;
}

.landing-hero h1 {
  margin: 0;
  max-width: 11ch;
  font-size: clamp(2.2rem, 5vw, 2.9rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: 0.005em;
  color: var(--app-text-on-theme);
}

.landing-hero__subhead {
  margin: 1.1rem 0 0;
  font-size: 1.12rem;
  color: var(--nys-color-theme-weaker, #d7e8e9);
  max-width: 34ch;
}

.landing-reassure {
  list-style: none;
  margin: 1.5rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1rem;
  font-size: 0.9rem;
  color: var(--nys-color-theme-weaker, #d7e8e9);
}

.landing-reassure li {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}

.landing-reassure span {
  color: var(--app-accent);
  font-weight: 800;
}

.landing-paths {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.landing-path-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  text-decoration: none;
  border-radius: var(--app-radius-lg);
  padding: 1.3rem 1.4rem;
  transition:
    transform 0.12s,
    box-shadow 0.12s,
    background 0.12s;
}

.landing-path-card:hover,
.landing-path-card:focus {
  transform: translateY(-2px);
  box-shadow: var(--app-shadow-md);
  text-decoration: none;
}

.landing-path-card__body {
  flex: 1;
  min-width: 0;
}

.landing-path-card__kicker {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  margin: 0 0 0.15rem;
}

.landing-path-card__title {
  font-size: 1.3rem;
  font-weight: 800;
  margin: 0;
}

.landing-path-card__desc {
  font-size: 0.92rem;
  margin: 0.3rem 0 0;
  line-height: 1.4;
}

.landing-path-card__arrow {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.landing-path-card--primary {
  border-color: var(--app-surface);
}

.landing-path-card--primary .landing-path-card__kicker {
  color: var(--nys-color-theme-mid, #3f8186);
}

.landing-path-card--primary .landing-path-card__title {
  color: var(--nys-color-theme-stronger, #042a2e);
}

.landing-path-card--primary .landing-path-card__desc {
  color: var(--app-text-weak);
}

.landing-path-card--primary .landing-path-card__arrow {
  background: var(--app-accent);
  color: var(--app-ink);
}

.landing-path-card--secondary {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.35);
}

.landing-path-card--secondary .landing-path-card__kicker {
  color: var(--nys-color-theme-weak, #a8cccd);
}

.landing-path-card--secondary .landing-path-card__title {
  color: var(--app-text-on-theme);
}

.landing-path-card--secondary .landing-path-card__desc {
  color: var(--nys-color-theme-weaker, #d7e8e9);
}

.landing-path-card--secondary .landing-path-card__arrow {
  background: rgba(255, 255, 255, 0.16);
  color: var(--app-text-on-theme);
  border: 1px solid rgba(255, 255, 255, 0.4);
}

.landing-section {
  padding: 2.5rem 0;
}

.landing-section__title {
  text-align: center;
  font-size: 1.9rem;
  font-weight: 800;
  color: var(--app-ink);
  margin: 0 0 2rem;
}

.landing-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.landing-card-grid--loose {
  gap: 2rem;
}

.landing-step {
  text-align: center;
}

.landing-step__num {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
  font-size: 1.2rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 0.8rem;
}

.landing-step h3,
.landing-benefit-card h3 {
  margin: 0 0 0.35rem;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--app-ink);
}

.landing-step p,
.landing-benefit-card p {
  margin: 0;
  color: var(--app-text-weak);
  font-size: 0.9rem;
}

.landing-step p {
  text-wrap: balance;
}

.landing-benefits {
  background: var(--app-surface-muted);
}

.landing-benefit-card {
  padding: 1.5rem;
  border-radius: var(--nys-radius-xl);
}

.landing-benefit-card__icon {
  width: 46px;
  height: 46px;
  border-radius: var(--app-radius-md);
  background: var(--nys-color-theme-faint, #eef5f5);
  color: var(--nys-color-theme, #084b52);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.9rem;
}

.landing-benefit-card__icon svg {
  width: 26px;
  height: 26px;
}

.landing-quote {
  text-align: center;
}

.landing-quote__mark {
  font-size: 3rem;
  line-height: 0.5;
  color: var(--app-accent);
  font-weight: 800;
}

.landing-quote blockquote {
  margin: 0.5rem auto 0;
  max-width: 24ch;
  font-size: 1.65rem;
  font-weight: 800;
  color: var(--app-ink);
  line-height: 1.25;
}

.landing-quote cite {
  display: block;
  margin-top: 1rem;
  font-style: normal;
  color: var(--app-text-weak);
  font-size: 0.95rem;
}

.landing-final-cta {
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
  text-align: center;
}

.landing-final-cta h2 {
  margin: 0 0 0.4rem;
  font-size: 1.9rem;
  font-weight: 800;
  color: var(--app-text-on-theme);
}

.landing-final-cta p {
  margin: 0 0 1.5rem;
  color: var(--nys-color-theme-weaker, #d7e8e9);
}

.landing-final-cta__buttons {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
}

.landing-final-cta .btn--outline {
  color: var(--app-text-on-theme);
  border-color: rgba(255, 255, 255, 0.6);
}

.landing-final-cta .btn--outline:hover,
.landing-final-cta .btn--outline:focus {
  background: rgba(255, 255, 255, 0.1);
  color: var(--app-text-on-theme);
}

.landing-trust {
  background: var(--app-surface-muted);
  border-top: 1px solid var(--app-base);
  padding: 1.25rem;
  text-align: center;
}

.landing-trust__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  font-size: 0.9rem;
  color: var(--app-text-weak);
}

.landing-trust__seal {
  width: 24px;
  height: 24px;
  color: var(--nys-color-theme, #084b52);
  flex: 0 0 auto;
}

.landing-trust strong {
  color: var(--app-ink);
}

@media (max-width: 1020px) {
  .landing-hero__inner {
    grid-template-columns: minmax(0, 1fr) 400px;
    gap: 2rem;
  }
}

@media (max-width: 880px) {
  .landing-hero__inner {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .landing-hero h1 {
    max-width: 14ch;
  }
}

@media (max-width: 760px) {
  .landing-card-grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
    max-width: 330px;
    margin: 0 auto;
  }
}

@media (max-width: 520px) {

  .landing-hero,
  .landing-section {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .landing-path-card {
    padding: 1.1rem 1rem;
  }
}

/* NEW CSS ENDS */

/* ── Chat transcript ─────────────────────────────────────────────────────── */
.chat-stream {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

#chat-log {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--app-space-100);
}

.message {
  display: flex;
  flex-direction: column;
  gap: var(--app-space-50);
  max-width: 80%;
  scroll-margin-bottom: 8rem;
  /* clears the sticky composer when scrolled into view */
}

.message--user {
  align-self: flex-end;
  align-items: flex-end;
}

.message--assistant {
  align-self: flex-start;
  align-items: flex-start;
}

.message-role {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--app-text-weak);
}

.message-content {
  margin: 0;
  padding: 0.7rem 0.95rem;
  border-radius: var(--app-radius-lg);
  white-space: pre-wrap;
  word-break: break-word;
}

.message--assistant .message-content {
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
  font-family: var(--nys-font-family-serif);
}

.message--user .message-content {
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
}

/* streaming bubble */
#streaming-bubble {
  margin-top: var(--app-space-200);
}

#streaming-text::after {
  content: "▋";
  margin-left: 1px;
  color: var(--nys-color-theme-mid, #3f8186);
  animation: blink 0.9s step-end infinite;
}

@keyframes blink {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0;
  }
}

/* ── Profile summary card ────────────────────────────────────────────────── */
.profile-card {
  margin: var(--app-space-300) 0 0;
  scroll-margin-bottom: 8rem;
}

.profile-card-head {
  background: var(--nys-color-theme-faint, #eef5f5);
  border-bottom: 1px solid var(--nys-color-theme-weaker, #d7e8e9);
  padding: 0.7rem 1.1rem;
}

.profile-card-head h2 {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--nys-color-theme-stronger, #042a2e);
}

.profile-card-body {
  padding: 1.1rem 1.1rem 1.25rem 1.1rem;
}

.profile-card dl {
  margin: 0 0 1.1rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.45rem 1.25rem;
  align-items: baseline;
}

.profile-card dt {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--app-text-weak);
}

.profile-card dd {
  margin: 0;
  font-size: 0.97rem;
}

.chip--interest {
  margin: 0 0.25rem 0.3rem 0;
}

.btn-row {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}

/* ── Buttons (app-owned; styled with theme tokens) ───────────────────────────
   Named .btn rather than .nys-btn so we don't shadow any class the design
   system itself may ship; the official equivalent is the <nys-button> web
   component, which you can adopt later without touching these rules. */
.btn {
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 700;
  padding: 0.55rem 1.15rem;
  border-radius: var(--app-radius-md);
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 1.5px solid transparent;
  transition:
    background 0.12s,
    border-color 0.12s,
    color 0.12s;
}

.btn--filled {
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
}

.btn--filled:hover {
  background: var(--nys-color-theme-strong, #06393f);
}

.btn--outline {
  background: transparent;
  color: var(--nys-color-theme, #084b52);
  border-color: var(--nys-color-theme, #084b52);
}

.btn--outline:hover {
  background: var(--nys-color-theme-faint, #eef5f5);
}

.btn--accent {
  background: var(--app-accent);
  color: var(--app-ink);
  border-color: var(--app-accent);
}

.btn--accent:hover,
.btn--accent:focus,
a.btn--accent:hover,
a.btn--accent:focus {
  background: color-mix(in srgb, var(--app-accent), #000 10%);
  border-color: color-mix(in srgb, var(--app-accent), #000 10%);
  color: var(--app-ink);
}

.btn:disabled {
  opacity: 0.6;
  cursor: default;
}

/* ── Composer ────────────────────────────────────────────────────────────── */
.composer-wrap {
  position: sticky;
  bottom: 0;
  background: linear-gradient(to top,
      var(--app-surface-muted) 70%,
      transparent);
  padding: 0.9rem 0 1rem;
  margin-top: var(--app-space-100);
}

#chat-form {
  display: flex;
  gap: 0.6rem;
  align-items: stretch;
}

#user-input {
  flex: 1;
  font-family: inherit;
  font-size: 1rem;
  padding: 0.65rem 0.85rem;
  border: 1px solid var(--app-base);
  border-radius: var(--app-radius-md);
  background: var(--app-surface);
  color: var(--app-ink);
}

#user-input:disabled {
  background: var(--app-base-weak);
  color: var(--app-text-weak);
}

#user-input:focus-visible {
  border-color: var(--nys-color-theme, #084b52);
  outline-offset: 0;
}

.chat-disclaimer {
  font-size: 0.74rem;
  margin: 0.5rem 0 0;
  text-align: center;
}

/* ── Footer (reverse) ────────────────────────────────────────────────────── */
.site-footer {
  background: var(--app-surface-reverse);
  color: var(--app-text-reverse);
  margin-top: 1.25rem;
  padding: 1.6rem 1.25rem 1.4rem;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 1.5rem;
  margin-left: auto;
}

.footer-links a {
  color: var(--app-link-reverse);
  font-size: 0.85rem;
  text-decoration: underline;
}

/* ── Opportunities list and ranked results ───────────────────────────────── */
.opportunities-page {
  width: 100%;
}


.rank-progress {
  padding: 1rem 1.15rem;
  margin-bottom: 1.25rem;
  /* collapse support */
  overflow: hidden;
  max-height: 32rem;
  transition: max-height .5s ease, opacity .4s ease,
    margin .5s ease, padding .5s ease, border-width .5s ease;
}

.rank-progress.is-collapsed {
  max-height: 0;
  opacity: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-width: 0;
}

.rank-progress__head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.rank-progress__title {
  flex: 1;
  font-weight: 700;
  color: var(--app-ink, #1b1b1b);
  cursor: progress;
}

.rank-progress__pct {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  /* keeps the % from jittering as it changes */
  color: var(--nys-color-theme, #084b52);
}

/* running: spinner */
.rank-progress__spinner {
  flex: none;
  width: 18px;
  height: 18px;
  border: 2px solid var(--nys-color-theme-weak, #a8cccd);
  border-top-color: var(--nys-color-theme, #084b52);
  border-radius: 50%;
  animation: rank-spin 0.8s linear infinite;
  cursor: progress;
}

@keyframes rank-spin {
  to {
    transform: rotate(360deg);
  }
}

/* done: check */
.rank-progress__check {
  flex: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--nys-color-theme, #084b52);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rank-progress__check svg {
  width: 11px;
  height: 11px;
}

/* bar */
.rank-progress__track {
  margin-top: 0.85rem;
  height: 8px;
  background: var(--app-base-weak, #e4e8ea);
  border-radius: 999px;
  overflow: hidden;
  cursor: progress;
}

.rank-progress__fill {
  height: 100%;
  background: var(--nys-color-theme, #084b52);
  border-radius: 999px;
  transition: width 0.4s ease;
}

/* the 0% moment: a sweep so it never looks stuck before the first batch lands */
.rank-progress__fill--indeterminate {
  width: 35%;
  animation: rank-indeterminate 1.5s ease-in-out infinite;
  background: var(--nys-color-business-teal-300);
}

@keyframes rank-indeterminate {
  0% {
    transform: translateX(-120%);
  }

  100% {
    transform: translateX(330%);
  }
}

.rank-progress__sub {
  margin: 0.55rem 0 0;
}

@media (prefers-reduced-motion: reduce) {

  .rank-progress__spinner,
  .rank-progress__fill--indeterminate {
    animation: none;
  }

  .rank-progress {
    transition: none;
  }
}

.unranked-opportunities.is-revealed {
  animation: unranked-fade 0.4s ease;
}

@keyframes unranked-fade {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .unranked-opportunities.is-revealed {
    animation: none;
  }
}

.results-bar {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--app-space-100);
  flex-wrap: wrap;
  margin-bottom: 0.9rem;
}

.results-bar .count {
  font-size: 1rem;
  font-weight: 400;
  color: var(--app-text-weak);
}

.results-bar .count span {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--app-ink);
}

.table-wrap {
  overflow-x: auto;
}

.opportunities-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  background: var(--app-surface);
}

.opportunities-table thead th {
  background: var(--nys-color-theme);
  color: var(--app-text-on-theme);
  font-weight: 700;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-align: left;
  padding: 0.8rem 1rem;
  white-space: nowrap;
}

.opportunities-table th.num,
.opportunities-table td.num {
  text-align: right;
}

.opportunities-table td.num {
  font-variant-numeric: tabular-nums;
}

.opportunities-table tbody tr {
  border-top: 1px solid var(--app-base-weak);
}

.opportunities-table tbody tr:nth-child(even) {
  background: var(--app-row-stripe);
}

.opportunities-table tbody tr:hover {
  background: var(--nys-color-theme-faint);
}

.opportunities-table td {
  padding: 0.75rem 1rem;
  vertical-align: top;
  font-size: 0.94rem;
}

.job-link {
  color: var(--nys-color-theme);
  font-weight: 700;
  text-decoration: none;
}

.job-link:hover {
  text-decoration: underline;
}

.org-name {
  font-size: 0.8rem;
  margin-top: 0.1rem;
}

.opportunities-table td.date {
  white-space: nowrap;
}

.empty-state {
  padding: 2rem;
  text-align: center;
  color: var(--app-text-weak);
}

.section-heading {
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--app-text-weak);
  margin: 0 0 0.75rem;
}

/* ── Ranked opportunity cards ────────────────────────────────────────────── */

.interests-banner {
  background: var(--nys-color-theme-faint);
  border: 1px solid var(--nys-color-theme-weaker);
  border-radius: var(--app-radius-md);
  padding: 0.8rem 1rem;
  margin-bottom: 1.25rem;
  font-size: 0.95rem;
  color: var(--app-ink);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
}

.interests-banner__lead {
  font-weight: 700;
  margin-right: 0.2rem;
}

.interests-banner__link {
  margin-left: auto;
  font-weight: 700;
}

.match-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2.5rem;
}

.match-card:hover {
  box-shadow: var(--app-shadow-md);
}

.match-card__inner {
  border-radius: calc(var(--app-radius-md) - 1px);
  background: var(--app-surface);
  border-left: 4px solid var(--app-base);
  padding: 1rem 1.15rem;
  transition:
    box-shadow 0.12s,
    transform 0.12s;
}

.match-card--strong .match-card__inner {
  border-left-color: var(--nys-color-success);
}

.match-card--moderate .match-card__inner {
  border-left-color: var(--nys-color-yellow-600);
}

.match-card--weak .match-card__inner {
  border-left-color: var(--nys-color-black-transparent-300);
}

.match-card__top {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-bottom: 0.15rem;
}

.match-card__title {
  font-size: 1.08rem;
}

.match-card__meta {
  margin: 0.05rem 0 0.6rem;
}

.match-card .chip .chip--label {
  font-weight: 800;
  margin-top: 1px;
}

.match-card__why {
  background: var(--nys-color-black-transparent-50);
  border: 1px solid var(--nys-color-black-transparent-100);
  border-radius: var(--app-radius-md);
  padding: 0.6rem 0.75rem;
}

.match-card__why p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--app-ink);
}

.match-card__why-label {
  display: block;
  margin-bottom: 0.1rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--nys-color-theme-stronger);
}

@media (max-width: 640px) {
  .interests-banner__link {
    width: 100%;
    margin-left: 0;
    margin-top: var(--nys-space-100);
  }

  .match-card__inner {
    padding: 0.95rem 1rem;
  }

  .match-card__why {
    padding: 0.6rem;
  }
}

/* ── Opportunity detail service page ────────────────────────────────────────
   Appended after the opportunities/ranked styles in app.css.
   The template extends base.html and replaces the generic title band with a
   custom crumb + hero, then uses the shared base header/footer/container.
   ------------------------------------------------------------------------- */

/* The service-page design is white, while the chat/results pages use the
   muted background. :has() lets us switch only the detail page without adding
   a body-class block to base.html. */
body:has(.opportunity-detail-page) {
  background: var(--app-surface);
}

#main-content:has(.opportunity-detail-page) {
  margin-top: 2rem;
}

.detail-crumb {
  background: var(--app-surface);
  padding: 0.85rem 0;
  font-size: 0.9rem;
}

.detail-crumb a {
  font-weight: 700;
}

.detail-hero {
  background: var(--nys-color-theme, #084b52);
  color: var(--app-text-on-theme);
  padding: 1.75rem 0 2rem;
}

.detail-hero h1 {
  margin: 0;
  font-size: clamp(1.7rem, 3vw, 2.1rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0.01em;
  color: var(--app-text-on-theme);
}

.detail-hero__org {
  margin: 0.4rem 0 0;
  font-size: 1.1rem;
  color: var(--app-text-on-theme);
}

.detail-hero__meta {
  margin: 0.55rem 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.5rem;
  color: var(--nys-color-theme-weaker, #d7e8e9);
  font-size: 0.95rem;
}

.detail-hero__meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.detail-hero__meta svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
}

.opportunity-detail-page {
  width: 100%;
}

.opportunity-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 210px;
  gap: 2.5rem;
  align-items: start;
}

.on-this-page {
  position: sticky;
  top: 1rem;
}

.on-this-page p {
  margin: 0 0 0.6rem;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--app-text-weak);
}

.on-this-page ul {
  list-style: none;
  margin: 0;
  padding: 0;
}


.on-this-page li {
  margin-bottom: 0;
}


.on-this-page li a {
  display: block;
  padding: 0.4rem 0 0.4rem 0.85rem;
  border-left: 2px solid var(--app-base-weak);
  color: var(--app-ink);
  font-size: 0.92rem;
  text-decoration: none;
}

.on-this-page li a:hover,
.on-this-page li a:focus {
  border-left-color: var(--nys-color-theme, #084b52);
  color: var(--nys-color-theme, #084b52);
}

.on-this-page li a.active {
  border-left-color: var(--nys-color-theme, #084b52);
  color: var(--nys-color-theme-stronger, #042a2e);
  font-weight: 700;
}

.detail-content {
  max-width: 680px;
}

.detail-section {
  padding-bottom: 1.75rem;
  margin-bottom: 1.75rem;
  border-bottom: 1px solid var(--app-base-weak);
  scroll-margin-top: 30px;
}

.detail-section:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.detail-section p {
  margin: 0;
  color: var(--app-ink);
}

.detail-section__heading {
  margin: 0 0 0.9rem;
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.25;
  color: var(--nys-color-theme, #084b52);
}

.detail-match__inner {
  border-radius: calc(var(--app-radius-md) - 1px);
  border-left: 4px solid var(--app-base);
  padding: 1.1rem 1.25rem;
  transition:
    box-shadow 0.12s,
    transform 0.12s;
}

.detail-match--strong .detail-match__inner {
  border-left-color: var(--nys-color-success);
}

.detail-match--moderate .detail-match__inner {
  border-left-color: var(--nys-color-yellow-600);
}

.detail-match--weak .detail-match__inner {
  border-left-color: var(--nys-color-black-transparent-300);
}

.detail-match__body {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.detail-match__body p {
  margin: 0;
  font-size: 0.97rem;
}

.detail-facts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}

.detail-fact {
  padding: 0.85rem 1rem;
}

.detail-fact dt {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--app-text-weak);
}

.detail-fact dd {
  margin: 0.25rem 0 0;
  font-size: 1.05rem;
  font-weight: 700;
}

.detail-subheading {
  margin: 1.25rem 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.25;
  color: var(--app-ink);
}

.detail-subheading:first-of-type {
  margin-top: 0;
}

.detail-wage {
  font-size: 1.7rem;
  font-weight: 800;
  line-height: 1.2;
  color: var(--nys-color-theme, #084b52);
}

.detail-clean-list {
  margin: 0.25rem 0 0;
  padding-left: 0;
}

.detail-clean-list li {
  margin: 0.35rem 0;
}

.detail-contact-row {
  margin: 1rem 0 0;
  background: var(--app-surface, #fff);
  border: 1px solid var(--nys-color-black-transparent-300);
  border-radius: var(--app-radius-md, 6px);
  overflow: hidden;
}

.detail-contact-item {
  padding: 0.65rem .9rem;
  border-top: 1px solid var(--app-base-weak, #e4e8ea);
}

.detail-contact-item:first-of-type {
  padding-top: .9rem;
}

.detail-contact-item:last-of-type {
  padding-bottom: .9rem;
}

.detail-contact-item:first-child {
  border-top: none;
}

.detail-contact-item dt {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--app-text-weak);
  margin-bottom: 0.15rem;
  line-height: 1;
}

.detail-contact-item dd {
  margin: 0;
  font-weight: 700;
}

.detail-contact-item dd a {
  font-weight: 700;
}

@media (max-width: 820px) {
  .opportunity-detail-layout {
    grid-template-columns: 1fr;
  }

  .on-this-page {
    display: none;
  }

  .detail-content {
    max-width: none;
  }

  .detail-clean-list {
    padding-left: 15px;
  }
}

@media (max-width: 520px) {
  .detail-facts {
    grid-template-columns: 1fr;
  }

  .detail-match__body {
    flex-direction: column;
  }
}