/* ============================================================
   GMAV Technologies — Shared Contact Form + Contact Section styles
   Single source of truth, extracted from contact.html.
   Linked on every page that renders the contact section.
   ============================================================ */

/* ── CONTACT SECTION LAYOUT ── */
.contact-grid{display:grid;grid-template-columns:1fr 460px;gap:var(--sp-10);align-items:start;margin-top:var(--sp-08)}
.contact-info-desc{font-weight:300;font-size:1.125rem;color:var(--text-secondary);line-height:1.75;margin-bottom:var(--sp-08)}
.contact-detail{display:flex;align-items:flex-start;gap:var(--sp-04);margin-bottom:var(--sp-05);padding-bottom:var(--sp-05);border-bottom:1px solid var(--border-subtle)}
.contact-detail:last-of-type{border-bottom:none}
.cd-icon{width:40px;height:40px;background:var(--blue-10);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.cd-icon svg{width:18px;height:18px}
.cd-label{font-weight:600;font-size:10px;color:var(--blue-60);letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px}
.cd-val{font-weight:400;font-size:13px;color:var(--text-primary)}
.cd-val a{color:var(--blue-60);text-decoration:none}
.cd-val a:hover{text-decoration:underline}

/* ── TRUST BLOCK ── */
.trust-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:var(--sp-03)}
.trust-item{display:flex;align-items:flex-start;gap:var(--sp-03);font-size:var(--ts-01);line-height:1.4;color:var(--text-secondary)}
.trust-ic{width:18px;height:18px;flex-shrink:0;margin-top:1px}

/* ── WHAT HAPPENS NEXT ── */
.contact-next-steps{background:var(--blue-10);border:1px solid var(--blue-20);padding:var(--sp-06);margin-top:var(--sp-06)}
.cns-title{font-weight:600;font-size:10px;color:var(--blue-70);letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--sp-05)}
.cns-steps{display:flex;flex-direction:column;gap:var(--sp-04)}
.cns-step{display:flex;align-items:flex-start;gap:var(--sp-04)}
.cns-step-num{width:22px;height:22px;background:var(--blue-60);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:11px;color:#fff;flex-shrink:0;margin-top:1px}
.cns-step-text{font-weight:400;font-size:13px;color:var(--blue-80);line-height:1.55}

/* ── FORM ── */
.contact-form-wrap{background:var(--gray-10);border:1px solid var(--border-subtle);padding:var(--sp-07)}
.form-title{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--sp-02)}
.form-subtitle{font-weight:300;font-size:13px;color:var(--text-secondary);margin-bottom:var(--sp-07)}
.form-stack{display:flex;flex-direction:column;gap:var(--sp-05)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-04)}
.form-group{display:flex;flex-direction:column;gap:var(--sp-02)}
.form-label{font-weight:600;font-size:11px;color:var(--text-secondary);letter-spacing:.04em}
.input{font-family:var(--font-body);font-weight:300;font-size:var(--ts-02);color:var(--text-primary);background:#fff;border:none;border-bottom:1px solid var(--border-strong);padding:0 var(--sp-04);height:48px;outline:none;width:100%;transition:border-color .11s}
.input:focus{border-bottom:2px solid var(--blue-60)}
.input::placeholder{color:var(--text-secondary)}
.input.error{border-bottom:2px solid var(--red-60)}
.phone-group{display:flex}
.phone-country{height:48px;border:none;border-bottom:1px solid var(--border-strong);background:#fff;font-family:var(--font-body);font-size:13px;color:var(--text-primary);padding:0 var(--sp-03);width:110px;flex-shrink:0;appearance:none;outline:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23525252' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px;border-right:none;transition:border-color .11s}
.phone-country:focus{border-bottom:2px solid var(--blue-60)}
.phone-number{flex:1}
.textarea{font-family:var(--font-body);font-weight:300;font-size:var(--ts-02);color:var(--text-primary);background:#fff;border:none;border-bottom:1px solid var(--border-strong);padding:var(--sp-03) var(--sp-04);outline:none;resize:vertical;width:100%;min-height:96px;transition:border-color .11s}
.textarea:focus{border-bottom:2px solid var(--blue-60)}
.textarea.error{border-bottom:2px solid var(--red-60)}
.select-wrap{position:relative}
.select{font-family:var(--font-body);font-weight:300;font-size:var(--ts-02);color:var(--text-primary);background:#fff;border:none;border-bottom:1px solid var(--border-strong);padding:0 2.5rem 0 var(--sp-04);height:48px;outline:none;width:100%;appearance:none;cursor:pointer;transition:border-color .11s}
.select:focus{border-bottom:2px solid var(--blue-60)}
.select.error{border-bottom:2px solid var(--red-60)}
.select-chevron{position:absolute;right:var(--sp-04);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-secondary)}
.select-chevron svg{width:12px;height:12px}

/* ── NATIVE NDA CHECKBOX (visible) ── */
.form-check-native{width:18px;height:18px;accent-color:var(--blue-60);flex-shrink:0;margin-top:2px;cursor:pointer}
.form-check-native:focus-visible{outline:2px solid var(--blue-60);outline-offset:2px}
.form-check-row{display:flex;align-items:flex-start;gap:var(--sp-03);cursor:pointer;user-select:none}
.form-check-label{font-weight:400;font-size:var(--ts-01);color:var(--text-secondary);line-height:1.5}

/* ── FIELD ERRORS ── */
.field-error{font-size:11px;color:var(--red-60);display:none;margin-top:2px}
.field-error.show{display:block;font-size:11px;color:var(--red-60);margin-top:2px}

/* ── FOCUS VISIBLE + BORDER CONTRAST ── */
.input:focus-visible,.textarea:focus-visible,.select:focus-visible,.phone-country:focus-visible{outline:2px solid var(--blue-60);outline-offset:1px}
.input,.textarea,.select,.phone-country{border-bottom-color:#767676}

/* ── FILE UPLOAD ── */
.file-input{width:100%;font-family:var(--font-body);font-weight:400;font-size:var(--ts-02);color:var(--text-primary);padding:var(--sp-04) 0;border:none;border-bottom:1px solid #767676;background:transparent;cursor:pointer}
.file-input::file-selector-button{font-family:var(--font-body);font-weight:600;font-size:12px;color:var(--blue-60);background:var(--blue-10);border:1px solid var(--blue-20);padding:6px 12px;margin-right:var(--sp-04);cursor:pointer;border-radius:0;transition:background .12s}
.file-input::file-selector-button:hover{background:var(--blue-20)}
.file-input:focus-visible{outline:2px solid var(--blue-60);outline-offset:2px}
.file-hint{display:block;font-family:var(--font-body);font-weight:300;font-size:11px;color:var(--text-secondary);margin-top:var(--sp-03)}
.file-list{list-style:none;margin:var(--sp-04) 0 0;padding:0;display:flex;flex-direction:column;gap:4px}
.file-list li{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-04);font-family:var(--font-body);font-weight:400;font-size:12px;color:var(--text-primary);background:var(--gray-10);border:1px solid var(--border-subtle);padding:6px 10px}
.file-list .fl-size{color:var(--text-secondary);font-size:11px;flex-shrink:0}
.file-list li .fl-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.file-list li .fl-remove{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;font-family:var(--font-body);font-size:14px;line-height:1;color:var(--text-secondary);background:transparent;border:1px solid var(--border-subtle);cursor:pointer;border-radius:0;transition:background .12s,color .12s}
.file-list li .fl-remove:hover{background:var(--red-60);color:#fff;border-color:var(--red-60)}
.file-list li .fl-remove:focus-visible{outline:2px solid var(--blue-60);outline-offset:1px}
.file-error{display:none;margin-top:var(--sp-03)}
.file-error.show{display:block}
.file-error p{font-family:var(--font-body);font-weight:400;font-size:11px;color:var(--red-60);margin:0 0 2px}

/* ── FORM SUCCESS (inline panel, legacy) ── */
.form-success{display:none;text-align:center;padding:var(--sp-10) var(--sp-07)}
.form-success.show{display:block}
.form-success-icon{width:64px;height:64px;background:var(--green-10);border:1px solid var(--green-50);display:flex;align-items:center;justify-content:center;margin:0 auto var(--sp-06)}
.form-success-icon svg{width:28px;height:28px}
.form-success h3{font-family:var(--font-display);font-weight:700;font-size:1.375rem;color:var(--text-primary);margin-bottom:var(--sp-04)}
.form-success p{font-weight:300;font-size:var(--ts-02);color:var(--text-secondary);line-height:1.65}

/* ── SUCCESS POPUP (dialog) ── */
.cf-popup{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:var(--sp-05)}
.cf-popup.open{display:flex}
.cf-popup-backdrop{position:absolute;inset:0;background:rgba(22,22,22,.6)}
.cf-popup-card{position:relative;z-index:1;width:100%;max-width:420px;background:#fff;border:1px solid var(--border-subtle);padding:var(--sp-08) var(--sp-07);text-align:center;box-shadow:0 8px 32px rgba(0,0,0,.18)}
.cf-popup-x{position:absolute;top:var(--sp-04);right:var(--sp-04);width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:18px;line-height:1;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;border-radius:0}
.cf-popup-x:hover{color:var(--text-primary)}
.cf-popup-x:focus-visible{outline:2px solid var(--blue-60);outline-offset:1px}
.cf-popup-icon{width:56px;height:56px;margin:0 auto var(--sp-05);display:flex;align-items:center;justify-content:center;background:var(--teal-40);border-radius:50%}
.cf-popup-card h2{font-family:var(--font-display);font-weight:700;font-size:var(--ts-06);color:var(--text-primary);margin:0 0 var(--sp-03)}
.cf-popup-card p{font-family:var(--font-body);font-weight:300;font-size:var(--ts-02);color:var(--text-secondary);margin:0 0 var(--sp-06);line-height:1.5}
.cf-popup-card .btn{width:100%;justify-content:center}
.cf-popup-card h2:focus-visible{outline:2px solid var(--blue-60);outline-offset:2px}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .form-row{grid-template-columns:1fr}
  .contact-form-wrap{padding:var(--sp-06)}
}
