/* assets/contact.css (FULL CLEAN COPY)
 * Contact page polish (enterprise-grade)
 * - CSP-friendly: no inline styles required
 * - Improves spacing, hierarchy, focus states, status messaging
 * - Adds field-level errors, consent block, and optional anti-bot widget
 * - Keeps layout/structure intact (light-touch)
 */

/* Ensure auth chip is hidden BEFORE first paint (contact.html sets html.no-auth-flash) */
html.no-auth-flash #authAction{visibility:hidden}

/* Page sizing */
.page-contact .wrap{max-width:1040px}

/* Card: more premium spacing + subtle depth */
.page-contact .card{position:relative;padding:28px 30px;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.06)}
.page-contact .card::before{content:"";display:block;height:4px;border-radius:999px;margin-bottom:18px;background:linear-gradient(90deg, rgba(37,99,235,.9), rgba(37,99,235,.25))}

/* Typography */
.page-contact h1{margin:0;font-size:34px;line-height:1.15;letter-spacing:-.3px}
.page-contact .contact-note{margin-top:10px;max-width:80ch}
.page-contact .contact-privacy{margin-top:8px;max-width:92ch;color:#6b7280;font-size:13px}
.page-contact .contact-privacy a{text-decoration:underline}

/* Form spacing */
.page-contact .contact-form{margin-top:18px}
.page-contact .grid3{gap:16px}
.page-contact .contact-message{margin-top:12px}

/* Required marker + hints */
.page-contact .req{color:#b42318;font-weight:700;margin-left:2px}
.page-contact .hint{font-weight:550;color:#6b7280}

/* Labels + inputs */
.page-contact .lbl{font-weight:650;color:#4b5563}
.page-contact .input{border-color:#d7dde6;transition:border-color .15s ease, box-shadow .15s ease}
.page-contact .input:focus{outline:none;border-color:rgba(37,99,235,.7);box-shadow:0 0 0 4px rgba(37,99,235,.18)}
.page-contact textarea.input{resize:vertical;min-height:168px}

/* Invalid state */
.page-contact .input.is-invalid{border-color:rgba(180,35,24,.75);box-shadow:0 0 0 4px rgba(180,35,24,.12)}

/* Field errors */
.page-contact .field-error{min-height:16px;margin-top:6px;font-size:12.5px;line-height:1.35;color:#b42318}

/* Error summary */
.page-contact .form-errors{margin:0 0 14px 0;padding:12px 14px;border:1px solid rgba(180,35,24,.25);border-radius:12px;background:rgba(180,35,24,.06);color:#7a1a12}
.page-contact .form-errors ul{margin:8px 0 0 18px;padding:0}
.page-contact .form-errors li{margin:4px 0}

/* Consent block */
.page-contact .contact-consent{margin-top:14px}
.page-contact .consent-row{display:flex;gap:10px;align-items:flex-start}
.page-contact .consent-row + .consent-row{margin-top:10px}
.page-contact .check{margin-top:3px;width:16px;height:16px}
.page-contact .contact-consent a{text-decoration:underline}

/* Optional anti-bot widget */
.page-contact .turnstile-wrap{margin-top:14px;padding:12px 14px;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb}
.page-contact .turnstile-label{margin-bottom:8px}
.page-contact .turnstile-help{margin-top:10px;font-size:12.5px;color:#6b7280}

/* Actions */
.page-contact .contact-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:18px}
.page-contact .contact-actions .btn{min-width:150px}

/* Success panel */
.page-contact .contact-success{margin-top:14px;padding:12px 14px;border:1px solid rgba(6,95,70,.25);border-radius:12px;background:rgba(6,95,70,.06)}
.page-contact .success-title{font-weight:750;color:#065f46}
.page-contact .success-body{margin-top:6px;color:#064e3b}
.page-contact .success-body code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12.5px}
.page-contact .success-actions{margin-top:10px}

/* Status line */
.page-contact .contact-status{padding-top:10px;min-height:18px}
.page-contact .contact-status.is-empty{display:none}
.page-contact .contact-status.is-info{color:inherit}
.page-contact .contact-status.is-success{color:#065f46}
.page-contact .contact-status.is-error{color:#b42318}

/* Anti-spam honeypot */
.page-contact .honeypot{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}

/* Signed-in mode (rendered by contact.page.js) */
.page-contact .contact-static{width:100%;padding:12px 14px;border:0;border-radius:0;background:transparent;color:inherit;user-select:text;white-space:pre-wrap;word-break:break-word}
.page-contact .contact-input-hidden{display:none !important}

/* Screen-reader only */
.page-contact .sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}

@media (max-width:720px){
  .page-contact .card{padding:22px 18px}
  .page-contact h1{font-size:28px}
}