.announcement-bar {
  background: var(--ink);
  color: var(--paper);
  font-size: var(--fs-14);
  text-align: center;
  padding: var(--sp-2) var(--sp-4);
  letter-spacing: 0.01em;
}
.announcement-bar a {
  color: var(--paper);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
}
.announcement-bar a:hover { color: var(--sapphire-light); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: var(--sp-5);
  position: relative;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  color: var(--ink);
  font-weight: 800;
  font-size: var(--fs-18);
  letter-spacing: -0.01em;
}
.brand:hover { text-decoration: none; color: var(--ink); }
.brand__mark { width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center; line-height: 0; flex-shrink: 0; }
.brand__mark img, .brand__mark svg { display: block; width: 100%; height: 100%; }

.nav { display: flex; gap: var(--sp-5); align-items: center; }
.nav a { color: var(--ink-2); font-weight: 500; font-size: var(--fs-14); }
.nav a:hover { color: var(--sapphire); text-decoration: none; }
.nav__cta { margin-left: var(--sp-2); }

.nav-toggle { display: none; background: none; border: 0; padding: var(--sp-2); cursor: pointer; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--ink); margin: 4px 0; transition: transform 0.15s ease; }

@media (max-width: 860px) {
  .nav {
    display: none;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    background: var(--paper);
    flex-direction: column;
    align-items: stretch;
    padding: var(--sp-4);
    border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow);
  }
  .nav.is-open { display: flex; }
  .nav a { padding: var(--sp-3) 0; border-bottom: 1px solid var(--paper-3); }
  .nav__cta { margin-left: 0; }
  .nav-toggle { display: block; }
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--radius);
  font-weight: 600;
  font-size: var(--fs-14);
  line-height: 1;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.05s ease, box-shadow 0.15s ease;
  white-space: nowrap;
  text-decoration: none;
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--sapphire); color: var(--paper); }
.btn--primary:hover { background: var(--sapphire-dark); color: var(--paper); text-decoration: none; box-shadow: var(--shadow); }
.btn--secondary { background: var(--paper); color: var(--ink); border-color: var(--line-strong); }
.btn--secondary:hover { border-color: var(--ink); color: var(--ink); text-decoration: none; }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { color: var(--sapphire); text-decoration: none; }
.btn--lg { padding: var(--sp-4) var(--sp-6); font-size: var(--fs-16); }
.btn--sm { padding: var(--sp-2) var(--sp-4); font-size: var(--fs-12); }
.btn--block { display: flex; width: 100%; }

.card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}
.card:hover { box-shadow: var(--shadow); border-color: var(--line-strong); }
.card__title { font-size: var(--fs-20); margin-bottom: var(--sp-3); }
.card__body { color: var(--slate); font-size: var(--fs-16); }
.card--feature { border-color: var(--sapphire); box-shadow: 0 0 0 1px var(--sapphire), var(--shadow); }

.grid { display: grid; gap: var(--sp-5); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 960px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

.field { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-4); }
.field label { font-size: var(--fs-14); font-weight: 600; color: var(--ink-2); }
.field input, .field textarea, .field select {
  font-family: inherit;
  font-size: var(--fs-16);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  background: var(--paper);
  color: var(--ink);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  width: 100%;
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none;
  border-color: var(--sapphire);
  box-shadow: 0 0 0 3px rgba(31, 128, 255, 0.15);
}
.field__help { font-size: var(--fs-12); color: var(--slate-2); }
.field__error { font-size: var(--fs-12); color: var(--danger); }

.site-footer {
  background: var(--ink);
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: var(--sp-7) 0 var(--sp-5);
  margin-top: var(--sp-9);
  color: rgba(255,255,255,0.7);
  font-size: var(--fs-14);
}
.site-footer__cols { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--sp-6); margin-bottom: var(--sp-5); }
.site-footer h5 { font-size: var(--fs-12); color: rgba(255,255,255,0.55); margin-bottom: var(--sp-3); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.site-footer a { color: rgba(255,255,255,0.8); display: block; padding: var(--sp-1) 0; transition: color 0.15s ease; }
.site-footer a:hover { color: var(--paper); text-decoration: none; }
.site-footer .brand { color: var(--paper); display: inline-flex; align-items: center; gap: var(--sp-3); }
.site-footer .brand:hover { color: var(--paper); }
.site-footer .brand .brand__deal { color: var(--paper); }
/* .brand__vital stays sapphire on dark backgrounds (defined globally below) */

.brand__wordmark { display: inline-flex; }
.brand__deal { color: var(--ink); }
.brand__vital { color: var(--sapphire); }

.site-footer__brand { max-width: 420px; }
.site-footer__tagline {
  color: rgba(255,255,255,0.7);
  font-size: var(--fs-14);
  line-height: 1.6;
  margin-top: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.site-footer__copyright {
  color: rgba(255,255,255,0.5);
  font-size: var(--fs-12);
  margin: 0 0 var(--sp-1);
  line-height: 1.5;
}
.site-footer__venture {
  color: rgba(255,255,255,0.6);
  font-size: var(--fs-12);
  font-weight: 600;
  margin: 0;
  line-height: 1.5;
  letter-spacing: 0.01em;
}

.site-footer__disclaimer {
  margin: 0 auto;
  padding-top: var(--sp-4);
  max-width: 920px;
  border-top: 1px solid rgba(255,255,255,0.06);
  font-size: 0.6875rem;
  font-style: italic;
  font-weight: 400;
  color: rgba(255,255,255,0.4);
  line-height: 1.5;
  text-align: center;
}

@media (max-width: 860px) {
  .site-footer__cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .site-footer__cols { grid-template-columns: 1fr; }
}

.stack > * + * { margin-top: var(--sp-4); }
.stack-lg > * + * { margin-top: var(--sp-6); }
.row { display: flex; gap: var(--sp-4); align-items: center; flex-wrap: wrap; }
.row--center { justify-content: center; }
.spacer { flex: 1; }
.badge {
  display: inline-block;
  padding: 2px var(--sp-3);
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
  font-weight: 600;
  background: var(--paper-3);
  color: var(--ink-2);
}
.badge--accent { background: var(--sapphire-tint); color: var(--sapphire-dark); }
.badge--success { background: rgba(22, 163, 74, 0.12); color: var(--success); }

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

.site-footer__venture a { display: inline; color: var(--sapphire-light); padding: 0; }
.site-footer__venture a:hover { color: var(--paper); text-decoration: underline; }

/* ---------------------------------------------------------------------
   Auth + dashboard (v9 Pass 1)
   --------------------------------------------------------------------- */
.alert { padding: var(--sp-4); border-radius: var(--radius-md); margin-bottom: var(--sp-5); font-size: var(--fs-14); line-height: 1.55; }
.alert a { font-weight: 600; }
.alert--error { background: rgba(220, 38, 38, 0.08); color: #991b1b; border: 1px solid rgba(220, 38, 38, 0.25); }
.alert--info  { background: var(--sapphire-tint); color: var(--sapphire-dark); border: 1px solid rgba(31,128,255,0.25); }

.checkbox { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-14); color: var(--ink-2); cursor: pointer; }
.checkbox input { width: 16px; height: 16px; margin: 0; }

.field--inline { flex-direction: row; align-items: center; justify-content: space-between; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.field__optional { font-weight: 400; color: var(--slate-2); font-size: var(--fs-12); margin-left: var(--sp-2); }

.auth-form { max-width: 440px; margin: 0 auto; }
.auth-form button[type="submit"] { margin-top: var(--sp-3); }
.auth-alt { text-align: center; color: var(--slate); font-size: var(--fs-14); margin-top: var(--sp-4); }
.auth-forgot { font-size: var(--fs-14); color: var(--sapphire); }
.auth-fineprint { font-size: var(--fs-12); color: var(--slate-2); line-height: 1.5; }

.auth-success { text-align: center; max-width: 480px; margin: 0 auto; padding: var(--sp-6) var(--sp-4); }
.auth-success__check { display: flex; justify-content: center; margin-bottom: var(--sp-4); }
.auth-success h2 { margin-bottom: var(--sp-3); }
.auth-success p { color: var(--slate); }

.dashboard-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--sp-5); margin-top: var(--sp-5); }
.dashboard-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--sp-5); position: relative; }
.dashboard-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--sapphire-dark), var(--sapphire));
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.dashboard-card__title { font-size: var(--fs-18); margin-bottom: var(--sp-4); }
.dashboard-card__empty { color: var(--slate); font-size: var(--fs-14); margin-bottom: var(--sp-4); }
.dashboard-card__cta-row { display: flex; gap: var(--sp-3); flex-wrap: wrap; margin-top: var(--sp-4); }
.dashboard-meta { display: grid; grid-template-columns: auto 1fr; gap: var(--sp-2) var(--sp-4); font-size: var(--fs-14); margin: 0 0 var(--sp-4); }
.dashboard-meta dt { color: var(--slate-2); font-weight: 500; }
.dashboard-meta dd { color: var(--ink-2); margin: 0; word-break: break-word; }

/* ---------------------------------------------------------------------
   Intake wizard (v9 Pass 4)
   --------------------------------------------------------------------- */
.intake-progress { margin: var(--sp-3) 0 var(--sp-5); }
.intake-progress__bar { height: 6px; background: var(--paper-3); border-radius: var(--radius-pill); overflow: hidden; }
.intake-progress__fill { height: 100%; background: linear-gradient(90deg, var(--sapphire-dark), var(--sapphire)); transition: width 0.3s ease; }
.intake-progress__labels { display: flex; justify-content: space-between; gap: var(--sp-3); margin-top: var(--sp-2); font-size: var(--fs-12); color: var(--slate-2); }

.intake-form .field--invalid input,
.intake-form .field--invalid select,
.intake-form .field--invalid textarea { border-color: var(--danger); }

.intake-nav { display: flex; align-items: center; gap: var(--sp-3); margin-top: var(--sp-6); padding-top: var(--sp-5); border-top: 1px solid var(--line); }
.intake-nav .spacer { flex: 1; }

.checkbox-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-3) var(--sp-4); padding: var(--sp-3) 0; }
.checkbox-grid .checkbox { padding: var(--sp-2) var(--sp-3); border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper); transition: border-color 0.15s ease, background 0.15s ease; }
.checkbox-grid .checkbox:hover { border-color: var(--line-strong); }
.checkbox-grid .checkbox:has(input:checked) { border-color: var(--sapphire); background: var(--sapphire-tint); }

/* Dashboard list rows (v9 Pass 4) */
.dashboard-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-4); }
.dashboard-list__item { padding: var(--sp-4); border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper-2, var(--paper)); }
.dashboard-list__head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); margin-bottom: var(--sp-2); }
.dashboard-list__title { font-weight: 600; color: var(--ink); }
.dashboard-list__meta { font-size: var(--fs-12); color: var(--slate-2); margin-bottom: var(--sp-2); }
.dashboard-list__body { font-size: var(--fs-14); color: var(--slate); margin-bottom: var(--sp-3); }
