/*
 * TrustFully Estate Planning Questionnaire
 * Uses high-specificity selectors to override WordPress theme CSS.
 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,700;0,800;1,700&display=swap');

/* ── RESET SCOPE ──────────────────────────────────────── */
#tfq-questionnaire,
#tfq-questionnaire * {
  box-sizing: border-box !important;
  font-family: 'Inter', system-ui, sans-serif !important;
}
#tfq-questionnaire {
  max-width: 700px !important;
  margin: 0 auto !important;
  padding: 0 1rem 3rem !important;
  color: #1a1a1a !important;
  background: transparent !important;
  -webkit-font-smoothing: antialiased !important;
}

/* ── PROGRESS ─────────────────────────────────────────── */
#tfq-questionnaire .tfq-progress-wrap {
  height: 6px !important;
  background: #e2e8f0 !important;
  border-radius: 99px !important;
  margin-bottom: 0.5rem !important;
  overflow: hidden !important;
  border: none !important;
  box-shadow: none !important;
}
#tfq-questionnaire .tfq-progress-bar {
  height: 100% !important;
  background: linear-gradient(90deg, #0d1f3c 0%, #b8902a 100%) !important;
  border-radius: 99px !important;
  transition: width 0.45s ease !important;
  border: none !important;
}
#tfq-questionnaire .tfq-progress-label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: #64748b !important;
  text-align: center !important;
  margin-bottom: 2rem !important;
  display: block !important;
}

/* ── STEPS ────────────────────────────────────────────── */
#tfq-questionnaire .tfq-step {
  display: none !important;
  animation: tfqSlideUp 0.32s ease !important;
}
#tfq-questionnaire .tfq-step.active {
  display: block !important;
}
@keyframes tfqSlideUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── STEP HEADER ──────────────────────────────────────── */
#tfq-questionnaire .tfq-step-icon {
  font-size: 2.4rem !important;
  line-height: 1 !important;
  margin-bottom: 0.75rem !important;
  display: block !important;
}
#tfq-questionnaire .tfq-step-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: clamp(1.4rem, 3.5vw, 2rem) !important;
  font-weight: 800 !important;
  color: #0d1f3c !important;
  line-height: 1.18 !important;
  margin: 0 0 0.85rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  text-align: left !important;
}
#tfq-questionnaire .tfq-step-sub {
  font-size: 0.95rem !important;
  color: #4a5568 !important;
  line-height: 1.72 !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}

/* ── FORM INPUTS ──────────────────────────────────────── */
#tfq-questionnaire .tfq-field-group {
  margin-bottom: 1.25rem !important;
}
#tfq-questionnaire .tfq-label {
  display: block !important;
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  color: #1a1a1a !important;
  margin-bottom: 0.4rem !important;
  background: none !important;
}
#tfq-questionnaire .tfq-req {
  color: #c0392b !important;
  margin-left: 2px !important;
}
#tfq-questionnaire .tfq-opt {
  color: #94a3b8 !important;
  font-weight: 400 !important;
  font-size: 0.8rem !important;
}
#tfq-questionnaire .tfq-field-note {
  font-size: 0.83rem !important;
  color: #4a5568 !important;
  line-height: 1.6 !important;
  margin: 0.25rem 0 0.85rem !important;
  padding: 0.65rem 1rem !important;
  background: #fdf6e8 !important;
  border-left: 3px solid #b8902a !important;
  border-radius: 0 4px 4px 0 !important;
  border-top: none !important;
  border-right: none !important;
  border-bottom: none !important;
}
#tfq-questionnaire .tfq-input,
#tfq-questionnaire .tfq-select,
#tfq-questionnaire .tfq-textarea {
  width: 100% !important;
  padding: 12px 14px !important;
  border: 2px solid #cbd5e1 !important;
  border-radius: 6px !important;
  font-size: 0.95rem !important;
  font-weight: 400 !important;
  color: #1a1a1a !important;
  background: #ffffff !important;
  outline: none !important;
  transition: border-color 0.15s !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06) !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
#tfq-questionnaire .tfq-input:focus,
#tfq-questionnaire .tfq-select:focus,
#tfq-questionnaire .tfq-textarea:focus {
  border-color: #b8902a !important;
  box-shadow: 0 0 0 3px rgba(184,144,42,0.15) !important;
}
#tfq-questionnaire .tfq-input.tfq-invalid,
#tfq-questionnaire .tfq-select.tfq-invalid {
  border-color: #c0392b !important;
  box-shadow: 0 0 0 3px rgba(192,57,43,0.12) !important;
}
#tfq-questionnaire .tfq-textarea {
  resize: vertical !important;
  min-height: 100px !important;
}
#tfq-questionnaire .tfq-select {
  cursor: pointer !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a5568' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding-right: 36px !important;
}

/* ── OPTION CARDS (single-select) ─────────────────────── */
#tfq-questionnaire .tfq-option-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0.85rem !important;
  margin-bottom: 1.25rem !important;
}
#tfq-questionnaire .tfq-option {
  /* Force light background — fully override any theme blue */
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 0.3rem !important;
  padding: 1.1rem 1.2rem !important;
  background-color: #ffffff !important;
  background-image: none !important;
  border: 2px solid #cbd5e1 !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  text-align: left !important;
  transition: border-color 0.15s, box-shadow 0.15s, background-color 0.15s !important;
  width: 100% !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  /* Reset any theme styles */
  text-transform: none !important;
  letter-spacing: normal !important;
  text-decoration: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}
#tfq-questionnaire .tfq-option:hover {
  background-color: #fdf6e8 !important;
  border-color: #b8902a !important;
  box-shadow: 0 3px 12px rgba(184,144,42,0.18) !important;
  transform: translateY(-2px) !important;
}
#tfq-questionnaire .tfq-option.selected {
  background-color: #f0f4ff !important;
  border-color: #0d1f3c !important;
  box-shadow: 0 0 0 3px rgba(13,31,60,0.15) !important;
}
#tfq-questionnaire .tfq-option.selected .tfq-opt-label {
  color: #0d1f3c !important;
}
#tfq-questionnaire .tfq-opt-icon {
  font-size: 1.5rem !important;
  line-height: 1 !important;
  margin-bottom: 0.1rem !important;
  display: block !important;
}
#tfq-questionnaire .tfq-opt-label {
  font-size: 0.93rem !important;
  font-weight: 700 !important;
  color: #0d1f3c !important;
  line-height: 1.3 !important;
  display: block !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
#tfq-questionnaire .tfq-opt-sub {
  font-size: 0.78rem !important;
  color: #64748b !important;
  line-height: 1.5 !important;
  display: block !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ── CHECKBOX GRID (multi-select) ─────────────────────── */
#tfq-questionnaire .tfq-checkbox-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0.65rem !important;
  margin-bottom: 1.5rem !important;
}
#tfq-questionnaire .tfq-checkbox-item {
  display: flex !important;
  align-items: center !important;
  gap: 0.65rem !important;
  padding: 0.8rem 1rem !important;
  background: #ffffff !important;
  border: 2px solid #cbd5e1 !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  font-size: 0.88rem !important;
  font-weight: 500 !important;
  color: #1a1a1a !important;
  transition: border-color 0.15s, background 0.15s !important;
  line-height: 1.4 !important;
}
#tfq-questionnaire .tfq-checkbox-item:hover {
  border-color: #b8902a !important;
  background: #fdf6e8 !important;
}
#tfq-questionnaire .tfq-checkbox-item input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  accent-color: #0d1f3c !important;
  cursor: pointer !important;
}
#tfq-questionnaire .tfq-checkbox-item:has(input:checked) {
  border-color: #0d1f3c !important;
  background: #f0f4ff !important;
}
#tfq-questionnaire .tfq-checkbox-item span {
  color: #1a1a1a !important;
  background: none !important;
}

/* ── CALLOUT BOX ──────────────────────────────────────── */
#tfq-questionnaire .tfq-callout {
  background: #fdf6e8 !important;
  border: 1.5px solid #c49a3c !important;
  border-radius: 6px !important;
  padding: 1rem 1.25rem !important;
  font-size: 0.9rem !important;
  color: #3a2800 !important;
  line-height: 1.68 !important;
  margin-bottom: 1.25rem !important;
}
#tfq-questionnaire .tfq-callout strong {
  color: #0d1f3c !important;
  font-weight: 700 !important;
}

/* ── RESULTS PANEL ────────────────────────────────────── */
#tfq-questionnaire .tfq-results-panel {
  background: #f8f9fa !important;
  border: 2px solid #e2e8f0 !important;
  border-radius: 10px !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}
#tfq-questionnaire .tfq-results-panel h3 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.2rem !important;
  font-weight: 800 !important;
  color: #0d1f3c !important;
  margin: 0 0 0.75rem !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}
#tfq-questionnaire .tfq-result-item {
  display: flex !important;
  gap: 0.85rem !important;
  align-items: flex-start !important;
  padding: 0.85rem 1rem !important;
  background: #ffffff !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 6px !important;
  margin-bottom: 0.65rem !important;
  border-left: 4px solid #b8902a !important;
}
#tfq-questionnaire .tfq-result-item:last-child {
  margin-bottom: 0 !important;
}
#tfq-questionnaire .tfq-result-icon {
  font-size: 1.3rem !important;
  flex-shrink: 0 !important;
  margin-top: 1px !important;
}
#tfq-questionnaire .tfq-result-text strong {
  display: block !important;
  font-size: 0.92rem !important;
  font-weight: 700 !important;
  color: #0d1f3c !important;
  margin-bottom: 0.2rem !important;
}
#tfq-questionnaire .tfq-result-text span {
  font-size: 0.84rem !important;
  color: #4a5568 !important;
  line-height: 1.6 !important;
  display: block !important;
}
#tfq-questionnaire .tfq-email-gate {
  background: #0d1f3c !important;
  border-radius: 8px !important;
  padding: 1.5rem !important;
  text-align: center !important;
  margin-bottom: 1rem !important;
}
#tfq-questionnaire .tfq-email-gate h3 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.15rem !important;
  font-weight: 800 !important;
  color: #ffffff !important;
  margin: 0 0 0.4rem !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}
#tfq-questionnaire .tfq-email-gate p {
  font-size: 0.88rem !important;
  color: rgba(255,255,255,0.65) !important;
  margin: 0 0 1.1rem !important;
  line-height: 1.6 !important;
}
#tfq-questionnaire .tfq-email-row {
  display: flex !important;
  gap: 0.5rem !important;
  flex-wrap: wrap !important;
}
#tfq-questionnaire .tfq-email-row .tfq-input {
  flex: 1 !important;
  min-width: 200px !important;
  background: #ffffff !important;
  border: 2px solid transparent !important;
}
#tfq-questionnaire .tfq-email-row .tfq-input:focus {
  border-color: #b8902a !important;
}

/* ── BUTTONS ──────────────────────────────────────────── */
#tfq-questionnaire .tfq-btn-next,
#tfq-questionnaire .tfq-btn-submit,
#tfq-questionnaire .tfq-btn-reveal {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #0d1f3c !important;
  background-image: none !important;
  color: #ffffff !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.02em !important;
  padding: 13px 26px !important;
  border: none !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  transition: background 0.15s, transform 0.1s !important;
  width: 100% !important;
  margin-top: 0.5rem !important;
  text-transform: none !important;
  text-decoration: none !important;
  box-shadow: 0 2px 8px rgba(13,31,60,0.25) !important;
  line-height: 1.4 !important;
}
#tfq-questionnaire .tfq-btn-next:hover,
#tfq-questionnaire .tfq-btn-submit:hover,
#tfq-questionnaire .tfq-btn-reveal:hover {
  background: #162840 !important;
  transform: translateY(-1px) !important;
  color: #ffffff !important;
}
#tfq-questionnaire .tfq-btn-submit,
#tfq-questionnaire .tfq-btn-reveal {
  background: #b8902a !important;
  font-size: 1rem !important;
  padding: 15px 26px !important;
}
#tfq-questionnaire .tfq-btn-submit:hover,
#tfq-questionnaire .tfq-btn-reveal:hover {
  background: #9a7520 !important;
}
#tfq-questionnaire .tfq-btn-submit:disabled {
  opacity: 0.6 !important;
  cursor: not-allowed !important;
  transform: none !important;
}
#tfq-questionnaire .tfq-btn-back {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  background: transparent !important;
  background-image: none !important;
  border: 2px solid #cbd5e1 !important;
  border-radius: 5px !important;
  color: #4a5568 !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  padding: 9px 16px !important;
  cursor: pointer !important;
  transition: border-color 0.15s, color 0.15s !important;
  text-transform: none !important;
  text-decoration: none !important;
  letter-spacing: normal !important;
  box-shadow: none !important;
}
#tfq-questionnaire .tfq-btn-back:hover {
  border-color: #0d1f3c !important;
  color: #0d1f3c !important;
  background: transparent !important;
}
#tfq-questionnaire .tfq-btn-calendly {
  display: inline-block !important;
  background: #b8902a !important;
  background-image: none !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  padding: 14px 28px !important;
  border-radius: 5px !important;
  text-decoration: none !important;
  transition: background 0.15s !important;
  margin-top: 0.5rem !important;
  display: block !important;
  text-align: center !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(184,144,42,0.3) !important;
}
#tfq-questionnaire .tfq-btn-calendly:hover {
  background: #9a7520 !important;
  color: #ffffff !important;
  text-decoration: none !important;
}

/* ── NAV BAR ──────────────────────────────────────────── */
#tfq-questionnaire .tfq-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-top: 1.5rem !important;
  padding-top: 1.25rem !important;
  border-top: 1px solid #e2e8f0 !important;
  background: none !important;
}
#tfq-questionnaire .tfq-step-dots {
  display: flex !important;
  gap: 6px !important;
  justify-content: center !important;
  flex: 1 !important;
}
#tfq-questionnaire .tfq-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: #cbd5e1 !important;
  transition: background 0.2s !important;
  display: inline-block !important;
}
#tfq-questionnaire .tfq-dot.active {
  background: #0d1f3c !important;
  width: 20px !important;
  border-radius: 4px !important;
}

/* ── ERROR / DISCLAIMER ───────────────────────────────── */
#tfq-questionnaire .tfq-error {
  background: #fff5f5 !important;
  border: 2px solid #e8c0bc !important;
  border-radius: 6px !important;
  padding: 0.9rem 1rem !important;
  font-size: 0.9rem !important;
  color: #9b1c1c !important;
  margin-top: 0.75rem !important;
  line-height: 1.6 !important;
}
#tfq-questionnaire .tfq-disclaimer {
  font-size: 0.74rem !important;
  color: #94a3b8 !important;
  line-height: 1.6 !important;
  margin-bottom: 1rem !important;
  padding: 0.75rem 1rem !important;
  background: #f8f9fa !important;
  border-radius: 4px !important;
  border: 1px solid #e2e8f0 !important;
}

/* ── SUCCESS SCREEN ───────────────────────────────────── */
#tfq-questionnaire .tfq-step[data-step="success"] {
  text-align: center !important;
}
#tfq-questionnaire .tfq-success-box {
  background: #f0fdf4 !important;
  border: 2px solid #86efac !important;
  border-radius: 10px !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}
#tfq-questionnaire .tfq-success-box p {
  font-size: 0.93rem !important;
  color: #14532d !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}

/* ── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 560px) {
  #tfq-questionnaire .tfq-option-grid,
  #tfq-questionnaire .tfq-checkbox-grid {
    grid-template-columns: 1fr !important;
  }
  #tfq-questionnaire .tfq-step-title {
    font-size: 1.3rem !important;
  }
  #tfq-questionnaire .tfq-email-row {
    flex-direction: column !important;
  }
  #tfq-questionnaire .tfq-email-row .tfq-input {
    min-width: 0 !important;
  }
}


/* ═══════════════════════════════════════════════════════════
   NUCLEAR OVERRIDE — Force all text colors inside cards
   These rules must come LAST to win the specificity war
═══════════════════════════════════════════════════════════ */

/* Force card backgrounds WHITE regardless of theme */
#tfq-questionnaire div.tfq-option,
#tfq-questionnaire .tfq-option[role='button'],
div#tfq-questionnaire .tfq-option {
  background-color: #ffffff !important;
  background: #ffffff !important;
  background-image: none !important;
  color: #1a1a1a !important;
  border: 2px solid #cbd5e1 !important;
}

/* Force ALL text inside option cards to be readable dark colors */
#tfq-questionnaire .tfq-option *,
#tfq-questionnaire .tfq-option span,
#tfq-questionnaire .tfq-option .tfq-opt-icon,
#tfq-questionnaire .tfq-option .tfq-opt-label,
#tfq-questionnaire .tfq-option .tfq-opt-sub,
div#tfq-questionnaire div.tfq-option span {
  color: #1a1a1a !important;
  background: transparent !important;
  background-color: transparent !important;
}

/* Specific overrides for label and sub */
#tfq-questionnaire .tfq-opt-label {
  color: #0d1f3c !important;
  font-weight: 700 !important;
}
#tfq-questionnaire .tfq-opt-sub {
  color: #4a5568 !important;
  font-size: 0.78rem !important;
}
#tfq-questionnaire .tfq-opt-icon {
  color: inherit !important;
  font-size: 1.5rem !important;
  display: block !important;
}

/* Hover state — gold tint, still readable */
#tfq-questionnaire .tfq-option:hover,
#tfq-questionnaire div.tfq-option:hover,
#tfq-questionnaire .tfq-option[role='button']:hover {
  background-color: #fdf6e8 !important;
  background: #fdf6e8 !important;
  border-color: #b8902a !important;
}
#tfq-questionnaire .tfq-option:hover *,
#tfq-questionnaire .tfq-option:hover span {
  color: #1a1a1a !important;
}

/* Selected state — light navy tint */
#tfq-questionnaire .tfq-option.selected,
#tfq-questionnaire div.tfq-option.selected,
#tfq-questionnaire .tfq-option.selected {
  background-color: #f0f4ff !important;
  background: #f0f4ff !important;
  border-color: #0d1f3c !important;
  box-shadow: 0 0 0 3px rgba(13,31,60,0.12) !important;
}
#tfq-questionnaire .tfq-option.selected *,
#tfq-questionnaire .tfq-option.selected span {
  color: #0d1f3c !important;
}

/* Checkbox items - force white background and dark text */
#tfq-questionnaire label.tfq-checkbox-item {
  background-color: #ffffff !important;
  background: #ffffff !important;
  color: #1a1a1a !important;
  border: 2px solid #cbd5e1 !important;
}
#tfq-questionnaire label.tfq-checkbox-item span,
#tfq-questionnaire .tfq-checkbox-item span {
  color: #1a1a1a !important;
  background: transparent !important;
}
#tfq-questionnaire label.tfq-checkbox-item:hover {
  background-color: #fdf6e8 !important;
  border-color: #b8902a !important;
}

/* Result items */
#tfq-questionnaire .tfq-result-item {
  background: #ffffff !important;
  border: 1.5px solid #e2e8f0 !important;
  border-left: 4px solid #b8902a !important;
}
#tfq-questionnaire .tfq-result-text strong {
  color: #0d1f3c !important;
  display: block !important;
}
#tfq-questionnaire .tfq-result-text span {
  color: #4a5568 !important;
}
