/* ============ HERO CONTACT ============ */
.hero-contact{min-height:50vh;padding:120px 48px 60px}
.hero-contact .hero-num{font-size:30vw}

/* ============ SECTION CONTACT ============ */
.contact-section{padding:120px 48px;position:relative;z-index:2;background:var(--paper);color:var(--ink);box-sizing:border-box;width:100%;max-width:100%;overflow-x:hidden}
.contact-inner{box-sizing:border-box;width:100%;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1.5fr;gap:100px;align-items:start}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;box-sizing:border-box;max-width:100%}
.contact-form{box-sizing:border-box;max-width:100%;overflow:hidden}

/* COLONNE GAUCHE - COORDONNÉES */
.contact-left{position:sticky;top:120px}
.contact-info{margin-top:40px;display:flex;flex-direction:column;gap:40px}
.contact-block{border-left:2px solid var(--cyan);padding-left:20px}
.contact-block-label{font-family:'JetBrains Mono',monospace;font-size:14px;letter-spacing:0.25em;text-transform:uppercase;color:var(--rust);margin-bottom:10px}
.contact-block-value{font-size:17px;line-height:1.5;color:var(--ink);font-weight:300}
.contact-block-value a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--cyan);transition:color 0.3s}
.contact-block-value a:hover{color:var(--cyan-deep)}

/* COLONNE DROITE - FORMULAIRE */
.contact-right{display:flex;flex-direction:column;gap:32px}
.contact-text{font-size:22px;line-height:1.7;color:rgba(10,14,20,0.75);font-weight:300}
.contact-text p{margin-bottom:16px}
.contact-text em{font-style:italic;color:var(--cyan-deep)}
.contact-text strong{font-weight:600;color:var(--ink)}

/* FORMULAIRE */
.contact-form{display:flex;flex-direction:column;gap:24px;background:#fff;padding:48px;border:1px solid rgba(10,14,20,0.08);box-shadow:0 4px 30px rgba(10,14,20,0.04)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-row{display:flex;flex-direction:column;gap:8px}
.form-row label{font-family:'JetBrains Mono',monospace;font-size:14px;letter-spacing:0.2em;text-transform:uppercase;color:var(--rust);font-weight:500}
.form-row .required{color:var(--cyan-deep)}
.form-row input,.form-row select,.form-row textarea{font-family:'Fraunces',Georgia,serif;font-size:16px;font-weight:300;padding:14px 16px;border:1px solid rgba(10,14,20,0.15);background:#fafafa;color:var(--ink);transition:all 0.3s;border-radius:0}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--cyan);background:#fff;box-shadow:0 0 0 3px rgba(0,212,255,0.1)}
.form-row textarea{resize:vertical;min-height:140px;font-family:'Fraunces',Georgia,serif;line-height:1.5}
.form-row select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230099cc' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}

/* CHECKBOXES */
.form-check{display:flex;gap:14px;align-items:flex-start;padding:6px 0}
.form-check input[type="checkbox"]{width:18px;height:18px;margin-top:3px;accent-color:var(--cyan-deep);flex-shrink:0;cursor:pointer}
.form-check label{font-size:15px;line-height:1.5;color:rgba(10,14,20,0.75);cursor:pointer;font-weight:300}
.form-check label a{color:var(--cyan-deep);text-decoration:underline}
.form-check label a:hover{color:var(--ink)}
.form-check .required{color:var(--cyan-deep);font-weight:500}

/* BOUTON SUBMIT */
.contact-submit{display:inline-flex;align-items:center;justify-content:center;gap:16px;font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--paper);background:var(--ink);padding:22px 40px;border:none;cursor:pointer;transition:all 0.3s;margin-top:12px;position:relative;overflow:hidden;font-weight:500}
.contact-submit::before{content:'';position:absolute;inset:0;background:var(--cyan);transform:translateY(100%);transition:transform 0.4s ease;z-index:0;;color:#000}
.contact-submit:hover::before{transform:translateY(0);}
.contact-submit span{transition:transform 0.3s;position:relative;z-index:1}
.contact-submit:hover{color:var(--ink)}
.contact-submit:hover span{transform:translateX(8px);color:#000}
.contact-submit > *{position:relative;z-index:1}

/* ALERTE */
.form-alert{padding:16px 20px;background:rgba(196,99,63,0.1);border-left:3px solid var(--rust);color:var(--rust);font-size:14px;font-family:'JetBrains Mono',monospace;letter-spacing:0.05em}

/* FOOTER FORM */
.form-footer{margin-top:32px;padding-top:32px;border-top:1px solid rgba(10,14,20,0.1)}
.form-footer p{font-size:12px;line-height:1.6;color:rgba(10,14,20,0.6);margin-bottom:12px;font-family:'JetBrains Mono',monospace;letter-spacing:0.02em}
.form-footer a{color:var(--cyan-deep);text-decoration:underline}
.form-footer a:hover{color:var(--ink)}

/* RESPONSIVE */
@media(max-width:980px){
.hero-contact{min-height:auto;padding:40px 20px 30px}
.contact-section{padding:60px 20px}
.contact-inner{grid-template-columns:1fr;gap:48px}
.contact-left{position:static}
.contact-form{padding:28px 20px}
.form-grid{grid-template-columns:1fr;gap:24px}
.contact-block-value{font-size:15px}
}