/* Custom Demo Form — CSS (CC&JS Pro snippet 263397) */
/* External-linked; loads in header. Targets the form mounted at #gsp-cf-mount. */

#gsp-cf-page{max-width:560px;margin:32px auto 40px;padding:0 20px;font-family:Inter,system-ui,sans-serif;color:#1a1a2e}
.gsp-cf-badge{display:inline-flex;align-items:center;gap:6px;background:#e8f0fe;color:#1a3a8f;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:20px;margin-bottom:12px}
.gsp-cf-badge svg{width:12px;height:12px}
#gsp-cf-page h1{font-size:24px;font-weight:700;color:#1a1a2e;margin:0 0 5px;line-height:1.25}
.gsp-cf-sub{font-size:14px;color:#666;margin:0 0 20px;line-height:1.5}

/* Progress indicator */
.gsp-progress{display:flex;align-items:center;gap:8px;margin:0 0 18px}
.gsp-progress-dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb;transition:background .2s}
.gsp-progress-dot.active{background:#1a3a8f}
.gsp-progress-dot.done{background:#1a3a8f}
.gsp-progress-label{font-size:12px;color:#6b7280;font-weight:600;letter-spacing:.02em}

/* Step containers */
.gsp-step{display:none;animation:gspFadeSlide .25s ease-out}
.gsp-step.active{display:block}
@keyframes gspFadeSlide{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}

/* Field rows / layout */
.gsp-cf-row{display:flex;gap:12px}
.gsp-cf-row .gsp-cf-field{flex:1}
.gsp-cf-field{margin-bottom:14px}
.gsp-cf-field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:4px}

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

.gsp-cf-field input{width:100%;padding:11px 36px 11px 12px;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:44px}
.gsp-cf-field input:focus{border-color:#1a3a8f;box-shadow:0 0 0 3px rgba(26,58,143,.12)}
.gsp-cf-field input:focus-visible{outline:2px solid transparent}
.gsp-cf-field.ok input{border-color:#16a34a}
.gsp-cf-field.err input{border-color:#dc2626}
.gsp-cf-field.err input:focus{box-shadow:0 0 0 3px rgba(220,38,38,.1)}

/* Phone: flag + dial-code prefix */
.gsp-phone-wrap{display:flex;gap:8px;align-items:flex-start}
.gsp-phone-prefix{display:flex;align-items:center;gap:6px;padding:10px 12px;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:44px}
.gsp-phone-prefix:focus{outline:none;border-color:#1a3a8f;box-shadow:0 0 0 3px rgba(26,58,143,.12)}
.gsp-phone-prefix:focus-visible{outline:2px solid #1a3a8f;outline-offset:1px}
.gsp-phone-prefix svg{width:10px;height:10px;color:#6b7280;flex-shrink:0}
.gsp-phone-input-wrap{flex:1;position:relative}
.gsp-phone-input-wrap input{width:100%;box-sizing:border-box}

/* Country dropdown with search */
.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-country-drop.open{display:flex}
.gsp-country-search{padding:8px 10px;border-bottom:1px solid #e5e7eb;flex-shrink:0}
.gsp-country-search input{width:100%;padding:7px 10px;border:1px solid #d1d5db;border-radius:5px;font-size:13px;outline:none;box-sizing:border-box;min-height:34px}
.gsp-country-search input:focus{border-color:#1a3a8f}
.gsp-country-list{overflow-y:auto;flex:1;max-height:220px}
.gsp-country-option{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:14px;color:#374151;cursor:pointer;transition:background .1s}
.gsp-country-option:hover,.gsp-country-option.kb-focused{background:#f5f8ff}
.gsp-country-option.selected{background:#eef2fd;font-weight:600}
.gsp-country-option .gsp-country-flag{font-size:18px;line-height:1}
.gsp-country-option .gsp-country-dial{color:#9ca3af;margin-left:auto;font-size:13px}
.gsp-country-empty{padding:14px;color:#9ca3af;font-size:13px;text-align:center}

/* Helper text + URL hint */
.gsp-url-hint{font-size:11px;color:#6b7280;margin-top:3px;display:none}
.gsp-url-hint.show{display:block}
.gsp-url-hint strong{color:#374151}

.gsp-cf-errmsg{font-size:12px;color:#dc2626;margin-top:4px;display:none}
.gsp-cf-field.err .gsp-cf-errmsg{display:block}
.gsp-cf-helptxt{font-size:12px;color:#6b7280;margin-top:3px}

/* Email typo suggestion */
.gsp-email-typo{font-size:13px;color:#1a3a8f;margin-top:5px;display:none}
.gsp-email-typo.show{display:block}
.gsp-email-typo button{background:none;border:none;color:#1a3a8f;text-decoration:underline;cursor:pointer;font:inherit;padding:0;font-weight:600}
.gsp-email-typo button:hover{color:#142d72}

/* Team size chips (role=radiogroup) */
.gsp-chips-label{font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
.gsp-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.gsp-chip{padding:9px 14px;border:1.5px solid #d1d5db;border-radius:100px;font-size:14px;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:38px}
.gsp-chip:hover{border-color:#1a3a8f;color:#1a3a8f;background:#f5f8ff}
.gsp-chip[aria-checked="true"]{border-color:#1a3a8f;background:#1a3a8f;color:#fff;font-weight:600}
.gsp-chip:focus-visible{outline:2px solid #1a3a8f;outline-offset:2px}
.gsp-chips-errmsg{font-size:12px;color:#dc2626;margin-top:2px;display:none}
.gsp-chips.err .gsp-chips-errmsg{display:block}

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

/* Buttons row (step 2 has Back + Submit) */
.gsp-cf-actions{display:flex;gap:10px;margin-top:6px}
.gsp-cf-btn-primary{flex:1;padding:14px;background:#1a3a8f;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;font-family:Inter,system-ui,sans-serif;cursor:pointer;transition:background .18s,transform .12s;min-height:48px}
.gsp-cf-btn-primary:hover{background:#142d72;transform:translateY(-1px)}
.gsp-cf-btn-primary:active{transform:translateY(0)}
.gsp-cf-btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}
.gsp-cf-btn-primary:focus-visible{outline:3px solid rgba(26,58,143,.4);outline-offset:2px}
.gsp-cf-btn-secondary{padding:14px 18px;background:#fff;color:#1a3a8f;border:1.5px solid #d1d5db;border-radius:8px;font-size:15px;font-weight:600;font-family:Inter,system-ui,sans-serif;cursor:pointer;transition:border-color .15s,background .15s;min-height:48px}
.gsp-cf-btn-secondary:hover{border-color:#1a3a8f;background:#f5f8ff}
.gsp-cf-btn-secondary:focus-visible{outline:2px solid #1a3a8f;outline-offset:2px}

/* Trust strip */
.gsp-trust{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:#6b7280;margin:12px 0 4px;text-align:center}
.gsp-trust svg{width:14px;height:14px;color:#16a34a;flex-shrink:0}

/* API status banner */
.gsp-api-status{font-size:13px;margin-top:10px;padding:9px 12px;border-radius:6px;display:none}
.gsp-api-status.ok{display:block;background:#d1fae5;color:#065f46}
.gsp-api-status.fail{display:block;background:#fee2e2;color:#991b1b}

.gsp-cf-footnote{font-size:11px;color:#9ca3af;text-align:center;margin-top:14px}
.gsp-cf-footnote span{background:#f3f4f6;border-radius:4px;padding:2px 6px;font-weight:600;color:#6b7280;font-family:monospace;font-size:10px}

/* Honeypot — hidden from real users + screen-readers */
.gsp-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}

/* Thank-you card */
.gsp-ty{display:none;flex-direction:column;align-items:center;text-align:center;padding:44px 24px 36px}
.gsp-ty.show{display:flex}
.gsp-ty-icon{width:64px;height:64px;border-radius:50%;background:#e8f0fe;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.gsp-ty-icon svg{width:32px;height:32px}
.gsp-ty h2{font-size:24px;font-weight:700;color:#1a1a2e;margin:0 0 10px;line-height:1.25}
.gsp-ty p{font-size:15px;color:#555;margin:0 0 28px;line-height:1.55;max-width:300px}
.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-open-btn:hover{background:#142d72;transform:translateY(-1px)}
.gsp-open-btn svg{width:18px;height:18px;flex-shrink:0}
.gsp-ty-note{font-size:12px;color:#aaa;margin-top:14px}

/* Visually-hidden helper for ARIA labels */
.gsp-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Mobile */
@media(max-width:480px){
  #gsp-cf-page{padding:0 16px;margin:24px auto 32px}
  .gsp-cf-row{flex-direction:column;gap:0}
  .gsp-chips{gap:5px}
  .gsp-chip{padding:9px 13px;font-size:14px}
  .gsp-cf-actions{flex-direction:column-reverse}
  .gsp-country-drop{min-width:240px}
}
