.vnq-shell {
  --vnq-forest: #30453d;
  --vnq-forest-deep: #1f2b26;
  --vnq-cream: #fbf8f2;
  --vnq-cream-deep: #f6efe4;
  --vnq-copper: #a77b5f;
  --vnq-text: #27322d;
  --vnq-muted: #667169;
  --vnq-line: rgba(48, 69, 61, 0.12);
  --vnq-shadow: 0 18px 42px rgba(70, 77, 70, 0.08);
  color: var(--vnq-text);
  font-family: "Manrope", sans-serif;
}

.vnq-shell * { box-sizing: border-box; }
.vnq-page { width: min(1180px, calc(100% - 32px)); margin: 0 auto; padding: 28px 0 84px; }
.vnq-shell img { max-width: 100%; }

.vnq-header,
.vnq-brand,
.vnq-actions,
.vnq-progress-panel,
.vnq-form-navigation,
.vnq-lead-actions { display: flex; }

.vnq-header,
.vnq-progress-panel { align-items: center; justify-content: space-between; }

.vnq-header { gap: 20px; margin-bottom: 32px; }
.vnq-brand { align-items: center; gap: 18px; }

.vnq-brand-logo {
  width: 82px; height: 82px; object-fit: cover; border-radius: 50%;
  border: 3px solid rgba(255, 244, 226, 0.88); box-shadow: 0 14px 30px rgba(48, 69, 61, 0.16);
}

.vnq-brand-title,
.vnq-hero-title,
.vnq-section-title,
.vnq-shell h3 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  color: var(--vnq-forest-deep);
  line-height: 0.98;
}

.vnq-brand-title { font-size: clamp(2rem, 3vw, 2.6rem); }
.vnq-hero-title { font-size: clamp(2.8rem, 5.4vw, 5rem); max-width: 11ch; }
.vnq-section-title { font-size: clamp(2.3rem, 4vw, 3.6rem); margin: 10px 0 14px; }

.vnq-eyebrow,
.vnq-card-label,
.vnq-step-label,
.vnq-progress-label {
  margin: 0; color: var(--vnq-copper); font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
}

.vnq-link-button,
.vnq-button {
  display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 22px;
  border-radius: 999px; text-decoration: none; font-weight: 700; cursor: pointer; transition: transform 180ms ease, box-shadow 180ms ease;
}

.vnq-link-button:hover,
.vnq-button:hover { transform: translateY(-1px); }

.vnq-link-button,
.vnq-button-secondary { border: 1px solid rgba(48, 69, 61, 0.18); color: var(--vnq-forest); background: #faf6ef; }

.vnq-button-primary { border: 0; color: #fff; background: linear-gradient(135deg, #2a3d37, #375046); box-shadow: 0 16px 28px rgba(30, 44, 38, 0.14); }

.vnq-hero { display: grid; grid-template-columns: 1.35fr 0.95fr; gap: 28px; align-items: start; padding-bottom: 56px; }

.vnq-card,
.vnq-hero-copy,
.vnq-assessment-card,
.vnq-info-card {
  border: 1px solid rgba(48, 69, 61, 0.08); background: var(--vnq-cream); box-shadow: var(--vnq-shadow);
}

.vnq-hero-copy { padding: clamp(28px, 5vw, 56px); border-radius: 38px; background: linear-gradient(180deg, var(--vnq-cream), var(--vnq-cream-deep)); }

.vnq-badge {
  display: inline-flex; align-items: center; gap: 14px; margin-bottom: 18px; padding: 10px 16px 10px 10px;
  border-radius: 999px; background: #fcf8f1; border: 1px solid rgba(48, 69, 61, 0.12); box-shadow: 0 8px 18px rgba(48, 69, 61, 0.05);
}

.vnq-badge-logo { width: 56px; height: 56px; object-fit: cover; border-radius: 50%; border: 2px solid rgba(255, 244, 226, 0.9); }
.vnq-badge span { font-size: 0.92rem; font-weight: 700; color: var(--vnq-forest); }

.vnq-hero-text,
.vnq-step-text,
.vnq-section-heading p:last-child,
.vnq-card p:last-child,
.vnq-results p,
.vnq-lead-copy p { color: var(--vnq-muted); line-height: 1.7; }

.vnq-hero-text { max-width: 58ch; margin: 24px 0 28px; font-size: 1.05rem; }
.vnq-actions { flex-wrap: wrap; gap: 12px; }
.vnq-hero-side { display: grid; gap: 18px; }
.vnq-card { padding: 30px; border-radius: 28px; background: #f7f0e5; }
.vnq-side-title { margin: 12px 0; }
.vnq-quote { margin: 0; padding: 4px 8px 0; font-family: "Cormorant Garamond", serif; font-size: clamp(1.65rem, 2vw, 2rem); color: var(--vnq-forest); line-height: 1.2; }

.vnq-list { list-style: none; margin: 18px 0 0; padding: 0; }
.vnq-list li { position: relative; padding-left: 24px; margin-bottom: 14px; line-height: 1.6; }
.vnq-list li::before {
  content: ""; position: absolute; left: 0; top: 0.75em; width: 10px; height: 10px; border-radius: 50%;
  background: linear-gradient(135deg, #b9965c, #8e6e57); transform: translateY(-50%);
}

.vnq-info-grid,
.vnq-results-grid { display: grid; gap: 18px; }
.vnq-info-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-bottom: 42px; }
.vnq-results-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.vnq-info-card { background: #f9f3e9; }

.vnq-assessment,
.vnq-results { padding-top: 28px; scroll-margin-top: 24px; }

.vnq-section-heading { margin-bottom: 24px; }
.vnq-assessment-card { padding: 28px; border-radius: 34px; background: #f8f2e8; }
.vnq-progress-panel { gap: 18px; margin-bottom: 26px; }
.vnq-progress-count { margin: 8px 0 0; font-size: 1.06rem; font-weight: 700; }

.vnq-progress-bar { width: min(320px, 100%); height: 10px; border-radius: 999px; background: rgba(48, 69, 61, 0.08); overflow: hidden; }
.vnq-progress-bar span { display: block; height: 100%; width: 16.66%; background: linear-gradient(90deg, #b9965c, #30453d); border-radius: inherit; transition: width 220ms ease; }

.vnq-step { display: none; }
.vnq-step.is-active { display: block; }
.vnq-step-text { margin: 12px 0 24px; }
.vnq-option-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }

.vnq-option-card {
  display: flex; min-height: 98px; padding: 18px 20px; border: 1px solid var(--vnq-line); border-radius: 18px;
  background: #fcf9f4; cursor: pointer; transition: border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.vnq-option-card:hover { transform: translateY(-2px); border-color: rgba(48, 69, 61, 0.24); box-shadow: 0 16px 28px rgba(48, 69, 61, 0.08); }
.vnq-option-card input { position: absolute; opacity: 0; pointer-events: none; }
.vnq-option-card span { font-weight: 600; line-height: 1.55; }
.vnq-option-card:has(input:checked) { border-color: rgba(48, 69, 61, 0.46); background: linear-gradient(135deg, #edf1e7, #faf6ef); box-shadow: 0 16px 24px rgba(48, 69, 61, 0.08); }

.vnq-form-navigation,
.vnq-lead-actions { justify-content: space-between; gap: 12px; margin-top: 28px; }
.vnq-hidden { display: none !important; }
.vnq-card-accent { background: linear-gradient(140deg, #2f433c, #566a59); color: #fff; }
.vnq-card-accent h3, .vnq-card-accent p { color: #fff; }

.vnq-lead-card { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 18px; background: #f7efe3; }
.vnq-field { display: block; margin-bottom: 14px; }
.vnq-field span { display: block; margin-bottom: 6px; font-size: 0.92rem; font-weight: 700; color: var(--vnq-forest); }
.vnq-field input { width: 100%; min-height: 52px; padding: 0 16px; border: 1px solid rgba(48, 69, 61, 0.16); border-radius: 14px; background: #fffdf9; color: var(--vnq-text); font: inherit; }
.vnq-honeypot { position: absolute !important; left: -9999px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }

.vnq-form-message { margin: 16px 0 0; min-height: 1.5em; font-weight: 600; }
.vnq-form-message.is-pending { color: var(--vnq-copper); }
.vnq-form-message.is-success { color: #345447; }
.vnq-form-message.is-error { color: #8e473f; }

@media (max-width: 920px) {
  .vnq-hero,
  .vnq-info-grid,
  .vnq-results-grid,
  .vnq-option-grid,
  .vnq-lead-card { grid-template-columns: 1fr; }

  .vnq-header,
  .vnq-progress-panel,
  .vnq-form-navigation,
  .vnq-lead-actions { flex-direction: column; align-items: stretch; }

  .vnq-hero-title,
  .vnq-section-title { max-width: none; }
}

@media (max-width: 640px) {
  .vnq-page { width: min(100% - 20px, 1180px); padding-top: 18px; }
  .vnq-brand-logo { width: 68px; height: 68px; }
  .vnq-card,
  .vnq-hero-copy,
  .vnq-assessment-card,
  .vnq-info-card { padding: 22px; }
  .vnq-badge { width: 100%; border-radius: 24px; }
  .vnq-badge-logo { width: 48px; height: 48px; }
  .vnq-hero-title { font-size: clamp(2.35rem, 11vw, 3.5rem); }
}
