/* =============================================================
   QUOTE PAGE
   ============================================================= */
.quote-page-wrapper { padding: 48px 0 64px; }
.quote-layout       { display: grid; grid-template-columns: 1fr 340px; gap: 48px; align-items: start; }

/* Form header */
.quote-form-header    { margin-bottom: 24px; }
.step-badge           { display: inline-block; background: rgba(30,58,123,.08); color: var(--blue); font-size: .75rem; font-weight: 700; padding: 3px 10px; border-radius: 20px; margin-bottom: 8px; }
.quote-form-header h2 { font-size: 1.4rem; font-weight: 800; color: var(--blue); }

/* Fieldset */
.form-fieldset        { border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-bottom: 20px; }
.form-fieldset legend { font-size: .82rem; font-weight: 700; color: var(--text-3); text-transform: uppercase; letter-spacing: .04em; padding: 0 8px; }

/* ── Radio pills ────────────────────────────────────────────── */
.radio-group {
  display: flex; flex-wrap: wrap; gap: 8px; padding-top: 8px;
}
.radio-option {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  border: 1.5px solid var(--border); border-radius: 8px;
  background: #fff; cursor: pointer;
  font-size: .875rem; font-weight: 500; color: var(--text-2);
  transition: border-color .18s, background .18s, color .18s, box-shadow .18s;
  user-select: none; line-height: 1.3;
}
/* Hide native radio — label click still toggles it */
.radio-option input[type="radio"] { display: none; }

.radio-option:hover {
  border-color: var(--blue-light);
  color: var(--blue);
  background: rgba(30,58,123,.04);
}
/* Checked state — :has() for modern browsers, .is-checked (JS) as fallback */
.radio-option:has(input:checked),
.radio-option.is-checked {
  border-color: var(--blue);
  background: var(--blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(30,58,123,.22);
}

/* ── Checkbox chips ─────────────────────────────────────────── */
.checkbox-group {
  display: flex; flex-wrap: wrap; gap: 8px; padding-top: 8px;
}
.checkbox-option {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px;
  border: 1.5px solid var(--border); border-radius: 8px;
  background: #fff; cursor: pointer;
  font-size: .875rem; font-weight: 500; color: var(--text-2);
  transition: border-color .18s, background .18s, color .18s, box-shadow .18s;
  user-select: none; line-height: 1.3;
}
.checkbox-option input[type="checkbox"] { display: none; }

.checkbox-option:hover {
  border-color: var(--green);
  color: var(--green-dark);
  background: rgba(45,158,68,.04);
}
.checkbox-option:has(input:checked),
.checkbox-option.is-checked {
  border-color: var(--green);
  background: var(--green);
  color: #fff;
  box-shadow: 0 2px 8px rgba(45,158,68,.22);
}
.checkbox-option:has(input:checked)::before,
.checkbox-option.is-checked::before {
  content: '';
  display: inline-block; flex-shrink: 0;
  width: 14px; height: 14px;
  background: rgba(255,255,255,.25)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")
    no-repeat center / 11px;
  border-radius: 3px;
}
.form-submit-area { margin-top: 20px; }
.form-note  { font-size: .8rem; color: var(--text-3); margin-bottom: 14px; display: flex; align-items: center; gap: 5px; }
.required   { color: #e53e3e; }
.btn-xl     { padding: 15px 36px; font-size: 1.05rem; }
.form-message       { margin-top: 12px; padding: 10px 14px; border-radius: 7px; font-size: .875rem; display: none; }
.form-message.success { background: rgba(45,158,68,.1); color: var(--green-dark); display: block; }
.form-message.error   { background: rgba(220,38,38,.08); color: #DC2626; display: block; }

/* Quote sidebar */
.quote-promise-box { background: var(--off-white); border-radius: var(--radius); padding: 24px; margin-bottom: 20px; border: 1px solid var(--border); }
.quote-promise-box h3 { font-size: 1rem; font-weight: 800; color: var(--blue); margin-bottom: 14px; }
.promise-list { list-style: none; padding: 0; counter-reset: none; }
.promise-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .875rem; color: var(--text-2); margin-bottom: 10px;
}
.promise-list li::before {
  content: ''; width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px;
  background: var(--green) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center / 11px;
  border-radius: 50%;
}
.quote-testimonial-mini { background: #fff; border-radius: var(--radius); border: 1px solid var(--border); padding: 20px; margin-top: 20px; }
.quote-testimonial-mini .stars     { font-size: 1rem; margin-bottom: 10px; }
.quote-testimonial-mini blockquote { font-size: .85rem; font-style: italic; color: var(--text-2); line-height: 1.6; margin-bottom: 10px; }
.quote-testimonial-mini cite       { font-size: .78rem; color: var(--text-3); font-style: normal; }

/* Quote sidebar CTA */
.btn-success { display: block; text-align: center; padding: 12px; background: var(--green); color: #fff; border-radius: 8px; font-weight: 700; font-size: .9rem; margin-bottom: 8px; }
.btn-zalo    { display: block; text-align: center; padding: 11px; background: #0068FF; color: #fff !important; border-radius: 8px; font-weight: 700; font-size: .875rem; }
.sidebar-cta-header   { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.sidebar-cta-header h3 { color: #fff; font-size: 1rem; }

/* Hero */
.quote-hero .page-subtitle strong { color: var(--green-light); }
.quote-hero-benefits { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 14px; }
.quote-hero-benefits span { font-size: .8rem; color: rgba(255,255,255,.8); display: flex; align-items: center; gap: 5px; }
.quote-hero-benefits span::before { content: '✓'; color: var(--green-light); font-weight: 900; }

@media (max-width: 900px) { .quote-layout { grid-template-columns: 1fr; } }
@media (max-width: 600px) { .form-row-2   { grid-template-columns: 1fr; } }
