/* ══════════════════════════════════════════════
   Contact Pro v3.4 – Frontend
   All rules scoped under #ps_contactpro
   ══════════════════════════════════════════════ */

/* ── Reset / base ───────────────────────────── */
#ps_contactpro { box-sizing: border-box; font-family: var(--psc-font); color: var(--psc-text); line-height: 1.5; text-align: left; }
#ps_contactpro *, #ps_contactpro *::before, #ps_contactpro *::after { box-sizing: inherit; }

/* ── Form container ─────────────────────────── */
#ps_contactpro .psc-form-wrap { max-width: 840px; margin: 0 auto; padding: 24px 0; }
#ps_contactpro .psc-form {
  background: var(--psc-bg);
  padding: 32px 36px;
  border-radius: var(--psc-radius);
  box-shadow: var(--psc-shadow);
  border: 1px solid var(--psc-border);
  text-align: left;
}
#ps_contactpro .psc-form-title {
  font-size: 22px; font-weight: 700; color: var(--psc-text);
  margin: 0 0 20px; padding: 0; text-align: left;
}
#ps_contactpro .psc-icon { margin-right: 8px; }

/* ── Grid layout ────────────────────────────── */
#ps_contactpro .psc-grid {
  display: flex; flex-wrap: wrap; gap: 0 20px;
}
#ps_contactpro .psc-col-full  { width: 100%; }
#ps_contactpro .psc-col-half  { width: calc(50% - 10px); }
#ps_contactpro .psc-col-third { width: calc(33.333% - 14px); }
#ps_contactpro .psc-col-twothird { width: calc(66.666% - 6px); }

/* ── Field wrap ─────────────────────────────── */
#ps_contactpro .psc-field { margin-bottom: 20px; }
#ps_contactpro .psc-label {
  display: block; font-size: 13px; font-weight: 600; color: var(--psc-text);
  margin-bottom: 6px; letter-spacing: .2px; text-align: left;
}
#ps_contactpro .psc-req { color: var(--psc-danger); margin-left: 3px; font-weight: 700; }

/* ── Inputs ─────────────────────────────────── */
#ps_contactpro .psc-input {
  width: 100%; padding: 11px 16px; font-size: 14px; font-family: var(--psc-font);
  color: var(--psc-text); background: var(--psc-input-bg);
  border: 1px solid var(--psc-border); border-radius: var(--psc-radius);
  transition: border-color .2s ease, box-shadow .2s ease;
  outline: none;
}
#ps_contactpro .psc-input::placeholder { color: var(--psc-muted); }
#ps_contactpro .psc-input:focus {
  border-color: var(--psc-brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--psc-brand) 15%, transparent);
  background: var(--psc-bg);
}
#ps_contactpro .psc-textarea { min-height: 120px; resize: vertical; line-height: 1.6; }
#ps_contactpro .psc-select { appearance: auto; cursor: pointer; }

/* ── Section header ─────────────────────────── */
#ps_contactpro .psc-section {
  font-size: 15px; font-weight: 700; color: var(--psc-brand);
  padding: 6px 0 10px; margin: 6px 0 2px;
  border-bottom: 2px solid var(--psc-brand);
  letter-spacing: .3px; text-align: left;
}

/* ── HTML block ─────────────────────────────── */
#ps_contactpro .psc-html { margin-bottom: 16px; font-size: 14px; line-height: 1.7; }
#ps_contactpro .psc-html p { margin: 0 0 8px; }

/* ── Phone with prefix (searchable dropdown) ── */
#ps_contactpro .psc-tel { display: flex; gap: 8px; position: relative; }
#ps_contactpro .psc-tel-dropdown { position: relative; flex-shrink: 0; }
#ps_contactpro .psc-tel-btn {
  display: flex; align-items: center; gap: 6px; padding: 10px 14px;
  background: var(--psc-input-bg); border: 1px solid var(--psc-border); border-radius: var(--psc-radius);
  cursor: pointer; font-size: 14px; color: var(--psc-text); white-space: nowrap;
  height: 100%; min-width: 110px; transition: border-color .2s;
}
#ps_contactpro .psc-tel-btn:hover { border-color: var(--psc-brand); }
#ps_contactpro .psc-tel-flag { width: 24px; height: 16px; object-fit: cover; border-radius: 2px; flex-shrink: 0; }
#ps_contactpro .psc-tel-code { font-weight: 600; font-size: 14px; }
#ps_contactpro .psc-tel-arrow { font-size: 10px; color: var(--psc-muted); margin-left: 2px; }
#ps_contactpro .psc-tel-panel {
  position: absolute; top: 100%; left: 0; z-index: 100; margin-top: 4px;
  background: var(--psc-bg); border: 1px solid var(--psc-border); border-radius: var(--psc-radius);
  box-shadow: 0 8px 32px rgba(0,0,0,.14); width: 320px; max-height: 340px;
  display: flex; flex-direction: column; overflow: hidden;
}
#ps_contactpro .psc-tel-search {
  padding: 10px 14px; border: none; border-bottom: 1px solid var(--psc-border);
  font-size: 14px; outline: none; background: var(--psc-input-bg);
  font-family: var(--psc-font); color: var(--psc-text); width: 100%;
}
#ps_contactpro .psc-tel-search::placeholder { color: var(--psc-muted); }
#ps_contactpro .psc-tel-list { overflow-y: auto; max-height: 280px; }
#ps_contactpro .psc-tel-item {
  display: flex; align-items: center; gap: 10px; padding: 9px 14px;
  cursor: pointer; font-size: 14px; color: var(--psc-text); transition: background .15s;
}
#ps_contactpro .psc-tel-item:hover { background: color-mix(in srgb, var(--psc-brand) 8%, var(--psc-bg)); }
#ps_contactpro .psc-tel-item-flag { width: 24px; height: 16px; object-fit: cover; border-radius: 2px; flex-shrink: 0; }
#ps_contactpro .psc-tel-item-name { flex: 1; }
#ps_contactpro .psc-tel-item-code { color: var(--psc-muted); font-weight: 600; font-size: 13px; flex-shrink: 0; }
#ps_contactpro .psc-tel-num { flex: 1; }

/* ── Radio & Checkbox options ───────────────── */
#ps_contactpro .psc-radio-group { display: flex; flex-wrap: wrap; gap: 8px; }
#ps_contactpro .psc-option {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  padding: 10px 16px; border: 1px solid var(--psc-border); border-radius: var(--psc-radius);
  font-size: 14px; color: var(--psc-text); transition: border-color .2s, background .2s;
  background: var(--psc-input-bg);
}
#ps_contactpro .psc-option:hover { border-color: var(--psc-brand); }
#ps_contactpro .psc-option input { accent-color: var(--psc-brand); }
#ps_contactpro .psc-option input:checked ~ span { font-weight: 600; color: var(--psc-brand); }
#ps_contactpro .psc-checkbox-wrap { margin-bottom: 16px; }

/* ── File upload ────────────────────────────── */
#ps_contactpro .psc-file-wrap { position: relative; }
#ps_contactpro .psc-file-input { position: absolute; opacity: 0; width: 0; height: 0; }
#ps_contactpro .psc-drop-area {
  border: 2px dashed color-mix(in srgb, var(--psc-brand) 35%, transparent);
  border-radius: var(--psc-radius); padding: 28px 20px; text-align: center;
  background: color-mix(in srgb, var(--psc-brand) 3%, var(--psc-bg));
  transition: all .25s ease; cursor: pointer;
}
#ps_contactpro .psc-dropzone.psc-drag-over .psc-drop-area {
  border-color: var(--psc-brand); background: color-mix(in srgb, var(--psc-brand) 8%, var(--psc-bg));
  transform: scale(1.01);
}
#ps_contactpro .psc-drop-icon { margin-bottom: 8px; }
#ps_contactpro .psc-drop-icon svg { color: var(--psc-brand); }
#ps_contactpro .psc-drop-text { margin: 0; font-size: 15px; font-weight: 600; color: var(--psc-text); }
#ps_contactpro .psc-drop-or { margin: 6px 0; font-size: 13px; color: var(--psc-muted); }
#ps_contactpro .psc-drop-btn {
  display: inline-block; padding: 8px 20px; border-radius: var(--psc-radius);
  background: var(--psc-brand); color: #fff; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: opacity .2s;
}
#ps_contactpro .psc-drop-btn:hover { opacity: .85; }
#ps_contactpro .psc-drop-hint { margin: 10px 0 0; font-size: 12px; color: var(--psc-muted); }
#ps_contactpro .psc-file-list { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }
#ps_contactpro .psc-file-item {
  display: flex; align-items: center; gap: 10px; padding: 8px 12px;
  background: var(--psc-bg); border: 1px solid var(--psc-border); border-radius: var(--psc-radius);
  font-size: 13px;
}
#ps_contactpro .psc-file-item-icon { color: var(--psc-brand); flex-shrink: 0; }
#ps_contactpro .psc-file-item-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#ps_contactpro .psc-file-item-size { color: var(--psc-muted); font-size: 12px; flex-shrink: 0; }
#ps_contactpro .psc-file-item-remove {
  background: none; border: none; color: var(--psc-muted); cursor: pointer;
  font-size: 16px; line-height: 1; padding: 0 4px; transition: color .2s;
}
#ps_contactpro .psc-file-item-remove:hover { color: var(--psc-danger, #e53935); }
#ps_contactpro .psc-file-error { color: var(--psc-danger, #e53935); font-size: 13px; margin-top: 6px; font-weight: 500; }
#ps_contactpro .psc-muted { color: var(--psc-muted); font-size: 12px; }
#ps_contactpro .psc-progress { height: 4px; background: var(--psc-border); border-radius: 2px; margin-top: 8px; overflow: hidden; }
#ps_contactpro .psc-progress-bar { height: 100%; background: var(--psc-brand); width: 0; transition: width .3s; border-radius: 2px; }

/* ── Wizard progress ────────────────────────── */
#ps_contactpro .psc-wizard-bar { display: flex; align-items: center; justify-content: center; margin-bottom: 28px; }
#ps_contactpro .psc-dot {
  width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700;
  background: var(--psc-border); color: var(--psc-muted);
  transition: background .3s, color .3s;
}
#ps_contactpro .psc-dot-active { background: var(--psc-brand); color: #fff; }
#ps_contactpro .psc-dot-done { background: var(--psc-success); color: #fff; }
#ps_contactpro .psc-dot-line { flex: 0 0 40px; height: 3px; background: var(--psc-border); }

/* ── Buttons ────────────────────────────────── */
#ps_contactpro .psc-actions { display: flex; gap: 12px; margin-top: 24px; align-items: center; }
#ps_contactpro .psc-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 13px 32px; font-size: 15px; font-weight: 600; font-family: var(--psc-font);
  border-radius: var(--psc-btn-radius); cursor: pointer;
  transition: opacity .2s, transform .15s; text-decoration: none; line-height: 1;
}
#ps_contactpro .psc-btn:hover { opacity: .88; transform: translateY(-1px); }
#ps_contactpro .psc-btn:active { transform: translateY(0); }
#ps_contactpro .psc-btn-primary {
  background: var(--psc-btn-bg); color: var(--psc-btn-color); border: var(--psc-btn-border);
}
#ps_contactpro .psc-btn-outline {
  background: transparent; color: var(--psc-brand); border: 2px solid var(--psc-brand);
  border-radius: var(--psc-btn-radius);
}

/* ── Alerts ──────────────────────────────────── */
#ps_contactpro .psc-alert {
  padding: 16px 20px; border-radius: var(--psc-radius); margin-bottom: 20px; font-size: 14px;
}
#ps_contactpro .psc-alert ul { margin: 0; padding-left: 18px; }
#ps_contactpro .psc-alert li { margin-bottom: 4px; }
#ps_contactpro .psc-alert-success {
  background: color-mix(in srgb, var(--psc-success) 10%, white);
  color: var(--psc-success); border: 1px solid color-mix(in srgb, var(--psc-success) 25%, white);
}
#ps_contactpro .psc-alert-danger {
  background: color-mix(in srgb, var(--psc-danger) 10%, white);
  color: var(--psc-danger); border: 1px solid color-mix(in srgb, var(--psc-danger) 25%, white);
}

/* ── Block Alert (inline) ───────────────────── */
#ps_contactpro .psc-block-alert {
  margin-top: 8px; padding: 10px 14px; border-radius: var(--psc-radius);
  background: #fff3cd; color: #856404; border: 1px solid #ffc107;
  font-size: 13px; font-weight: 500; line-height: 1.5;
  animation: pscShake .4s ease;
}
#ps_contactpro .psc-btn:disabled,
#ps_contactpro .psc-btn[disabled] {
  opacity: 0.4 !important; cursor: not-allowed !important;
  pointer-events: auto !important;
}
@keyframes pscShake {
  0%,100% { transform: translateX(0); }
  20%,60% { transform: translateX(-6px); }
  40%,80% { transform: translateX(6px); }
}

/* ── reCAPTCHA ───────────────────────────────── */
#ps_contactpro .psc-recaptcha { margin: 20px 0; }

/* ── Responsive ──────────────────────────────── */
@media (max-width: 640px) {
  #ps_contactpro .psc-form { padding: 20px 18px; }
  #ps_contactpro .psc-col-half,
  #ps_contactpro .psc-col-third,
  #ps_contactpro .psc-col-twothird { width: 100%; }
  #ps_contactpro .psc-tel { flex-direction: column; }
  #ps_contactpro .psc-tel-panel { width: 100%; }
  #ps_contactpro .psc-actions { flex-direction: column; }
  #ps_contactpro .psc-btn { width: 100%; justify-content: center; }
}
