/* Custom Demo Form Single — CSS */
/* External-linked; loads in header. Targets the single-form mounted at .gsp-cf-single-mount. */
/* Compact layout — denser than v3 (matches HS reference form's density) BUT input font-size */
/* stays at 16px because iOS Safari zooms into <input> focus when font-size < 16px. */

.gsp-cf-single-mount{width:100%;display:block}
/* Card wrapper — visually separates the form from LP copy / hero content that may sit
 * adjacent to it. Subtle border + light shadow, matches the HS iframe form's container
 * treatment on /demo so the migrated pages keep a familiar visual rhythm. */
.gsp-cf-single-mount #gsp-cf-page{max-width:min(520px,100%);margin:20px auto 24px;padding:22px 20px;font-family:Inter,system-ui,sans-serif;color:#1a1a2e;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.gsp-cf-single-mount .gsp-cf-badge{display:inline-flex;align-items:center;gap:5px;background:#e8f0fe;color:#1a3a8f;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:20px;margin-bottom:10px}
.gsp-cf-single-mount .gsp-cf-badge svg{width:11px;height:11px}
.gsp-cf-single-mount h1{font-size:22px;font-weight:700;color:#1a1a2e;margin:0 0 4px;line-height:1.22}
.gsp-cf-single-mount .gsp-cf-sub{font-size:13px;color:#666;margin:0 0 14px;line-height:1.45}

.gsp-cf-single-mount .gsp-cf-row{display:flex;gap:10px}
.gsp-cf-single-mount .gsp-cf-row .gsp-cf-field{flex:1}
.gsp-cf-single-mount .gsp-cf-field{margin-bottom:10px}
.gsp-cf-single-mount .gsp-cf-field label{display:block;font-size:12px;font-weight:600;color:#374151;margin-bottom:3px}

.gsp-cf-single-mount .gsp-cf-input-wrap{position:relative}
.gsp-cf-single-mount .gsp-cf-input-wrap input{width:100%;box-sizing:border-box}
.gsp-cf-single-mount .gsp-cf-input-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:15px;height:15px;pointer-events:none;display:none}
.gsp-cf-single-mount .gsp-cf-input-icon.ok{display:block;color:#16a34a}
.gsp-cf-single-mount .gsp-cf-input-icon.bad{display:block;color:#dc2626}

/* Input padding tight, but font-size:16px is a HARD rule (iOS zoom prevention) */
.gsp-cf-single-mount .gsp-cf-field input{width:100%;padding:9px 32px 9px 11px;border:1.5px solid #d1d5db;border-radius:6px;font-size:16px;font-family:Inter,system-ui,sans-serif;color:#1a1a2e;background:#fff;box-sizing:border-box;transition:border-color .15s,box-shadow .15s;outline:none;min-height:40px}
.gsp-cf-single-mount .gsp-cf-field input:focus{border-color:#1a3a8f;box-shadow:0 0 0 3px rgba(26,58,143,.12)}
.gsp-cf-single-mount .gsp-cf-field input:focus-visible{outline:2px solid transparent}
.gsp-cf-single-mount .gsp-cf-field.ok input{border-color:#16a34a}
.gsp-cf-single-mount .gsp-cf-field.err input{border-color:#dc2626}
.gsp-cf-single-mount .gsp-cf-field.err input:focus{box-shadow:0 0 0 3px rgba(220,38,38,.1)}

.gsp-cf-single-mount .gsp-phone-wrap{display:flex;gap:6px;align-items:flex-start}
.gsp-cf-single-mount .gsp-phone-prefix{display:flex;align-items:center;gap:5px;padding:9px 10px;border:1.5px solid #d1d5db;border-radius:6px;background:#f9fafb;cursor:pointer;white-space:nowrap;font-size:14px;font-family:Inter,system-ui,sans-serif;color:#374151;transition:border-color .15s;flex-shrink:0;position:relative;user-select:none;min-height:40px}
.gsp-cf-single-mount .gsp-phone-prefix:focus{outline:none;border-color:#1a3a8f;box-shadow:0 0 0 3px rgba(26,58,143,.12)}
.gsp-cf-single-mount .gsp-phone-prefix:focus-visible{outline:2px solid #1a3a8f;outline-offset:1px}
.gsp-cf-single-mount .gsp-phone-prefix svg{width:10px;height:10px;color:#6b7280;flex-shrink:0}
.gsp-cf-single-mount .gsp-phone-input-wrap{flex:1;position:relative}
.gsp-cf-single-mount .gsp-phone-input-wrap input{width:100%;box-sizing:border-box}

.gsp-cf-single-mount .gsp-country-drop{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:999;min-width:260px;max-height:280px;display:none;flex-direction:column}
.gsp-cf-single-mount .gsp-country-drop.open{display:flex}
.gsp-cf-single-mount .gsp-country-search{padding:7px 9px;border-bottom:1px solid #e5e7eb;flex-shrink:0}
/* Country search is an <input> — keep font-size:16px so iOS Safari doesn't zoom on focus */
.gsp-cf-single-mount .gsp-country-search input{width:100%;padding:6px 10px;border:1px solid #d1d5db;border-radius:5px;font-size:16px;outline:none;box-sizing:border-box;min-height:34px}
.gsp-cf-single-mount .gsp-country-search input:focus{border-color:#1a3a8f}
.gsp-cf-single-mount .gsp-country-list{overflow-y:auto;flex:1;max-height:220px}
.gsp-cf-single-mount .gsp-country-option{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:14px;color:#374151;cursor:pointer;transition:background .1s}
.gsp-cf-single-mount .gsp-country-option:hover,.gsp-cf-single-mount .gsp-country-option.kb-focused{background:#f5f8ff}
.gsp-cf-single-mount .gsp-country-option.selected{background:#eef2fd;font-weight:600}
.gsp-cf-single-mount .gsp-country-option .gsp-country-flag{font-size:18px;line-height:1}
.gsp-cf-single-mount .gsp-country-option .gsp-country-dial{color:#9ca3af;margin-left:auto;font-size:13px}
.gsp-cf-single-mount .gsp-country-empty{padding:14px;color:#9ca3af;font-size:13px;text-align:center}

.gsp-cf-single-mount .gsp-url-hint{font-size:11px;color:#6b7280;margin-top:2px;display:none}
.gsp-cf-single-mount .gsp-url-hint.show{display:block}
.gsp-cf-single-mount .gsp-url-hint strong{color:#374151}

.gsp-cf-single-mount .gsp-cf-errmsg{font-size:11px;color:#dc2626;margin-top:3px;display:none}
.gsp-cf-single-mount .gsp-cf-field.err .gsp-cf-errmsg{display:block}

.gsp-cf-single-mount .gsp-email-typo{font-size:12px;color:#1a3a8f;margin-top:4px;display:none}
.gsp-cf-single-mount .gsp-email-typo.show{display:block}
.gsp-cf-single-mount .gsp-email-typo button{background:none;border:none;color:#1a3a8f;text-decoration:underline;cursor:pointer;font:inherit;padding:0;font-weight:600}
.gsp-cf-single-mount .gsp-email-typo button:hover{color:#142d72}

.gsp-cf-single-mount .gsp-chips-label{font-size:12px;font-weight:600;color:#374151;margin-bottom:5px}
.gsp-cf-single-mount .gsp-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.gsp-cf-single-mount .gsp-chip{padding:7px 12px;border:1.5px solid #d1d5db;border-radius:100px;font-size:13px;font-family:Inter,system-ui,sans-serif;color:#374151;background:#fff;cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap;line-height:1;min-height:34px}
.gsp-cf-single-mount .gsp-chip:hover{border-color:#1a3a8f;color:#1a3a8f;background:#f5f8ff}
.gsp-cf-single-mount .gsp-chip[aria-checked="true"]{border-color:#1a3a8f;background:#1a3a8f;color:#fff;font-weight:600}
.gsp-cf-single-mount .gsp-chip:focus-visible{outline:2px solid #1a3a8f;outline-offset:2px}
.gsp-cf-single-mount .gsp-chips-errmsg{font-size:11px;color:#dc2626;margin-top:2px;display:none}
.gsp-cf-single-mount .gsp-chips.err .gsp-chips-errmsg{display:block}

/* Help-question <select>: full native-appearance reset so the field matches our text
 * inputs (same border, padding, font, focus ring). font-size:16px is mandatory — iOS
 * Safari zooms on focus for any form control < 16px. Custom SVG chevron sits absolutely
 * positioned in front of the (now invisible) native arrow for cross-browser consistency. */
.gsp-cf-single-mount .gsp-select-wrap{position:relative;display:block}
.gsp-cf-single-mount .gsp-cf-field select{
  width:100%;
  padding:9px 34px 9px 11px;
  margin:0;
  border:1.5px solid #d1d5db;
  border-radius:6px;
  font-size:16px;
  font-family:Inter,system-ui,sans-serif;
  font-weight:400;
  line-height:1.4;
  color:#1a1a2e;
  background-color:#fff;
  background-image:none;
  box-sizing:border-box;
  transition:border-color .15s,box-shadow .15s;
  outline:none;
  min-height:40px;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
}
/* Style the placeholder option lighter so the unselected state reads as a prompt */
.gsp-cf-single-mount .gsp-cf-field select:invalid,
.gsp-cf-single-mount .gsp-cf-field select option[value=""]{color:#9ca3af}
.gsp-cf-single-mount .gsp-cf-field select option{color:#1a1a2e}
.gsp-cf-single-mount .gsp-cf-field select:focus{border-color:#1a3a8f;box-shadow:0 0 0 3px rgba(26,58,143,.12)}
.gsp-cf-single-mount .gsp-cf-field select:focus-visible{outline:2px solid transparent}
.gsp-cf-single-mount .gsp-cf-field.ok select{border-color:#16a34a}
.gsp-cf-single-mount .gsp-cf-field.err select{border-color:#dc2626}
.gsp-cf-single-mount .gsp-select-chevron{position:absolute;right:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:#6b7280;pointer-events:none;z-index:1}

.gsp-cf-single-mount .gsp-cf-radios-label{font-size:12px;font-weight:600;color:#374151;margin-bottom:5px}
.gsp-cf-single-mount .gsp-cf-radios{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.gsp-cf-single-mount .gsp-cf-radio{display:flex;align-items:center;gap:8px;cursor:pointer;padding:7px 11px;border:1.5px solid #e5e7eb;border-radius:6px;transition:border-color .12s,background .12s;min-height:36px}
.gsp-cf-single-mount .gsp-cf-radio:hover{border-color:#1a3a8f;background:#f5f8ff}
.gsp-cf-single-mount .gsp-cf-radio.selected{border-color:#1a3a8f;background:#eef2fd}
.gsp-cf-single-mount .gsp-cf-radio input{width:15px;height:15px;accent-color:#1a3a8f;flex-shrink:0;cursor:pointer}
.gsp-cf-single-mount .gsp-cf-radio input:focus-visible{outline:2px solid #1a3a8f;outline-offset:2px}
.gsp-cf-single-mount .gsp-cf-radio span{font-size:13px;color:#374151;line-height:1.3}
.gsp-cf-single-mount .gsp-cf-radios.err .gsp-cf-radios-label{color:#dc2626}
.gsp-cf-single-mount .gsp-cf-radio-errmsg{font-size:11px;color:#dc2626;margin-top:2px;display:none}
.gsp-cf-single-mount .gsp-cf-radios.err .gsp-cf-radio-errmsg{display:block}

/* Submit button — font-size 15px is fine (it's a button, not an input — no iOS zoom risk) */
.gsp-cf-single-mount .gsp-cf-btn-primary{width:100%;padding:11px;background:#1a3a8f;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;font-family:Inter,system-ui,sans-serif;cursor:pointer;transition:background .18s,transform .12s;min-height:44px;margin-top:4px}
.gsp-cf-single-mount .gsp-cf-btn-primary:hover{background:#142d72;transform:translateY(-1px)}
.gsp-cf-single-mount .gsp-cf-btn-primary:active{transform:translateY(0)}
.gsp-cf-single-mount .gsp-cf-btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}
.gsp-cf-single-mount .gsp-cf-btn-primary:focus-visible{outline:3px solid rgba(26,58,143,.4);outline-offset:2px}

.gsp-cf-single-mount .gsp-trust{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11px;color:#6b7280;margin:10px 0 4px;text-align:center}
.gsp-cf-single-mount .gsp-trust svg{width:12px;height:12px;color:#16a34a;flex-shrink:0}

.gsp-cf-single-mount .gsp-api-status{font-size:12px;margin-top:8px;padding:7px 10px;border-radius:6px;display:none}
.gsp-cf-single-mount .gsp-api-status.ok{display:block;background:#d1fae5;color:#065f46}
.gsp-cf-single-mount .gsp-api-status.fail{display:block;background:#fee2e2;color:#991b1b}

.gsp-cf-single-mount .gsp-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}

.gsp-cf-single-mount .gsp-ty{display:none;flex-direction:column;align-items:center;text-align:center;padding:44px 24px 36px}
.gsp-cf-single-mount .gsp-ty.show{display:flex}
.gsp-cf-single-mount .gsp-ty-icon{width:64px;height:64px;border-radius:50%;background:#e8f0fe;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;align-self:center;flex-shrink:0}
.gsp-cf-single-mount .gsp-ty-icon svg{width:32px;height:32px}
.gsp-cf-single-mount .gsp-ty h2{font-size:24px;font-weight:700;color:#1a1a2e;margin:0 0 10px;line-height:1.25}
.gsp-cf-single-mount .gsp-ty p{font-size:15px;color:#555;margin:0 0 28px;line-height:1.55;max-width:380px}
.gsp-cf-single-mount .gsp-open-btn{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;background:#1a3a8f;color:#fff;border:none;border-radius:8px;font-family:Inter,system-ui,sans-serif;font-size:16px;font-weight:600;cursor:pointer;transition:background .18s,transform .12s;min-height:48px}
.gsp-cf-single-mount .gsp-open-btn:hover{background:#142d72;transform:translateY(-1px)}
.gsp-cf-single-mount .gsp-open-btn svg{width:18px;height:18px;flex-shrink:0}
.gsp-cf-single-mount .gsp-ty-note{font-size:12px;color:#aaa;margin-top:14px}

@media(max-width:480px){
  .gsp-cf-single-mount #gsp-cf-page{padding:0 14px;margin:16px auto 20px}
  /* On mobile: stack email + phone (the only paired row) so each gets full width */
  .gsp-cf-single-mount .gsp-cf-row{flex-direction:column;gap:0}
  .gsp-cf-single-mount .gsp-chips{gap:4px}
  /* Slightly larger chips on mobile for thumb-friendliness, but still compact */
  .gsp-cf-single-mount .gsp-chip{padding:8px 12px;font-size:13px;min-height:36px}
  .gsp-cf-single-mount .gsp-country-drop{min-width:240px}
}
