/* ==========================================================================
   Optinove — Contact page specific styles
   Extends /styles/legal.css
   ========================================================================== */

.ct-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.ct-info{display:flex;flex-direction:column;gap:14px}

.ct-card{
  padding:22px 24px;border:1px solid var(--bd);border-radius:var(--r3);
  background:var(--sf);display:flex;gap:16px;align-items:flex-start;
  transition:border-color .25s, transform .35s;
}
.ct-card:hover{border-color:var(--r-b);transform:translateY(-2px)}
.ct-card-ico{
  width:42px;height:42px;border-radius:var(--r2);flex-shrink:0;
  background:var(--r-s);color:var(--r);border:1px solid var(--r-b);
  display:flex;align-items:center;justify-content:center;
}
.ct-card-ico svg{width:18px;height:18px}
.ct-card-l{flex:1;min-width:0}
.ct-card-lbl{font-size:.74rem;letter-spacing:1.6px;text-transform:uppercase;color:var(--tx3);font-weight:600;margin-bottom:4px}
.ct-card-val{font-size:1.02rem;color:var(--tx);font-weight:500;line-height:1.5}
.ct-card-val a{color:inherit;transition:color .18s}
.ct-card-val a:hover{color:var(--r)}
.ct-card-sub{font-size:.85rem;color:var(--tx2);margin-top:4px;line-height:1.55}

.ct-form{
  padding:clamp(24px,3vw,36px);border:1px solid var(--bd);border-radius:var(--r3);
  background:var(--sf2);position:relative;overflow:hidden;
}
.ct-form-h{font-family:var(--f-d);font-size:1.5rem;font-weight:600;color:var(--tx);margin-bottom:6px;letter-spacing:-.3px}
.ct-form-sub{font-size:.92rem;color:var(--tx2);margin-bottom:24px;line-height:1.6}

.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fg label{font-size:.82rem;font-weight:500;color:var(--tx2);letter-spacing:.2px}
.fg label span{color:var(--r)}
.fg input,.fg textarea{
  padding:12px 14px;border:1px solid var(--bd);border-radius:var(--r2);
  background:var(--bg);color:var(--tx);font-family:inherit;font-size:.96rem;
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.fg input:focus,.fg textarea:focus{outline:none;border-color:var(--r-b);background:var(--sf3);box-shadow:0 0 0 3px var(--r-g)}
.fg input:focus-visible,.fg textarea:focus-visible{outline:none;border-color:var(--r-b);box-shadow:0 0 0 3px var(--r-g)}
/* Validation native — visible UNIQUEMENT si le champ contient un contenu invalide
   (pas affichée pour les champs vides — la validation HTML5 native s'occupe du "required") */
.fg input:user-invalid:not(:placeholder-shown),.fg textarea:user-invalid:not(:placeholder-shown){border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.12)}
.fg input:user-invalid:not(:placeholder-shown):focus,.fg textarea:user-invalid:not(:placeholder-shown):focus{box-shadow:0 0 0 3px rgba(220,38,38,.22)}
.fg input:user-valid:not(:placeholder-shown),.fg textarea:user-valid:not(:placeholder-shown){border-color:rgba(16,185,129,.45)}
.fg textarea{resize:vertical;min-height:120px;line-height:1.55}
.fcheck input:focus-visible{outline:2px solid var(--r);outline-offset:2px}

.fcheck{display:flex;gap:10px;font-size:.84rem;color:var(--tx2);align-items:flex-start;margin-bottom:18px;line-height:1.6}
.fcheck input{width:16px;height:16px;margin-top:2px;accent-color:var(--r);flex-shrink:0}
.fcheck a{color:var(--r);text-decoration:underline;text-underline-offset:2px}

.fbtn{
  width:100%;padding:14px 22px;border:none;border-radius:var(--rp);
  background:var(--r);color:#fff;font-family:inherit;font-size:.96rem;font-weight:600;
  cursor:pointer;transition:background .2s, transform .2s;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.fbtn:hover{background:var(--r-d);transform:translateY(-1px)}
.fbtn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.fstatus{margin-top:14px;font-size:.9rem;color:var(--tx2);min-height:1.2em;text-align:center;line-height:1.5;transition:color .2s}
.fstatus.ok{color:#10b981;font-weight:600}
.fstatus.err{color:#dc2626;font-weight:600}

.ct-map{
  margin-top:60px;border:1px solid var(--bd);border-radius:var(--r3);
  overflow:hidden;height:340px;background:var(--sf2);
}
.ct-map iframe{width:100%;height:100%;border:0;filter:grayscale(.25) contrast(1.05)}
[data-theme="light"] .ct-map iframe{filter:none}

@media(max-width:900px){.ct-grid{grid-template-columns:1fr}}
@media(max-width:640px){.frow{grid-template-columns:1fr}}
