/* CharterSelect website UI kit — page-level styles */

* { box-sizing: border-box; }
body { margin: 0; }

/* ----- Buttons ----- */
.cs-btn {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15px;
  padding: 13px 24px;
  border-radius: 999px;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: background 140ms var(--ease-out), color 140ms var(--ease-out), box-shadow 220ms var(--ease-out), transform 100ms;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}
.cs-btn--sm { padding: 10px 18px; font-size: 14px; }
.cs-btn--primary { background: var(--cs-teal); color: #fff; box-shadow: var(--shadow-teal); }
.cs-btn--primary:hover { background: var(--cs-teal-700); }
.cs-btn--primary:active { transform: translateY(1px); }
.cs-btn--secondary { background: #fff; color: var(--cs-teal); border-color: var(--cs-teal); }
.cs-btn--secondary:hover { background: var(--cs-teal-50); }
.cs-btn--gold { background: var(--cs-gold); color: var(--cs-charcoal); }
.cs-btn--gold:hover { background: var(--cs-gold-600); color: #fff; }

.cs-link { color: var(--cs-teal); font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 6px; text-decoration: none; transition: color 140ms; }
.cs-link:hover { color: var(--cs-teal-700); }
.cs-link--lg { font-size: 16px; }

.cs-display { font-family: var(--font-display); font-weight: 400; font-size: clamp(3rem, 5.5vw, 4.5rem); line-height: 1.05; letter-spacing: -0.015em; color: var(--fg-1); margin: 12px 0 20px; }
.cs-lead { font-family: var(--font-body); font-size: 18px; line-height: 1.6; color: var(--fg-2); margin: 0 0 24px; max-width: 60ch; }
.cs-eyebrow { font-family: var(--font-body); font-size: 12px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cs-teal); margin-bottom: 6px; }
.cs-eyebrow--on-teal { color: var(--cs-gold); }

/* ----- Nav ----- */
.cs-nav { position: sticky; top: 0; background: rgba(255,255,255,0.95); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border-1); z-index: 50; }
.cs-nav__inner { max-width: 1200px; margin: 0 auto; padding: 14px 32px; display: flex; align-items: center; gap: 32px; }
.cs-nav__brand img { height: 36px; }
.cs-nav__links { display: flex; gap: 28px; flex: 1; }
.cs-nav__links a { color: var(--fg-1); font-size: 14px; font-weight: 500; text-decoration: none; transition: color 140ms; }
.cs-nav__links a:hover { color: var(--cs-teal); }
.cs-nav__cta { display: flex; align-items: center; gap: 18px; }

/* ----- Hero ----- */
.cs-hero { background: linear-gradient(180deg, #fff 0%, var(--cs-cream) 100%); padding: 64px 32px 96px; }
.cs-hero__inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.cs-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 24px; }
.cs-hero__trust { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--fg-muted); font-weight: 500; }
.cs-hero__trust i { color: var(--cs-teal); }

.cs-hero__art { position: relative; max-width: 420px; justify-self: center; width: 100%; display: flex; align-items: center; justify-content: center; }
.cs-hero__mark { width: 100%; height: auto; display: block; filter: drop-shadow(0 16px 32px rgba(15,118,110,0.14)); }

/* ----- Stats ----- */
.cs-stats { background: var(--cs-teal); color: #fff; }
.cs-stats__inner { max-width: 1200px; margin: 0 auto; padding: 40px 32px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.cs-stat { text-align: center; }
.cs-stat__num { font-family: var(--font-display); font-weight: 400; font-size: 60px; line-height: 1; letter-spacing: -0.02em; color: var(--cs-gold); }
.cs-stat__usa { height: 60px; display: flex; align-items: center; justify-content: center; color: var(--cs-gold); }
.cs-stat__usa img, .cs-stat__usa svg { height: 100%; width: auto; max-width: 160px; display: block; color: var(--cs-gold); }
.cs-stat__usa img { filter: drop-shadow(0 0 3px rgba(251,191,36,0.5)); }
.cs-stat__lbl { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; margin-top: 10px; opacity: 0.92; line-height: 1.4; }

/* ----- Sections ----- */
.cs-section { padding: 96px 32px; }
.cs-section--cream { background: var(--cs-cream); }
.cs-section--teal { background: var(--cs-teal); color: #fff; }
.cs-section__inner { max-width: 1200px; margin: 0 auto; }
.cs-section__head { text-align: center; max-width: 760px; margin: 0 auto 56px; }
.cs-section__head h2 { font-family: var(--font-display); font-weight: 400; font-size: 44px; line-height: 1.2; letter-spacing: -0.01em; margin: 8px 0 0; }

/* ----- Cards ----- */
.cs-grid--4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.cs-card { background: #fff; border: 1px solid var(--border-1); border-radius: 12px; padding: 24px; box-shadow: var(--shadow-sm); transition: transform 220ms var(--ease-out), box-shadow 220ms var(--ease-out); display: flex; flex-direction: column; gap: 10px; }
.cs-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.cs-card__icon { width: 44px; height: 44px; border-radius: 8px; background: var(--cs-teal-50); color: var(--cs-teal); display: flex; align-items: center; justify-content: center; }
.cs-card__title { font-family: var(--font-display); font-weight: 400; font-size: 20px; color: var(--fg-1); margin: 0; line-height: 1.3; }
.cs-card__body { font-size: 14px; line-height: 1.55; color: var(--fg-2); margin: 0 0 8px; flex: 1; }

/* ----- Why split ----- */
.cs-split { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.cs-split h2 { font-family: var(--font-display); font-weight: 400; font-size: 44px; line-height: 1.2; letter-spacing: -0.01em; margin: 8px 0 16px; }
.cs-checklist { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-direction: column; gap: 12px; }
.cs-checklist li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; color: var(--fg-2); line-height: 1.5; }
.cs-checklist li i, .cs-checklist li svg { color: var(--cs-teal); margin-top: 4px; flex-shrink: 0; }

.cs-quote-card { background: #fff; border: 1px solid var(--border-1); border-radius: 16px; padding: 32px; box-shadow: var(--shadow-md); position: relative; }
.cs-quote-card > i { color: var(--cs-gold); }
.cs-quote { font-family: var(--font-display); font-weight: 400; font-style: italic; font-size: 19px; line-height: 1.5; color: var(--fg-1); margin: 12px 0 24px; }
.cs-quote-attr { font-size: 13px; color: var(--fg-muted); line-height: 1.5; }
.cs-quote-attr strong { color: var(--fg-1); font-family: var(--font-body); font-weight: 600; }
.cs-quote-nav { display: flex; gap: 8px; margin-top: 22px; }
.cs-quote-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--cs-gray-300); border: 0; padding: 0; cursor: pointer; transition: background 140ms var(--ease-out), transform 140ms var(--ease-out); }
.cs-quote-dot:hover { background: var(--cs-teal-50); }
.cs-quote-dot.is-active { background: var(--cs-teal); transform: scale(1.2); }

/* ----- Upload ----- */
.cs-upload { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.cs-h2-on-teal { font-family: var(--font-display); font-weight: 400; font-size: 44px; line-height: 1.2; letter-spacing: -0.01em; color: #fff; margin: 8px 0 16px; }
.cs-lead-on-teal { font-size: 18px; line-height: 1.6; color: rgba(255,255,255,0.9); margin: 0; max-width: 50ch; }
.cs-upload__box { background: rgba(255,255,255,0.06); border: 1.5px dashed rgba(255,255,255,0.4); border-radius: 16px; padding: 40px 32px; text-align: center; color: #fff; }
.cs-upload__box > i { color: var(--cs-gold); margin-bottom: 8px; }
.cs-upload__title { font-family: var(--font-display); font-weight: 400; font-size: 24px; margin-bottom: 4px; }
.cs-upload__sub { font-size: 13px; color: rgba(255,255,255,0.7); margin-bottom: 20px; }
.cs-upload__file { font-size: 13px; margin-top: 14px; color: var(--cs-gold); font-family: var(--font-mono); }
.cs-upload__lock { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; color: rgba(255,255,255,0.7); margin-top: 18px; }
.cs-upload__fields { display: flex; flex-direction: column; gap: 12px; margin: 20px 0; text-align: left; }
.cs-upload__field { display: flex; flex-direction: column; gap: 5px; }
.cs-upload__label { font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.6); letter-spacing: 0.08em; text-transform: uppercase; }
.cs-upload__input { background: rgba(255,255,255,0.08); border: 1.5px solid rgba(255,255,255,0.2); border-radius: 8px; padding: 10px 14px; color: #fff; font-family: var(--font-body); font-size: 14px; outline: none; transition: border-color 150ms, background 150ms; width: 100%; box-sizing: border-box; }
.cs-upload__input::placeholder { color: rgba(255,255,255,0.3); }
.cs-upload__input:focus { border-color: var(--cs-gold); background: rgba(255,255,255,0.12); }
.cs-upload__files { display: flex; flex-direction: column; gap: 6px; margin-top: 14px; }
.cs-upload__file-item { display: flex; align-items: center; gap: 8px; font-size: 13px; color: rgba(255,255,255,0.85); background: rgba(255,255,255,0.07); border-radius: 8px; padding: 8px 12px; }
.cs-upload__file-item span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cs-upload__file-remove { background: none; border: none; color: rgba(255,255,255,0.35); cursor: pointer; padding: 0 2px; font-size: 18px; line-height: 1; transition: color 120ms; flex-shrink: 0; }
.cs-upload__file-remove:hover { color: rgba(255,255,255,0.8); }
.cs-upload__submit { width: 100%; margin-top: 20px; padding: 14px 24px; font-size: 15px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.cs-upload__submit:disabled { opacity: 0.45; cursor: not-allowed; transform: none !important; }
.cs-rank__ctas { display: flex; gap: 12px; margin-top: 20px; }
@media (max-width: 560px) { .cs-rank__ctas { flex-direction: column; } }
.cs-peer-stat { display: flex; align-items: flex-start; gap: 16px; background: rgba(255,255,255,0.08); border: 1px solid rgba(251,191,36,0.35); border-radius: 12px; padding: 20px 24px; }
.cs-peer-stat__emoji { font-size: 28px; line-height: 1; flex-shrink: 0; margin-top: 2px; }
.cs-peer-stat__headline { font-family: var(--font-display); font-size: 20px; color: var(--cs-gold); margin-bottom: 6px; }
.cs-peer-stat__body { font-size: 14px; color: rgba(255,255,255,0.85); line-height: 1.65; margin: 0; }
.cs-upload__error { background: rgba(239,68,68,0.15); border: 1px solid rgba(239,68,68,0.4); border-radius: 8px; padding: 11px 16px; font-size: 13px; color: #fca5a5; margin-top: 14px; text-align: left; line-height: 1.5; }
.cs-upload__success { display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 16px 8px; text-align: center; }
.cs-upload__success-icon { width: 56px; height: 56px; background: var(--cs-gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cs-upload__success-icon i { color: var(--cs-charcoal) !important; }
.cs-upload__success-title { font-family: var(--font-display); font-size: 30px; color: #fff; margin: 0; }
.cs-upload__success-msg { font-size: 15px; color: rgba(255,255,255,0.85); line-height: 1.65; margin: 0; max-width: 380px; }
.cs-upload__success-msg strong { color: #fff; }
@keyframes cs-spin { to { transform: rotate(360deg); } }
.cs-upload__spinner { display: inline-block; animation: cs-spin 0.9s linear infinite; }

/* ----- Self-Assessment ----- */
.cs-assess { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; }
.cs-assess__row { display: grid; grid-template-columns: 32px 1fr auto; gap: 16px; align-items: center; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.15); border-radius: 12px; padding: 16px 20px; }
.cs-assess__num { font-family: var(--font-display); font-size: 22px; color: var(--cs-gold); line-height: 1; text-align: center; }
.cs-assess__q { font-size: 15px; line-height: 1.5; color: rgba(255,255,255,0.95); }
.cs-assess__btns { display: flex; gap: 8px; flex-shrink: 0; }
.cs-assess__btn { font-family: var(--font-body); font-size: 13px; font-weight: 600; padding: 7px 16px; border-radius: 999px; border: 1.5px solid rgba(255,255,255,0.35); background: transparent; color: rgba(255,255,255,0.75); cursor: pointer; transition: background 120ms, color 120ms, border-color 120ms; white-space: nowrap; }
.cs-assess__btn:hover { background: rgba(255,255,255,0.12); color: #fff; border-color: rgba(255,255,255,0.6); }
.cs-assess__btn.is-active.is-yes { background: #14b8a6; border-color: #14b8a6; color: #fff; }
.cs-assess__btn.is-active.is-no { background: #ef4444; border-color: #ef4444; color: #fff; }
.cs-assess__btn.is-active.is-not-sure { background: var(--cs-gold); border-color: var(--cs-gold); color: var(--cs-charcoal); }
.cs-assess__result { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.2); border-radius: 14px; padding: 28px 32px; display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.cs-assess__result p { color: rgba(255,255,255,0.9); font-size: 15.5px; line-height: 1.65; margin: 0; }

@media (max-width: 720px) {
  .cs-assess__row { grid-template-columns: 1fr; gap: 12px; }
  .cs-assess__num { display: none; }
  .cs-assess__btns { flex-wrap: wrap; }
}

/* ----- Rank / drag-to-order ----- */
.cs-rank { display: flex; flex-direction: column; gap: 10px; }
.cs-rank__row { display: grid; grid-template-columns: 32px 1fr auto; gap: 16px; align-items: center; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.15); border-radius: 12px; padding: 16px 20px; cursor: grab; transition: background 120ms, border-color 120ms, opacity 120ms, transform 120ms; user-select: none; }
.cs-rank__row:active { cursor: grabbing; }
.cs-rank__row:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.3); }
.cs-rank__row.is-dragging { opacity: 0.35; cursor: grabbing; }
.cs-rank__row.is-over { border-color: var(--cs-gold); background: rgba(251,191,36,0.12); transform: scale(1.01); }
.cs-rank__num { font-family: var(--font-display); font-size: 22px; color: var(--cs-gold); line-height: 1; text-align: center; }
.cs-rank__label { font-size: 15px; line-height: 1.5; color: rgba(255,255,255,0.95); }
.cs-rank__handle { color: rgba(255,255,255,0.35); display: flex; align-items: center; flex-shrink: 0; }
.cs-rank__row:hover .cs-rank__handle { color: rgba(255,255,255,0.7); }

/* ----- Community ----- */
.cs-community { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: center; }
.cs-community h2 { font-family: var(--font-display); font-weight: 400; font-size: 44px; line-height: 1.2; letter-spacing: -0.01em; margin: 8px 0 16px; }
.cs-community__seal { display: flex; justify-content: center; }
.cs-community__seal img { width: 240px; height: auto; filter: drop-shadow(0 12px 24px rgba(15,118,110,0.18)); }

/* ----- Sub-page hero ----- */
.cs-page-hero { background: linear-gradient(180deg, #fff 0%, var(--cs-cream) 100%); padding: 56px 32px 72px; border-bottom: 1px solid var(--border-1); }
.cs-page-hero__inner { max-width: 1000px; margin: 0 auto; }
.cs-page-hero__title { font-family: var(--font-display); font-weight: 400; font-size: clamp(2.5rem, 4.5vw, 3.75rem); line-height: 1.05; letter-spacing: -0.015em; color: var(--fg-1); margin: 12px 0 20px; }
.cs-back { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--cs-teal); font-weight: 600; text-decoration: none; margin-bottom: 24px; }
.cs-back:hover { color: var(--cs-teal-700); }

/* ----- Long-form prose blocks ----- */
.cs-prose { max-width: 1000px; margin: 0 auto; padding: 0 32px; }
.cs-prose h2 { font-family: var(--font-display); font-weight: 400; font-size: 32px; line-height: 1.2; letter-spacing: -0.01em; margin: 48px 0 16px; color: var(--fg-1); }
.cs-prose h3 { font-family: var(--font-display); font-weight: 400; font-size: 22px; margin: 32px 0 8px; color: var(--fg-1); }
.cs-prose p { font-size: 16.5px; line-height: 1.7; color: var(--fg-2); margin: 0 0 16px; }
.cs-prose ul { font-size: 16.5px; line-height: 1.7; color: var(--fg-2); padding-left: 22px; }
.cs-prose ul li { margin-bottom: 6px; }

/* Detail card grid (deeper than home cards) */
.cs-detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 24px; }
.cs-detail { background: #fff; border: 1px solid var(--border-1); border-radius: 14px; padding: 28px; box-shadow: var(--shadow-sm); }
.cs-detail__head { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.cs-detail__head .cs-card__icon { margin: 0; }
.cs-detail h3 { font-family: var(--font-display); font-weight: 400; font-size: 22px; margin: 0; color: var(--fg-1); line-height: 1.2; }
.cs-detail p { font-size: 14.5px; line-height: 1.6; color: var(--fg-2); margin: 0 0 12px; }
.cs-detail ul { font-size: 14px; line-height: 1.55; color: var(--fg-2); padding-left: 18px; margin: 0; }
.cs-detail ul li { margin-bottom: 4px; }

/* Testimonial block (longer than home quote card) */
.cs-testimonials { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
.cs-testimonial { background: var(--cs-cream); border-left: 3px solid var(--cs-gold); border-radius: 0 12px 12px 0; padding: 24px 28px; }
.cs-testimonial__quote { font-family: var(--font-display); font-style: italic; font-size: 17px; line-height: 1.55; color: var(--fg-1); margin: 0 0 16px; }
.cs-testimonial__attr { font-size: 13px; color: var(--fg-muted); line-height: 1.5; }
.cs-testimonial__attr strong { display: block; color: var(--fg-1); font-family: var(--font-body); font-weight: 600; font-size: 14px; }

/* CTA strip */
.cs-cta-strip { background: var(--cs-teal); color: #fff; padding: 56px 32px; margin-top: 80px; }
.cs-cta-strip__inner { max-width: 1000px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; gap: 32px; flex-wrap: wrap; }
.cs-cta-strip h2 { font-family: var(--font-display); font-weight: 400; font-size: 32px; line-height: 1.2; margin: 0 0 8px; color: #fff; }
.cs-cta-strip p { margin: 0; color: rgba(255,255,255,0.85); font-size: 15px; max-width: 50ch; }

/* Numbered process */
.cs-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 24px; }
.cs-step { background: #fff; border: 1px solid var(--border-1); border-radius: 12px; padding: 24px; }
.cs-step__num { font-family: var(--font-display); font-weight: 400; font-size: 36px; color: var(--cs-gold); line-height: 1; margin-bottom: 12px; }
.cs-step__title { font-family: var(--font-display); font-weight: 400; font-size: 18px; color: var(--fg-1); margin: 0 0 6px; }
.cs-step__body { font-size: 13.5px; line-height: 1.55; color: var(--fg-2); margin: 0; }

@media (max-width: 720px) {
  .cs-detail-grid, .cs-testimonials { grid-template-columns: 1fr; }
  .cs-steps { grid-template-columns: 1fr 1fr; }
}

/* ----- Need selector (hero) ----- */
.cs-need-selector { margin: 0 0 8px; }
.cs-need-selector__label { font-size: 13px; font-weight: 600; color: var(--fg-muted); letter-spacing: 0.06em; text-transform: uppercase; margin: 0 0 12px; }
.cs-need-selector__btns { display: flex; flex-direction: column; gap: 10px; max-width: 420px; }
.cs-need-btn { display: flex; align-items: center; gap: 14px; background: #fff; border: 1.5px solid var(--border-1); border-radius: 12px; padding: 16px 20px; text-decoration: none; color: var(--fg-1); font-family: var(--font-body); font-weight: 600; font-size: 15px; box-shadow: var(--shadow-sm); transition: border-color 150ms, box-shadow 150ms, background 150ms; cursor: pointer; }
.cs-need-btn:hover { border-color: var(--cs-teal); box-shadow: var(--shadow-md); background: var(--cs-teal-50); color: var(--cs-teal); }
.cs-need-btn > i:first-child { color: var(--cs-teal); flex-shrink: 0; }
.cs-need-btn span { flex: 1; }
.cs-need-btn__arrow { color: var(--fg-muted); flex-shrink: 0; transition: transform 150ms; }
.cs-need-btn:hover .cs-need-btn__arrow { transform: translateX(3px); color: var(--cs-teal); }
.cs-need-btn--gold { background: #FBBF24; border-color: #FBBF24; color: #1F2937; }
.cs-need-btn--gold > i:first-child { color: #1F2937; }
.cs-need-btn--gold .cs-need-btn__arrow { color: #1F2937; opacity: 0.6; }
.cs-need-btn--gold:hover { background: #F59E0B; border-color: #F59E0B; color: #1F2937; }
.cs-need-btn--gold:hover .cs-need-btn__arrow { color: #1F2937; opacity: 1; transform: translateX(3px); }

/* ----- Footer ----- */
.cs-footer { background: var(--cs-charcoal); color: rgba(255,255,255,0.85); padding: 64px 32px 24px; }
.cs-footer__inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 2fr; gap: 64px; }
.cs-footer__logo { height: 36px; margin-bottom: 16px; }
.cs-footer__brand p { font-size: 14px; line-height: 1.6; max-width: 38ch; color: rgba(255,255,255,0.65); }
.cs-footer__cols { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }
.cs-footer__cols h5 { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: #fff; margin: 0 0 14px; font-weight: 600; }
.cs-footer__cols a { display: block; color: rgba(255,255,255,0.65); font-size: 14px; text-decoration: none; padding: 4px 0; transition: color 140ms; }
.cs-footer__cols a:hover { color: var(--cs-gold); }
.cs-footer__bar { max-width: 1200px; margin: 48px auto 0; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: rgba(255,255,255,0.5); }
.cs-footer__nationwide { display: inline-flex; flex-direction: column; align-items: center; gap: 6px; line-height: 1; letter-spacing: 0.06em; text-transform: uppercase; color: rgba(255,255,255,0.7); }
.cs-footer__flag { display: block; border-radius: 2px; box-shadow: 0 1px 0 rgba(0,0,0,0.25); }

/* ===== MOBILE RESPONSIVE (max-width: 768px) ===== */
@media (max-width: 768px) {

  /* Nav — collapse to single row, hide text links */
  .cs-nav__inner { padding: 12px 16px; gap: 0; flex-wrap: wrap; justify-content: space-between; }
  .cs-nav__brand img { height: 28px; }
  .cs-nav__links { display: none; }
  .cs-nav__cta { gap: 10px; }
  .cs-nav__cta .cs-link { display: none; }
  .cs-btn--sm { padding: 9px 14px; font-size: 13px; }

  /* Hero — single column, tighter padding */
  .cs-hero { padding: 40px 16px 56px; }
  .cs-hero__inner { grid-template-columns: 1fr; gap: 32px; }
  .cs-hero__art { display: none; }
  .cs-display { font-size: clamp(2.2rem, 9vw, 3rem); }
  .cs-lead { font-size: 16px; }
  .cs-need-selector__btns { max-width: 100%; }
  .cs-need-btn { font-size: 14px; padding: 14px 16px; gap: 10px; }

  /* Stats bar — 2x2 grid */
  .cs-stats__inner { grid-template-columns: repeat(2, 1fr); padding: 32px 16px; gap: 24px; }
  .cs-stat__num { font-size: 44px; }

  /* Sections */
  .cs-section { padding: 56px 16px; }
  .cs-section__head h2 { font-size: 30px; }

  /* 4-col cards → single col */
  .cs-grid--4 { grid-template-columns: 1fr; }

  /* Split layouts → single col */
  .cs-split { grid-template-columns: 1fr; gap: 40px; }
  .cs-split h2 { font-size: 30px; }

  /* Community */
  .cs-community { grid-template-columns: 1fr; gap: 32px; }
  .cs-community h2 { font-size: 30px; }
  .cs-community__seal img { width: 160px; }

  /* Upload/rank section */
  .cs-h2-on-teal { font-size: 28px; }
  .cs-rank__row { padding: 12px 14px; gap: 12px; }
  .cs-rank__label { font-size: 13.5px; }

  /* Footer — stack everything */
  .cs-footer { padding: 48px 16px 20px; }
  .cs-footer__inner { grid-template-columns: 1fr; gap: 36px; }
  .cs-footer__cols { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .cs-footer__bar { flex-direction: column; gap: 12px; text-align: center; margin-top: 32px; }

  /* Prose pages */
  .cs-prose { padding: 0 16px; }
  .cs-prose h2 { font-size: 26px; }
  .cs-page-hero { padding: 36px 16px 48px; }
  .cs-detail-grid { grid-template-columns: 1fr; }
  .cs-testimonials { grid-template-columns: 1fr; }
  .cs-steps { grid-template-columns: 1fr; }
  .cs-cta-strip { padding: 40px 16px; }
  .cs-cta-strip__inner { flex-direction: column; align-items: flex-start; gap: 20px; }
  .cs-cta-strip h2 { font-size: 26px; }
}

/* ----- Footer mobile quick-nav strip ----- */
.cs-footer__mobile-nav {
  display: none;
}
@media (max-width: 768px) {
  .cs-footer__mobile-nav {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 24px 16px 0;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    margin-bottom: 36px;
  }
  .cs-footer__mobile-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 15px 20px;
    border-radius: 12px;
    border: 1.5px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.06);
    color: #fff;
    font-family: var(--font-body);
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
    transition: background 140ms, border-color 140ms;
  }
  .cs-footer__mobile-btn:hover {
    background: rgba(255,255,255,0.12);
    border-color: rgba(255,255,255,0.4);
  }
  .cs-footer__mobile-btn--gold {
    background: var(--cs-gold);
    border-color: var(--cs-gold);
    color: var(--cs-charcoal);
  }
  .cs-footer__mobile-btn--gold:hover {
    background: var(--cs-gold-600);
    border-color: var(--cs-gold-600);
  }
}
