:root {
  /* Light theme — white surfaces, navy text, royal-blue + gold accents */
  --navy-deep: #f3f6fb;   /* input backgrounds */
  --navy:      #ffffff;   /* page surface */
  --navy-2:    #ffffff;   /* card surface */
  --navy-3:    #eaf1fb;   /* subtle accent fill */
  --royal:      #2a6ad6;
  --royal-2:    #3a82ee;
  --royal-glow: #1f5dc4;  /* link color — readable on white */
  --gold:        #b6892a; /* darker gold for text on white */
  --gold-bright: #d6a948;
  --gold-soft:   rgba(214, 169, 72, 0.18);
  --silver: #d6dfee;
  --ink:       #0e2440;   /* primary text */
  --ink-soft:  #2a3b57;
  --ink-muted: #5a6b85;
  --line:       #d8e0ec;
  --line-gold:  rgba(214, 169, 72, 0.55);
  --warn:   #c2841d;
  --danger: #c0382f;
  --radius: 14px;
  --radius-lg: 20px;

  /* Dark surfaces kept for splash + intro pages where dark is required */
  --dark-surface: #0e2440;
  --dark-surface-2: #143055;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background:
    radial-gradient(1300px 700px at 18% -10%, rgba(58, 130, 238, 0.10), transparent 60%),
    radial-gradient(1000px 600px at 110% 8%, rgba(214, 169, 72, 0.08), transparent 60%),
    radial-gradient(900px 700px at 50% 110%, rgba(42, 106, 214, 0.06), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f5f8fc 50%, #ffffff 100%);
  background-attachment: fixed;
  color: var(--ink);
  font: 16px/1.55 "Inter", -apple-system, BlinkMacSystemFont,
    "SF Pro Text", "Segoe UI", Roboto, sans-serif;
  letter-spacing: 0.005em;
  min-height: 100vh;
}

h1, h2, h3, h4, .ss-display {
  font-family: "Playfair Display", "Times New Roman", Georgia, serif;
  letter-spacing: 0.005em;
}

a { color: var(--royal-glow); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ====== Splash / vault curtain reveal ====== */
.ss-splash {
  position: fixed; inset: 0; z-index: 1000;
  overflow: hidden;
  pointer-events: auto;
}
.ss-splash[hidden] { display: none !important; }

.ss-splash-half {
  position: absolute; top: 0; bottom: 0; width: 50%;
  overflow: hidden;
  background:
    radial-gradient(900px 700px at 50% 45%, rgba(74, 144, 217, 0.45), transparent 65%),
    radial-gradient(700px 500px at 50% 55%, rgba(224, 189, 94, 0.18), transparent 70%),
    linear-gradient(180deg, #1a3a66 0%, #143055 55%, #0e2440 100%);
  transition: transform 1.4s cubic-bezier(.72, .04, .25, 1);
  z-index: 1;
}
.ss-splash-half.left  { left: 0;
  box-shadow: inset -1px 0 0 var(--gold),
              inset -8px 0 24px rgba(224,189,94,0.18);
}
.ss-splash-half.right { left: 50%;
  box-shadow: inset 1px 0 0 var(--gold),
              inset 8px 0 24px rgba(224,189,94,0.18);
}

.ss-splash-content {
  position: absolute; top: 50%;
  width: 100vw; transform: translateY(-50%);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 18px; padding: 24px; text-align: center;
}
.ss-splash-half.left  .ss-splash-content { left: 0; }
.ss-splash-half.right .ss-splash-content { left: -50vw; }

.ss-splash-logo {
  max-width: min(72vw, 420px);
  width: 100%; height: auto;
  filter: drop-shadow(0 14px 38px rgba(0,0,0,0.45))
          drop-shadow(0 0 24px rgba(106,169,238,0.35));
}
.ss-splash-brand {
  font-family: "Playfair Display", "Times New Roman", serif;
  font-size: clamp(1.4rem, 3.2vw, 2.0rem);
  font-weight: 700; color: #ffffff;
  letter-spacing: 0.01em;
  text-shadow: 0 2px 14px rgba(0,0,0,0.4);
}
.ss-splash-tag {
  font-family: "Inter", sans-serif;
  font-size: 0.82rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold-bright);
  text-shadow: 0 1px 6px rgba(0,0,0,0.4);
}

.ss-splash.is-opening .ss-splash-half.left  { transform: translateX(-100%); }
.ss-splash.is-opening .ss-splash-half.right { transform: translateX(100%); }

.ss-splash-controls {
  position: absolute; left: 0; right: 0; bottom: 8%;
  z-index: 5;
  display: flex; align-items: center; justify-content: center;
  gap: 20px; padding: 0 16px;
  pointer-events: none;
}
.ss-splash-controls > * { pointer-events: auto; }
.ss-splash.is-opening .ss-splash-controls { opacity: 0; transition: opacity .4s ease; }

.ss-splash-enter {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 13px 38px;
  border-radius: 999px;
  border: 1px solid var(--gold);
  background: linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%);
  color: #2a1d04;
  font-family: "Inter", sans-serif;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-size: 0.84rem;
  cursor: pointer;
  box-shadow: 0 8px 28px rgba(224,189,94,0.45),
              inset 0 1px 0 rgba(255,255,255,0.45);
  animation: ss-glow 2.4s ease-in-out infinite;
}
.ss-splash-enter:hover {
  background: linear-gradient(180deg, #ffe08a 0%, var(--gold-bright) 100%);
}
@keyframes ss-glow {
  0%, 100% { box-shadow: 0 8px 24px rgba(224,189,94,0.35), inset 0 1px 0 rgba(255,255,255,0.45); }
  50%      { box-shadow: 0 12px 36px rgba(224,189,94,0.65), inset 0 1px 0 rgba(255,255,255,0.55); }
}

.ss-splash-skip {
  background: transparent; border: 0;
  color: rgba(255,255,255,0.85); font: inherit;
  font-family: "Inter", sans-serif;
  font-size: 0.78rem; letter-spacing: 0.22em;
  text-transform: uppercase; cursor: pointer;
  padding: 8px 14px;
}
.ss-splash-skip:hover { color: var(--gold-bright); }

@media (prefers-reduced-motion: reduce) {
  .ss-splash-half { transition: none !important; }
  .ss-splash-enter { animation: none !important; }
}

/* ====== Sticky jurisdiction band ====== */
.ss-jurisdiction-banner {
  position: sticky; top: 0; z-index: 30;
  background: rgba(7, 17, 29, 0.92);
  border-bottom: 1px solid var(--line-gold);
  padding: 6px 14px;
  font-size: 0.74rem;
  color: var(--ink-muted);
  backdrop-filter: blur(8px);
}
.ss-jurisdiction-banner summary { cursor: pointer; list-style: none; }
.ss-jurisdiction-banner summary::-webkit-details-marker { display: none; }
.ss-jurisdiction-banner > div {
  margin-top: 8px; padding-top: 8px;
  border-top: 1px dashed var(--line);
  color: var(--ink);
}

/* ====== Header ====== */
.ss-header {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 18px 22px 16px;
  border-bottom: 1px solid var(--line);
  gap: 14px;
  background: linear-gradient(180deg, rgba(7,17,29,0.7), rgba(7,17,29,0.0));
  text-align: center;
}
@media (min-width: 720px) {
  .ss-header {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}
.ss-brand {
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  color: var(--ink); text-align: center;
}
@media (min-width: 720px) {
  .ss-brand { flex-direction: row; gap: 12px; text-align: left; }
}
.ss-brand-mark {
  width: 42px; height: 42px; border-radius: 10px;
  background: linear-gradient(160deg, var(--royal-2), var(--royal));
  border: 1px solid var(--gold);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; letter-spacing: 0.06em;
  color: var(--gold-bright);
  box-shadow: 0 6px 18px rgba(27,78,166,0.45),
              inset 0 1px 0 rgba(255,255,255,0.15);
}
.ss-brand-text strong {
  display: block; font-size: 1.35rem; font-weight: 800;
  font-family: "Playfair Display", serif;
  color: var(--ink);
  line-height: 1.15;
}
.ss-brand-text em {
  font-style: normal; font-size: 0.78rem;
  color: var(--gold); letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 700;
}
.ss-nav {
  display: flex; flex-wrap: wrap; gap: 14px;
  align-items: center; justify-content: center;
  font-size: 1.18rem; font-weight: 800;
  width: 100%;
}
.ss-nav a { color: var(--ink-soft); }
.ss-nav a:hover { color: var(--gold); text-decoration: none; }
.ss-pill {
  padding: 14px 30px; border: 1px solid var(--line);
  border-radius: 999px; color: var(--ink) !important;
  font-size: 1.18rem; font-weight: 800;
  letter-spacing: .03em;
}
.ss-pill-cta {
  background: linear-gradient(180deg, var(--gold-bright), var(--gold));
  color: #2a1d04 !important;
  border-color: var(--gold);
  font-weight: 800;
  box-shadow: 0 4px 14px rgba(216,179,90,0.35);
}

/* ====== Main / Hero ====== */
.ss-main {
  max-width: 880px; margin: 0 auto;
  padding: 28px 18px 60px;
}

.ss-hero-card {
  position: relative;
  margin: 6px 0 8px;
  padding: 36px 30px 32px;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(150deg, rgba(27,78,166,0.18) 0%, rgba(7,17,29,0.0) 60%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(216,179,90,0.28);
  box-shadow:
    0 20px 60px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.06),
    0 0 0 1px rgba(255,255,255,0.02);
  overflow: hidden;
}
.ss-hero-card::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.7;
}
.ss-hero-card::after {
  content: ""; position: absolute; right: -120px; top: -120px;
  width: 320px; height: 320px; border-radius: 50%;
  background: radial-gradient(circle, rgba(74,144,217,0.25), transparent 70%);
  pointer-events: none;
}

.ss-eyebrow-gold {
  display: inline-block;
  font-family: "Inter", sans-serif;
  font-size: 0.74rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.ss-h1 {
  font-family: "Playfair Display", serif;
  font-size: clamp(2.2rem, 6vw, 3.4rem);
  margin: 0 0 14px; line-height: 1.05;
  font-weight: 700;
}
.ss-h1-white { color: var(--ink); }
.ss-h1-year {
  background: linear-gradient(180deg, var(--gold-bright), var(--gold));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  font-style: italic;
}
.ss-sub {
  color: var(--ink-soft); margin: 8px 0;
  font-size: 1.02rem;
}
.ss-sub-lead {
  color: var(--ink);
  font-size: clamp(1.1rem, 2.4vw, 1.32rem);
  font-weight: 500;
  line-height: 1.4;
  margin: 4px 0 12px;
  max-width: 60ch;
}

.ss-cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; align-items: center; }

.ss-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 13px 22px; border-radius: 12px;
  border: 1px solid transparent; cursor: pointer;
  font: inherit; font-weight: 600; text-decoration: none;
  background: var(--navy-2); color: var(--ink);
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.ss-btn:hover { text-decoration: none; transform: translateY(-1px); }
.ss-btn-primary {
  background: linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%);
  color: #2a1d04;
  border-color: var(--gold);
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow:
    0 8px 24px rgba(216,179,90,0.35),
    inset 0 1px 0 rgba(255,255,255,0.4);
  animation: ss-cta-pulse 3s ease-in-out infinite;
}
.ss-btn-primary:hover {
  background: linear-gradient(180deg, #ffe08a 0%, var(--gold-bright) 100%);
  box-shadow: 0 10px 30px rgba(216,179,90,0.55), inset 0 1px 0 rgba(255,255,255,0.5);
}
@keyframes ss-cta-pulse {
  0%, 100% { box-shadow: 0 8px 24px rgba(216,179,90,0.30), inset 0 1px 0 rgba(255,255,255,0.4); }
  50%      { box-shadow: 0 12px 36px rgba(216,179,90,0.55), inset 0 1px 0 rgba(255,255,255,0.5); }
}
.ss-btn-secondary {
  background: linear-gradient(180deg, var(--royal-2), var(--royal));
  color: #fff; border-color: rgba(255,255,255,0.12);
  box-shadow: 0 6px 20px rgba(27,78,166,0.45);
}
.ss-btn-ghost { background: transparent; border-color: var(--line-gold); color: var(--gold); }
.ss-btn-link { background: transparent; color: var(--royal-glow); padding: 13px 8px; }
.ss-btn[disabled] { opacity: 0.5; cursor: not-allowed; }

/* ====== Cards / tiles ====== */
.ss-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px; margin: 18px 0;
  box-shadow: 0 12px 30px rgba(0,0,0,0.35);
}
.ss-card-eyebrow {
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 6px;
  font-weight: 600;
}
.ss-card-resume { border-color: var(--gold); }

.ss-grid-3 { display: grid; gap: 16px; grid-template-columns: 1fr; margin-top: 26px; }
.ss-grid-2 { display: grid; gap: 16px; grid-template-columns: 1fr; }
@media (min-width: 720px) {
  .ss-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .ss-grid-2 { grid-template-columns: repeat(2, 1fr); }
}
.ss-tile {
  display: block;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
  padding: 22px 20px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  color: var(--ink);
  transition: transform .14s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow: 0 10px 24px rgba(0,0,0,0.3);
}
.ss-tile:hover {
  border-color: var(--line-gold);
  transform: translateY(-2px);
  text-decoration: none;
  box-shadow: 0 14px 32px rgba(0,0,0,0.4), 0 0 0 1px rgba(216,179,90,0.18);
}
.ss-tile h3 {
  margin: 12px 0 6px;
  font-size: 1.08rem; font-weight: 700; color: var(--ink);
  font-family: "Playfair Display", serif;
}
.ss-tile p { color: var(--ink-muted); margin: 0; font-size: 0.92rem; }
.ss-tile-num {
  width: 34px; height: 34px; border-radius: 50%;
  background: linear-gradient(160deg, var(--royal-2), var(--royal));
  border: 1px solid var(--gold);
  color: var(--gold-bright);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 0.92rem;
  font-family: "Inter", sans-serif;
  box-shadow: 0 4px 12px rgba(27,78,166,0.35);
}

/* ====== Forms ====== */
.ss-form { display: flex; flex-direction: column; gap: 12px; }
.ss-form-inline { flex-direction: row; flex-wrap: wrap; align-items: end; }
.ss-form label { display: flex; flex-direction: column; gap: 4px; font-size: 0.86rem; color: var(--ink-muted); }
.ss-form input, .ss-form textarea, .ss-form select {
  background: var(--navy-deep); color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 10px; padding: 11px 13px; font: inherit;
}
.ss-form input:focus, .ss-form textarea:focus, .ss-form select:focus {
  outline: none; border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(216,179,90,0.15);
}
.ss-form textarea { resize: vertical; min-height: 80px; }

.ss-field { border: 1px solid var(--line); border-radius: 10px; padding: 12px; margin: 0; }
.ss-field legend { padding: 0 6px; color: var(--ink); font-weight: 600; }
.ss-radio, .ss-check { display: flex; align-items: center; gap: 8px; padding: 6px 0; color: var(--ink); }

.ss-progress { background: var(--navy-deep); border-radius: 999px; height: 8px; overflow: hidden; margin-bottom: 8px; border: 1px solid var(--line); }
.ss-progress-bar { background: linear-gradient(90deg, var(--royal-2), var(--gold)); height: 100%; transition: width .25s ease; }

.ss-stat-row { display: grid; gap: 12px; grid-template-columns: 1fr; margin: 14px 0; }
@media (min-width: 720px) { .ss-stat-row { grid-template-columns: repeat(3, 1fr); } }
.ss-stat { background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); padding: 14px; border-radius: 10px; border: 1px solid var(--line); }
.ss-stat-label { color: var(--gold); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; }
.ss-stat-value { font-size: 1.18rem; font-weight: 700; margin-top: 4px; color: var(--ink); }

.ss-list { padding-left: 18px; margin: 8px 0; }
.ss-list li { margin: 5px 0; }
.ss-list-num { list-style: decimal; }
.ss-list-check { list-style: none; padding-left: 0; }
.ss-list-x { list-style: none; padding-left: 0; color: var(--warn); }

.ss-timeline { padding-left: 18px; }
.ss-timeline li { padding: 4px 0; color: var(--ink); }

.ss-table { width: 100%; border-collapse: collapse; margin-top: 10px; font-size: 0.9rem; }
.ss-table th, .ss-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); vertical-align: top; }
.ss-table th { color: var(--gold); text-transform: uppercase; font-size: 0.72rem; letter-spacing: 0.10em; font-weight: 700; }

.ss-muted { color: var(--ink-muted); font-size: 0.9rem; }
.ss-eyebrow { color: var(--gold); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 6px; font-weight: 600; }
.ss-warn { background: rgba(240, 168, 48, 0.10); border-left: 3px solid var(--warn); padding: 10px 12px; border-radius: 6px; }
.ss-note { background: rgba(255,255,255,0.03); border: 1px dashed var(--line); padding: 10px 12px; border-radius: 8px; color: var(--ink-muted); }

.ss-flash { padding: 12px 14px; border-radius: 10px; margin-bottom: 16px; }
.ss-flash-success {
  background: linear-gradient(180deg, rgba(216,179,90,0.18), rgba(216,179,90,0.08));
  border: 1px solid var(--gold); color: var(--gold-bright);
}
.ss-flash-warn { background: rgba(240, 168, 48, 0.12); border: 1px solid var(--warn); }

.ss-paywall { background: linear-gradient(180deg, rgba(216,179,90,0.10), rgba(216,179,90,0.02)); border: 1px dashed var(--gold); padding: 16px; border-radius: 12px; }

.ss-pricing { background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 22px; box-shadow: 0 12px 30px rgba(0,0,0,0.35); }
.ss-pricing-feature { border-color: var(--gold); box-shadow: 0 12px 30px rgba(216,179,90,0.18); }
.ss-pricing-name { font-weight: 800; font-size: 1.18rem; font-family: "Playfair Display", serif; }
.ss-pricing-price {
  background: linear-gradient(180deg, var(--gold-bright), var(--gold));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  font-weight: 800; font-size: 1.5rem; margin: 6px 0 12px;
}

.ss-chat { display: flex; flex-direction: column; gap: 10px; margin: 14px 0; }
.ss-msg { background: rgba(255,255,255,0.04); border: 1px solid var(--line); border-radius: 12px; padding: 12px 14px; }
.ss-msg-user { border-color: var(--gold); }
.ss-msg-role { font-size: 0.7rem; color: var(--gold); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
.ss-msg-body { white-space: pre-wrap; }
.ss-next-step { margin-top: 6px; font-size: 0.78rem; color: var(--royal-glow); }

.ss-footer {
  border-top: 1px solid var(--line);
  padding: 24px 18px 40px; max-width: 880px;
  margin: 50px auto 0; color: var(--ink-muted); font-size: 0.78rem;
}
.ss-footer-disclaimer { margin-bottom: 8px; }

/* ====== Compliance card (calm, downsized) ====== */
.ss-compliance-card {
  margin: 2.4rem auto 1rem;
  max-width: 680px;
  padding: 14px 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(216, 179, 90, 0.22);
  border-left: 3px solid var(--gold);
  border-radius: 10px;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.55;
}
.ss-compliance-title {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}
.ss-compliance-body { margin: 0 0 8px; color: var(--ink-soft); }
.ss-compliance-list {
  margin: 0; padding: 0; list-style: none;
  display: flex; flex-wrap: wrap; gap: 6px 18px;
}
.ss-compliance-list li {
  position: relative; padding-left: 16px;
  font-size: 0.86rem; color: var(--ink-soft);
}
.ss-compliance-list li::before {
  content: ""; position: absolute; left: 0; top: 0.55em;
  width: 5px; height: 5px; border-radius: 50%; background: var(--gold);
}

/* Assistant mode tabs */
.ss-tabs {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 6px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 12px;
  margin: 12px 0 18px;
}
.ss-tab {
  flex: 1 1 auto; text-align: center;
  padding: 9px 14px; border-radius: 8px;
  color: var(--ink-soft); font-size: 0.88rem; font-weight: 600;
  letter-spacing: 0.04em;
  transition: background .15s ease, color .15s ease;
}
.ss-tab:hover { color: var(--gold); text-decoration: none; background: rgba(216,179,90,0.06); }
.ss-tab-active {
  background: linear-gradient(180deg, rgba(216,179,90,0.22), rgba(216,179,90,0.08));
  color: var(--gold-bright);
  box-shadow: inset 0 0 0 1px var(--gold);
}

/* iOS safe-area for sticky banner */
@supports (padding-top: env(safe-area-inset-top)) {
  .ss-jurisdiction-banner { padding-top: calc(6px + env(safe-area-inset-top)); }
}

/* Intro infographic pages (post-splash) */
.ss-intro-page{
  max-width: 820px;
  margin: 18px auto 32px;
  display: flex; flex-direction: column; align-items: center;
}
.ss-intro-img{
  width: 100%; height: auto; display: block;
  border-radius: 18px;
  box-shadow: 0 12px 40px rgba(0,0,0,.45),
              0 0 0 1px rgba(212,175,55,.18);
}
.ss-intro-actions{
  display: flex; gap: 18px; align-items: center;
  margin-top: 18px; flex-wrap: wrap; justify-content: center;
}
.ss-btn-link{
  color: #cdd7e4;
  text-decoration: none; font-size: .95rem;
  padding: 10px 6px;
}
.ss-btn-link:hover{ color: var(--gold, #d4af37); }

/* Progress timeline status states */
.ss-timeline { list-style: none; padding-left: 0; margin: 8px 0; }
.ss-timeline-item{
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 12px; border-radius: 10px;
  border: 1px solid rgba(255,255,255,.06);
  margin-bottom: 6px;
  background: rgba(255,255,255,.02);
}
.ss-timeline-label{ color: #e7ecf3; }
.ss-timeline-status{ font-size: .82rem; color: #cdd7e4; }
.ss-timeline-done .ss-timeline-label{ color: #cdd7e4; }
.ss-timeline-done .ss-timeline-status{ color: #6cd28a; }
.ss-timeline-current{
  background: rgba(212,175,55,.08);
  border-color: rgba(212,175,55,.45);
}
.ss-timeline-current .ss-timeline-label{
  color: #fff; font-weight: 600;
}
.ss-timeline-current .ss-timeline-status{ color: #d4af37; }
.ss-timeline-upcoming .ss-timeline-label{ color: #a7b3c4; }

/* Pricing / plan cards */
.ss-plan-card{
  display:flex; flex-direction:column; gap:10px;
  padding: 22px 20px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
}
.ss-plan-featured{
  border-color: rgba(212,175,55,.55);
  box-shadow: 0 0 0 1px rgba(212,175,55,.25), 0 14px 40px rgba(0,0,0,.35);
}
.ss-plan-name{ color:#fff; font-weight:700; letter-spacing:.02em; font-size:1.05rem;}
.ss-plan-price{ color:#fff; font-family: 'Playfair Display', Georgia, serif; }
.ss-plan-price span{ font-size: 2rem; font-weight: 700; }
.ss-plan-price small{ color:#cdd7e4; font-size: .9rem; margin-left: 4px; }
.ss-btn-disabled{ opacity:.6; pointer-events:none; }

/* Document/policy pages */
.ss-doc-card{ max-width: 760px; margin: 18px auto; }
.ss-doc-card h1{ margin-top: 6px; }
.ss-doc-card h2{ margin-top: 18px; color:#fff; }
.ss-doc-card a{ color: var(--gold, #d4af37); }

/* Roadmap */
.ss-roadmap-card{ position:relative; padding-top: 28px; }
.ss-roadmap-num{
  position:absolute; top:14px; right:18px;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.6rem; color: rgba(212,175,55,.7);
}

/* Homepage trust block */
.ss-trust-card{ max-width: 820px; margin: 18px auto; }
.ss-trust-title{ color:#fff; }
.ss-trust-list{ columns: 2; -webkit-columns: 2; }
@media (max-width: 540px){ .ss-trust-list{ columns: 1; -webkit-columns: 1; } }
.ss-trust-fineprint{ margin-top: 8px; font-size: .85rem; }

/* Footer */
.ss-footer-tools{
  display:flex; flex-wrap:wrap; gap:10px 18px;
  justify-content:center; margin: 4px 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.ss-footer-tools a{
  color:#E0B84B; text-decoration:none; font-size:.95rem;
  font-weight:600; letter-spacing:.01em;
}
.ss-footer-tools a:hover{ color:#fff; }
.ss-footer-links{
  display:flex; flex-wrap:wrap; gap:14px 22px;
  justify-content:center; margin-bottom: 12px;
}
.ss-footer-links a{ color:#cdd7e4; text-decoration:none; font-size:.92rem; }
.ss-footer-links a:hover{ color: var(--gold, #d4af37); }
.ss-footer a{ color: var(--gold, #d4af37); }
.ss-nav-cases{
  color:#cdd7e4; text-decoration:none;
  font-size: 1.18rem; font-weight: 800; letter-spacing: .03em;
  padding: 14px 30px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
}
.ss-nav-cases:hover{ color:#fff; background: rgba(255,255,255,0.06); }

/* Educational hero — emotional first impression after splash */
.ss-edu-hero{
  text-align:center;
  padding: 56px 20px 44px;
  margin: 8px auto 22px;
  max-width: 920px;
  background:
    radial-gradient(ellipse at top, rgba(74,144,217,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border: 1px solid rgba(212,175,55,.25);
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
}
.ss-edu-hero-title{
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2rem, 5vw, 3.4rem);
  line-height: 1.1;
  color: #fff;
  margin: 14px 0 18px;
  letter-spacing: -.01em;
}
.ss-h1-gold{ color: var(--gold, #d4af37); display:inline-block; }
.ss-edu-hero-lead{
  color:#dde6f1; font-size: 1.08rem; line-height:1.6;
  max-width: 720px; margin: 0 auto 22px;
}
.ss-cta-row-center{ justify-content:center; flex-wrap:wrap; }
.ss-btn-gold{
  background: var(--gold, #d4af37); color:#1a1a2e; border:none;
  font-weight:600;
}
.ss-btn-gold:hover{ filter: brightness(1.08); }

/* 5-step grind */
.ss-steps-card{ max-width: 920px; margin: 22px auto; padding: 28px; }
.ss-steps-title{
  font-family: 'Playfair Display', Georgia, serif;
  color:#fff; margin: 6px 0 18px; font-size: clamp(1.4rem, 3vw, 1.9rem);
}
.ss-steps-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px; }
.ss-step{
  display:grid; grid-template-columns: 56px 1fr; gap:16px;
  padding: 16px; border:1px solid rgba(255,255,255,.08);
  border-radius: 12px; background: rgba(255,255,255,.02);
}
.ss-step-num{
  width:48px; height:48px; border-radius:50%;
  background: linear-gradient(135deg, rgba(212,175,55,.25), rgba(74,144,217,.2));
  border:1px solid rgba(212,175,55,.5);
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display', Georgia, serif;
  font-size:1.4rem; color: var(--gold,#d4af37); font-weight:700;
}
.ss-step-body h3{ color:#fff; margin:0 0 6px; }
.ss-step-body p{ color:#cdd7e4; margin:0; line-height:1.55; }

/* What happens next */
.ss-next-card{ max-width: 820px; margin: 18px auto; }

/* Utilities (secondary nav block) */
.ss-utilities{ margin: 28px auto 12px; max-width: 1080px; }
.ss-utilities-eyebrow{
  text-transform: uppercase; letter-spacing:.18em;
  color:#9bb0c8; font-size:.78rem; margin-bottom:10px; padding-left:4px;
}

/* Intro fullscreen image experience (after splash, before app) */
.ss-main-intro{
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.ss-intro-fullscreen{
  min-height: 100vh;
  min-height: 100svh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 18px;
  padding: 16px 12px 28px;
  background: radial-gradient(ellipse at top, rgba(74,144,217,.15), transparent 65%), #0D1B2A;
  box-sizing: border-box;
}
.ss-intro-fullscreen-img{
  display: block;
  width: 100%;
  max-width: 720px;
  max-height: 78vh;
  height: auto;
  object-fit: contain;
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
}
.ss-intro-fullscreen-actions{
  display: flex; flex-direction: column; align-items: center;
  gap: 10px;
}
.ss-btn-lg{ padding: 14px 28px; font-size: 1.05rem; }
@media (max-width: 540px){
  .ss-intro-fullscreen{ padding: 10px 8px 22px; gap: 14px; }
  .ss-intro-fullscreen-img{ max-height: 72vh; border-radius: 10px; }
}

.ss-intro-fullscreen-sublinks{
  display: flex; align-items: center; gap: 10px;
  margin-top: 4px;
}
.ss-intro-divider{ color: #6e7d92; }

/* ============================================================
   LIGHT THEME OVERRIDES
   The original styles were designed for a dark navy background
   using rgba(255,255,255,*) fills. On a white page those become
   invisible, so we re-skin every card / tile / hero / form / etc.
   Splash and /intro pages keep their dark surfaces (the
   infographics need the dark backdrop).
   ============================================================ */

/* Cards & tiles get crisp white surfaces with a soft shadow */
.ss-hero-card,
.ss-card,
.ss-tile,
.ss-stat,
.ss-pricing,
.ss-plan-card,
.ss-edu-hero,
.ss-steps-card,
.ss-trust-card,
.ss-doc-card,
.ss-next-card,
.ss-compliance-card,
.ss-tabs,
.ss-msg,
.ss-step,
.ss-timeline-item,
.ss-note {
  background: #ffffff !important;
  border-color: var(--line) !important;
  box-shadow: 0 6px 18px rgba(14, 36, 64, 0.06),
              0 1px 2px rgba(14, 36, 64, 0.04) !important;
  color: var(--ink);
}

/* Hero card: keep gold top accent + a hint of blue, on white */
.ss-hero-card {
  background:
    linear-gradient(150deg, rgba(42,106,214,0.06) 0%, rgba(255,255,255,0) 60%),
    #ffffff !important;
  border: 1px solid var(--line-gold) !important;
}

/* Educational hero (homepage) */
.ss-edu-hero {
  background:
    radial-gradient(ellipse at top, rgba(42,106,214,0.08), transparent 60%),
    #ffffff !important;
  border: 1px solid var(--line-gold) !important;
}
.ss-edu-hero-title { color: var(--ink) !important; }
.ss-edu-hero-lead  { color: var(--ink-soft) !important; }

/* Steps */
.ss-steps-title    { color: var(--ink) !important; }
.ss-step           { background: #fafbfd !important; }
.ss-step-body h3   { color: var(--ink) !important; }
.ss-step-body p    { color: var(--ink-soft) !important; }
.ss-step-num       { color: var(--gold) !important; }

/* Plan / pricing cards */
.ss-plan-name, .ss-plan-price { color: var(--ink) !important; }
.ss-plan-price small          { color: var(--ink-muted) !important; }

/* Doc pages */
.ss-doc-card h2 { color: var(--ink) !important; }
.ss-doc-card a  { color: var(--royal-glow) !important; }

/* Trust block */
.ss-trust-title { color: var(--ink) !important; }

/* Header band — light, no dark gradient */
header, .ss-header {
  background: #ffffff !important;
  border-bottom: 1px solid var(--line);
}
.ss-brand-text strong { color: var(--ink) !important; }
.ss-nav a             { color: var(--ink-soft) !important; }
.ss-nav a:hover       { color: var(--gold) !important; }
.ss-pill              { color: var(--ink) !important; }

/* Sticky jurisdiction banner — light strip with subtle border */
.ss-jurisdiction-banner {
  background: #fff8e6 !important;
  color: var(--ink-soft) !important;
  border-bottom: 1px solid var(--line-gold) !important;
}
.ss-jurisdiction-banner * { color: var(--ink-soft) !important; }

/* Forms — light inputs */
.ss-form input,
.ss-form textarea,
.ss-form select {
  background: var(--navy-deep) !important;  /* now #f3f6fb */
  color: var(--ink) !important;
  border: 1px solid var(--line) !important;
}
.ss-form label { color: var(--ink-muted) !important; }

/* Progress bar background */
.ss-progress { background: var(--navy-deep) !important; border-color: var(--line) !important; }

/* Generic button (non-primary, non-secondary) — light surface */
.ss-btn {
  background: #ffffff;
  color: var(--ink);
  border: 1px solid var(--line);
  box-shadow: 0 2px 6px rgba(14,36,64,0.06);
}
.ss-btn:hover { background: #f5f8fc; }

/* Secondary (royal) button keeps white text — already correct */

/* Link button — readable on white */
.ss-btn-link { color: var(--royal-glow) !important; }

/* Footer */
.ss-footer        { color: var(--ink-muted) !important; border-top: 1px solid var(--line); }
.ss-footer a      { color: var(--royal-glow) !important; }
.ss-footer-links a{ color: var(--ink-soft) !important; }
.ss-footer-links a:hover{ color: var(--gold) !important; }

/* Notes / muted blocks */
.ss-note   { color: var(--ink-muted) !important; }
.ss-muted  { color: var(--ink-muted) !important; }
.ss-warn   { background: #fff4d6 !important; color: var(--ink) !important; }
.ss-flash-warn { background: #fff4d6 !important; color: var(--ink) !important; }
.ss-flash-success {
  background: #fff7e0 !important;
  color: var(--ink) !important;
  border-color: var(--gold) !important;
}

/* Compliance card */
.ss-compliance-card,
.ss-compliance-body,
.ss-compliance-list li { color: var(--ink-soft) !important; }

/* Timeline list */
.ss-timeline-label  { color: var(--ink) !important; }
.ss-timeline-status { color: var(--ink-muted) !important; }
.ss-timeline-current { background: #fff7e0 !important; }

/* Tabs — light pill row */
.ss-tabs { background: #f5f8fc !important; }
.ss-tab  { color: var(--ink-soft) !important; }
.ss-tab-active {
  background: #ffffff !important;
  color: var(--gold) !important;
  box-shadow: inset 0 0 0 1px var(--gold) !important;
}

/* Tile internals */
.ss-tile h3 { color: var(--ink) !important; }
.ss-tile p  { color: var(--ink-muted) !important; }

/* Stat */
.ss-stat-value { color: var(--ink) !important; }

/* Tables */
.ss-table th { color: var(--gold) !important; border-color: var(--line) !important; }
.ss-table td { color: var(--ink) !important; border-color: var(--line) !important; }

/* Headings inside white cards */
h1, h2, h3, h4 { color: var(--ink); }
.ss-h1-white   { color: var(--ink) !important; }

/* Re-assert gold/royal/secondary buttons — they must keep brand color
   on the new white surface. */
.ss-btn-primary,
.ss-btn-gold,
.ss-pill-cta {
  background: linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%) !important;
  color: #2a1d04 !important;
  border: 1px solid var(--gold) !important;
  box-shadow: 0 8px 22px rgba(214,169,72,0.35),
              inset 0 1px 0 rgba(255,255,255,0.5) !important;
}
.ss-btn-primary:hover,
.ss-btn-gold:hover,
.ss-pill-cta:hover {
  background: linear-gradient(180deg, #ecbe5a 0%, var(--gold-bright) 100%) !important;
}
.ss-btn-secondary {
  background: linear-gradient(180deg, var(--royal-2), var(--royal)) !important;
  color: #ffffff !important;
  border: 1px solid var(--royal) !important;
  box-shadow: 0 6px 18px rgba(42,106,214,0.35) !important;
}
.ss-btn-ghost {
  background: transparent !important;
  border: 1px solid var(--gold) !important;
  color: var(--gold) !important;
  box-shadow: none !important;
}

/* ============================================================
   BOLDER TEXT FOR LIGHT THEME
   On white, the previous weights felt too thin. Bump body text,
   headings, navigation, labels, and tile/card copy.
   ============================================================ */
html, body {
  font-weight: 500;
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
p, li, label, .ss-sub, .ss-sub-lead, .ss-muted,
.ss-edu-hero-lead, .ss-step-body p, .ss-tile p,
.ss-compliance-body, .ss-compliance-list li,
.ss-timeline-label, .ss-timeline-status,
.ss-doc-card, .ss-card, .ss-msg-body,
.ss-trust-fineprint {
  font-weight: 500 !important;
}
.ss-muted, .ss-footer, .ss-tile p, .ss-step-body p,
.ss-compliance-list li, .ss-timeline-status {
  color: #3a4a66 !important;        /* darker muted for contrast */
}
strong, b { font-weight: 800 !important; }

h1, h2, h3, h4, .ss-display,
.ss-h1, .ss-h1-white, .ss-h1-gold,
.ss-edu-hero-title, .ss-steps-title,
.ss-pricing-name, .ss-plan-name,
.ss-tile h3, .ss-step-body h3,
.ss-doc-card h2 {
  font-weight: 800 !important;
  color: var(--ink);
}

.ss-nav a            { font-weight: 800 !important; font-size: 1.18rem !important; }
.ss-nav .ss-pill, .ss-nav .ss-nav-cases { font-weight: 800 !important; font-size: 1.18rem !important; }
.ss-brand-text strong{ font-weight: 800 !important; }
.ss-brand-text em    { font-weight: 700 !important; }
.ss-eyebrow, .ss-eyebrow-gold,
.ss-card-eyebrow, .ss-stat-label,
.ss-utilities-eyebrow { font-weight: 800 !important; }

.ss-btn        { font-weight: 700 !important; }
.ss-btn-primary, .ss-btn-gold,
.ss-btn-secondary, .ss-pill-cta { font-weight: 800 !important; }
.ss-btn-link   { font-weight: 600 !important; }

.ss-form input, .ss-form textarea, .ss-form select {
  font-weight: 600 !important;
  color: var(--ink) !important;
}
.ss-form label { font-weight: 700 !important; color: var(--ink-soft) !important; }

.ss-jurisdiction-banner,
.ss-jurisdiction-banner * { font-weight: 700 !important; }

/* ============================================================
   ROYAL BLUE + WHITE + WARM GOLD COLOR LOCK
   Per design spec: every box this royal blue, every letter
   white, every yellow this warm honey gold. Final override —
   nothing below should be added without preserving these.
   ============================================================ */
:root{
  --rb-blue:        #1e3d96;   /* primary box / surface */
  --rb-blue-2:      #2649a8;   /* slightly lighter accent */
  --rb-blue-deep:   #16306f;   /* page edges */
  --rb-white:       #ffffff;
  --rb-white-soft:  #eef2fb;
  --rb-gold:        #f4c244;   /* warm honey gold */
  --rb-gold-bright: #ffd866;
  --rb-gold-deep:   #b8861f;
}

/* Page background — royal blue wash */
html, body{
  background:
    radial-gradient(1200px 700px at 18% -10%, rgba(38, 73, 168, 0.55), transparent 60%),
    radial-gradient(900px 600px at 110% 8%, rgba(244, 194, 68, 0.10), transparent 60%),
    linear-gradient(180deg, #1a3686 0%, #1e3d96 50%, #16306f 100%) !important;
  color: var(--rb-white) !important;
}

/* Every box / card / surface → royal blue */
.ss-hero-card,
.ss-card,
.ss-tile,
.ss-stat,
.ss-pricing,
.ss-plan-card,
.ss-edu-hero,
.ss-steps-card,
.ss-trust-card,
.ss-doc-card,
.ss-next-card,
.ss-compliance-card,
.ss-tabs,
.ss-msg,
.ss-step,
.ss-timeline-item,
.ss-note,
.ss-warn,
.ss-flash,
.ss-flash-warn,
.ss-flash-success,
.ss-paywall,
.ss-field,
header, .ss-header{
  background: linear-gradient(180deg, var(--rb-blue-2) 0%, var(--rb-blue) 100%) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  color: var(--rb-white) !important;
  box-shadow: 0 10px 28px rgba(10, 22, 60, 0.35),
              inset 0 1px 0 rgba(255,255,255,0.08) !important;
}

/* Sticky jurisdiction strip — slim royal-blue bar */
.ss-jurisdiction-banner,
.ss-jurisdiction-banner *{
  background: var(--rb-blue-deep) !important;
  color: var(--rb-white) !important;
  border-color: rgba(255,255,255,0.14) !important;
}

/* Every letter → white */
body, p, li, a, span, label, legend, td, th,
h1, h2, h3, h4, h5, h6,
strong, b, em, small,
.ss-h1, .ss-h1-white, .ss-h1-gold, .ss-h1-year,
.ss-sub, .ss-sub-lead, .ss-muted, .ss-eyebrow, .ss-eyebrow-gold,
.ss-card-eyebrow, .ss-stat-label, .ss-stat-value,
.ss-tile h3, .ss-tile p,
.ss-step-body h3, .ss-step-body p, .ss-step-num,
.ss-edu-hero-title, .ss-edu-hero-lead,
.ss-steps-title, .ss-pricing-name, .ss-plan-name,
.ss-plan-price, .ss-plan-price small,
.ss-doc-card, .ss-doc-card h2, .ss-doc-card a,
.ss-trust-title, .ss-trust-fineprint,
.ss-compliance-title, .ss-compliance-body, .ss-compliance-list li,
.ss-timeline-label, .ss-timeline-status,
.ss-msg-role, .ss-msg-body,
.ss-tab, .ss-tab-active,
.ss-nav a, .ss-pill,
.ss-brand-text strong, .ss-brand-text em,
.ss-footer, .ss-footer a, .ss-footer-links a,
.ss-utilities-eyebrow,
.ss-table th, .ss-table td,
.ss-form label{
  color: var(--rb-white) !important;
}

/* Soft white for secondary copy so hierarchy still reads */
.ss-muted, .ss-tile p, .ss-step-body p,
.ss-compliance-body, .ss-compliance-list li,
.ss-timeline-status, .ss-footer, .ss-footer-links a,
.ss-edu-hero-lead, .ss-plan-price small,
.ss-trust-fineprint{
  color: var(--rb-white-soft) !important;
  opacity: 0.92;
}

/* Links — white but underline-on-hover */
a{ color: var(--rb-white) !important; }
a:hover{ color: var(--rb-gold) !important; text-decoration: underline; }

/* All gold accents → the warm honey tone */
.ss-eyebrow, .ss-eyebrow-gold, .ss-card-eyebrow,
.ss-stat-label, .ss-utilities-eyebrow,
.ss-h1-gold, .ss-tab-active,
.ss-compliance-title,
.ss-timeline-current .ss-timeline-status,
.ss-table th{
  color: var(--rb-gold) !important;
}

/* Gold pill / primary buttons → warm honey gradient with deep brown text
   (matches the badge in the reference image) */
.ss-btn-primary,
.ss-btn-gold,
.ss-pill-cta{
  background: linear-gradient(180deg, var(--rb-gold-bright) 0%, var(--rb-gold) 100%) !important;
  color: #5a3a06 !important;
  border: 1px solid var(--rb-gold) !important;
  box-shadow: 0 0 24px rgba(255, 216, 102, 0.45),
              0 8px 22px rgba(0, 0, 0, 0.30),
              inset 0 1px 0 rgba(255,255,255,0.55) !important;
  text-shadow: none !important;
}
.ss-btn-primary:hover,
.ss-btn-gold:hover,
.ss-pill-cta:hover{
  filter: brightness(1.06);
}

/* Call pill in the header — green tap-to-call button. On phones,
   space is tight, so we show only the phone icon + a short
   "Call" label; the full number is announced via title attribute
   and visible on tablet/desktop. */
.ss-pill-call{
  background: linear-gradient(180deg,#22c55e 0%,#16a34a 100%) !important;
  color:#fff !important;
  border:1px solid #15803d !important;
  font-weight:700 !important;
  display:inline-flex !important;
  align-items:center;
  gap:6px;
  box-shadow:0 4px 12px rgba(34,197,94,.35),inset 0 1px 0 rgba(255,255,255,.35) !important;
}
.ss-pill-call:hover{ filter:brightness(1.06); }
.ss-pill-call .ss-pill-call-num{ white-space:nowrap; }
@media (max-width: 540px){
  .ss-pill-call .ss-pill-call-num{
    font-size:.92rem;
  }
}

/* Generic / secondary buttons on royal blue */
.ss-btn{
  background: rgba(255,255,255,0.10) !important;
  color: var(--rb-white) !important;
  border: 1px solid rgba(255,255,255,0.30) !important;
  box-shadow: none !important;
}
.ss-btn:hover{ background: rgba(255,255,255,0.18) !important; }
.ss-btn-secondary{
  background: linear-gradient(180deg, #2f5dd0, #1f47a8) !important;
  color: var(--rb-white) !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
}
.ss-btn-ghost{
  background: transparent !important;
  border: 1px solid var(--rb-gold) !important;
  color: var(--rb-gold) !important;
}
.ss-btn-link{ color: var(--rb-white) !important; }
.ss-btn-link:hover{ color: var(--rb-gold) !important; }

/* Form inputs — readable on royal blue */
.ss-form input, .ss-form textarea, .ss-form select{
  background: rgba(255,255,255,0.08) !important;
  color: var(--rb-white) !important;
  border: 1px solid rgba(255,255,255,0.30) !important;
}
.ss-form input::placeholder,
.ss-form textarea::placeholder{ color: rgba(255,255,255,0.55) !important; }
.ss-form input:focus, .ss-form textarea:focus, .ss-form select:focus{
  border-color: var(--rb-gold) !important;
  box-shadow: 0 0 0 3px rgba(244, 194, 68, 0.25) !important;
}

/* Progress bar */
.ss-progress{ background: rgba(255,255,255,0.10) !important; border-color: rgba(255,255,255,0.20) !important; }
.ss-progress-bar{ background: linear-gradient(90deg, #ffffff, var(--rb-gold)) !important; }

/* Scale icon "PA" pill in the brand spot */
.ss-brand > div:first-child{
  background: linear-gradient(160deg, #2f5dd0, #1f47a8) !important;
  color: var(--rb-gold) !important;
}

/* Re-declare gold buttons LAST so they win over the generic
   .ss-btn rule above (both single-class, last wins). */
.ss-btn.ss-btn-primary,
.ss-btn.ss-btn-gold,
.ss-pill-cta,
a.ss-btn-primary,
a.ss-btn-gold{
  background: linear-gradient(180deg, var(--rb-gold-bright) 0%, var(--rb-gold) 100%) !important;
  color: #5a3a06 !important;
  border: 1px solid var(--rb-gold) !important;
  box-shadow: 0 0 24px rgba(255,216,102,0.45),
              0 8px 22px rgba(0,0,0,0.30),
              inset 0 1px 0 rgba(255,255,255,0.55) !important;
}

/* Restore white page background — only the BOXES are royal blue */
html, body{
  background:
    radial-gradient(1300px 700px at 18% -10%, rgba(58, 130, 238, 0.08), transparent 60%),
    radial-gradient(900px 600px at 110% 8%, rgba(244, 194, 68, 0.06), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f5f8fc 50%, #ffffff 100%) !important;
  color: var(--ink) !important;
}

/* Letters OUTSIDE the blue boxes (sticky strip, footer text, etc.)
   need to be readable on white. We re-color body-level text only;
   anything inside a blue box is already white via the box rules. */
.ss-main, .ss-footer{ color: var(--ink) !important; }

/* Stick the footer right under the content instead of leaving a
   sea of white space below short pages (e.g. the new Situation
   Selector home). Body becomes a flex column; main grows to fill
   the leftover viewport so the footer always sits flush — but
   without an obvious gap because there's no contrasting bg above
   the footer. */
html { min-height: 100%; }
body { display: flex; flex-direction: column; min-height: 100vh; }
.ss-main { flex: 1 0 auto; width: 100%; }
.ss-footer { flex: 0 0 auto; }

/* Make the App-sections row readable on the white footer. The
   global rule on line ~1091 forces every .ss-footer a to white,
   which paints them invisible. Override with the warm gold so the
   tool links pop without changing the rest of the footer. */
.ss-footer .ss-footer-tools a{
  color: var(--rb-gold-deep, #b8861f) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}
.ss-footer .ss-footer-tools a:hover{
  color: #5a3a06 !important;
  text-decoration: underline !important;
}
.ss-footer-tools{
  border-bottom: 1px solid rgba(0,0,0,0.10) !important;
}
/* Site links row also needs to be visible on white. */
.ss-footer .ss-footer-links a{
  color: var(--ink-soft, #3a4a66) !important;
}
.ss-footer .ss-footer-links a:hover{
  color: var(--rb-gold-deep, #b8861f) !important;
  text-decoration: underline !important;
}

/* ── AI assistant: preserve newlines/bullets, next-step card, quick-options ── */
.ss-chat .ss-msg-body{
  white-space: pre-wrap;
  word-wrap: break-word;
  line-height: 1.5;
}
.ss-next-step{
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 12px;
  background: linear-gradient(180deg,#1e3d96 0%,#2649a8 100%) !important;
  color: #fff !important;
  box-shadow: 0 10px 28px rgba(30,61,150,0.25);
}
.ss-next-step-title{ font-weight: 800; font-size: 1.05rem; margin-bottom: 6px; color:#fff !important; }
.ss-next-step-body{ color: #eef2fb !important; margin-bottom: 10px; line-height: 1.45; }
.ss-next-step .ss-btn{ display:inline-block; }
.ss-quick-options{
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ss-quick-option-form{ margin: 0; padding: 0; display: inline-block; }
.ss-quick-options .ss-btn{
  padding: 8px 14px;
  font-size: 0.95rem;
  font-weight: 700;
}

/* ── Document-generation wizard ─────────────────────────────────── */
.ss-wizard-card { padding: 22px 20px 26px; }
.ss-wizard-progress { margin-bottom: 18px; }
.ss-wizard-progress-meta {
  display:flex; justify-content:space-between;
  font-size:.85rem; color:#9fb1cf; margin-bottom:6px;
  font-weight:600; letter-spacing:.02em;
}
.ss-wizard-progress-bar {
  height:8px; border-radius:999px; background:rgba(255,255,255,.08);
  overflow:hidden;
}
.ss-wizard-progress-fill {
  height:100%; background:linear-gradient(90deg,#4A90D9 0%,#74b3ff 100%);
  border-radius:999px; transition:width .25s ease;
}
.ss-wizard-title {
  font-family:'Playfair Display',serif; font-weight:700;
  font-size:1.7rem; line-height:1.2; margin:6px 0 8px;
}
.ss-wizard-help { color:#c8d4ea; margin:0 0 18px; line-height:1.5; }
.ss-wizard-form { display:flex; flex-direction:column; gap:16px; }
.ss-wizard-actions {
  display:flex; flex-direction:column; gap:10px; margin-top:6px;
}
.ss-wizard-actions .ss-btn { width:100%; }
@media (min-width:640px) {
  .ss-wizard-actions { flex-direction:row-reverse; justify-content:flex-start; }
  .ss-wizard-actions .ss-btn { width:auto; min-width:180px; }
}

.ss-input-lg {
  font-size:1.05rem; padding:14px 14px; border-radius:10px;
  width:100%; box-sizing:border-box;
  background:#0a1424; color:#fff;
  border:1px solid rgba(255,255,255,.18);
}
.ss-input-lg:focus { outline:2px solid #4A90D9; outline-offset:1px; }
.ss-input-money {
  display:flex; align-items:stretch; gap:0;
  border:1px solid rgba(255,255,255,.18); border-radius:10px;
  background:#0a1424; overflow:hidden;
}
.ss-input-money > span {
  display:inline-flex; align-items:center; padding:0 14px;
  background:rgba(255,255,255,.05); color:#9fb1cf; font-weight:700;
}
.ss-input-money .ss-input-lg { border:0; border-radius:0; background:transparent; }

.ss-choice-list { display:flex; flex-direction:column; gap:10px; }
.ss-choice {
  display:flex; align-items:center; gap:12px;
  padding:14px 16px; border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.03);
  cursor:pointer; transition:background .15s,border-color .15s;
  font-size:1rem;
}
.ss-choice input { transform:scale(1.2); accent-color:#4A90D9; }
.ss-choice:hover { background:rgba(74,144,217,.08); border-color:#4A90D9; }
.ss-choice.is-selected { background:rgba(74,144,217,.18); border-color:#4A90D9; }

.ss-btn-lg { padding:14px 22px; font-size:1.05rem; font-weight:700; }

.ss-flash-error {
  background:rgba(220,55,75,.12); border:1px solid rgba(220,55,75,.5);
  color:#ffb4be; padding:10px 14px; border-radius:8px; margin-bottom:14px;
}

.ss-notice-decision {
  background:linear-gradient(180deg,#1e3d96 0%,#2649a8 100%);
  color:#fff; padding:16px 18px; border-radius:12px; margin:14px 0 18px;
  box-shadow:0 10px 28px rgba(30,61,150,.25);
}
.ss-notice-decision-label {
  font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  color:#cdd9f5; font-weight:700;
}
.ss-notice-decision-title {
  font-size:1.25rem; font-weight:800; margin:4px 0 6px;
  font-family:'Playfair Display',serif;
}

.ss-review-table { width:100%; border-collapse:collapse; margin-top:12px; }
.ss-review-table th, .ss-review-table td {
  text-align:left; padding:10px 6px; border-bottom:1px solid rgba(255,255,255,.07);
  vertical-align:top;
}
.ss-review-table th { color:#9fb1cf; font-weight:600; font-size:.92rem; width:40%; }
.ss-review-table td:last-child { width:60px; text-align:right; }

.ss-generate-cta {
  background:linear-gradient(180deg,#1a2a4a 0%,#0D1B2A 100%);
  border:1px solid rgba(74,144,217,.4);
  box-shadow:0 12px 32px rgba(30,61,150,.18);
}

/* ── Printable generated document ──────────────────────────────── */
.ss-doc-toolbar {
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:10px;
}
.ss-doc-page {
  background:#fff; color:#111; padding:42px 48px;
  max-width:820px; margin:18px auto;
  border-radius:8px;
  box-shadow:0 10px 32px rgba(0,0,0,.35);
  font-family: Georgia, 'Times New Roman', serif;
  line-height:1.5;
}
.ss-doc-head { text-align:center; margin-bottom:18px; }
.ss-doc-eyebrow { font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:#444; }
.ss-doc-page h1 { font-size:1.6rem; margin:6px 0 4px; letter-spacing:.04em; }
.ss-doc-page h2 { font-size:1.25rem; margin:14px 0 6px; text-align:center; }
.ss-doc-page h3 { font-size:1rem; margin:14px 0 6px; color:#222; }
.ss-doc-sub { color:#444; font-style:italic; }
.ss-doc-section { margin:14px 0; }
.ss-doc-kv { margin:4px 0; }
.ss-doc-cos { list-style:none; padding:0; margin:8px 0; }
.ss-doc-cos li { margin:6px 0; }
.ss-doc-divider { margin:24px 0; border:0; border-top:2px solid #222; }
.ss-doc-sig-line { margin:8px 0; }
.ss-doc-blank {
  display:inline-block; min-width:240px; border-bottom:1px solid #444;
  height:1.1em; vertical-align:bottom;
}
.ss-doc-footer {
  margin-top:24px; padding-top:12px; border-top:1px solid #ccc;
  color:#666; font-size:.85rem; text-align:center;
}

@media print {
  body { background:#fff !important; color:#000 !important; }
  .no-print, .ss-header, .ss-footer, .ss-jurisdiction-banner { display:none !important; }
  .ss-doc-page { box-shadow:none; margin:0; padding:24px; max-width:none; border-radius:0; }
  .ss-main { padding:0 !important; }
}

/* Reusable legal-disclaimer partial (_legal_disclaimer.html) */
.ss-legal-disclaimer {
  display: block;
  margin: 18px auto 0;
  max-width: 640px;
  padding: 14px 16px;
  border-radius: 10px;
  background: rgba(74, 144, 217, 0.08);
  border: 1px solid rgba(74, 144, 217, 0.25);
  color: #cfe0f5;
  font-size: 0.9rem;
  line-height: 1.5;
}
.ss-legal-disclaimer strong { color: #fff; }
@media (max-width: 480px) {
  .ss-legal-disclaimer { font-size: 0.85rem; padding: 12px 14px; }
}
