/* page-contact.css — CSS complet de la page */


/* ═══════════════════════════════════════
   TOKENS
═══════════════════════════════════════ */
:root {
  --navy:       #1b375f;
  --navy-dk:    #142843;
  --navy-md:    #1f3f6e;
  --gold:       #c49d74;
  --gold-dk:    #a8824f;
  --gold-lt:    #d4b48e;
  --gold-pale:  #f5ede0;
  --gold-ultra: #faf6f0;
  --gold-line:  rgba(196,157,116,.25);
  --white:      #ffffff;
  --off:        #faf9f7;
  --cream:      #f4f0ea;
  --ink:        #1a1a1a;
  --ink-md:     #3d3d3d;
  --ink-mt:     #6b7280;
  --border:     rgba(196,157,116,.18);
  --border-md:  rgba(196,157,116,.35);
  --border-navy:rgba(27,55,95,.12);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.05);
  --shadow-md:  0 8px 28px rgba(0,0,0,.09);
  --shadow-lg:  0 20px 60px rgba(27,55,95,.12);
  --r:          12px;
  --r-lg:       18px;
  --serif:      'Platypi', Georgia, serif;
  --sans:       'DM Sans', system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--ink);background:var(--off);overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:var(--sans);cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

/* ─── LAYOUT ─────────────────────────── */
.wrap    {max-width:1160px;margin:0 auto;padding:0 40px}
.wrap-md {max-width:860px;margin:0 auto;padding:0 40px}

/* ─── BOUTONS ────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:8px;border:1.5px solid transparent;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.01em;transition:all .18s;cursor:pointer;white-space:nowrap}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-dk);transform:translateY(-1px);box-shadow:0 4px 16px rgba(196,157,116,.35)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-dk);transform:translateY(-1px)}
.btn-outline-navy{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline-navy:hover{background:var(--gold-ultra);border-color:var(--gold)}
.btn-ghost-white{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.btn-ghost-white:hover{background:rgba(255,255,255,.1);color:#fff}
.btn-lg{padding:14px 28px;font-size:14px}

/* ─── NAV — bleu #1b375f ─────────────── */
.nav{background:#1b375f;border-bottom:1px solid rgba(196,157,116,.2);position:sticky;top:0;z-index:100;transition:box-shadow .2s}
.nav.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.2)}
.nav-inner{max-width:1160px;margin:0 auto;padding:12px 40px;height:auto;min-height:72px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-brand{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--gold);letter-spacing:.02em}
.nav-tagline{font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.35);text-transform:uppercase;display:block;margin-top:1px}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-link{font-size:12px;font-weight:500;color:rgba(255,255,255,.55);padding:6px 12px;border-radius:6px;transition:all .15s}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-link.active{color:#fff;font-weight:700}
.nav-phone{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--gold);padding:8px 14px;border-radius:8px;border:1.5px solid rgba(196,157,116,.4);transition:all .18s}
.nav-phone:hover{background:rgba(196,157,116,.12)}

/* ─── BREADCRUMB ─────────────────────── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--gold-line);padding:12px 0}
.breadcrumb-inner{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-mt)}
.breadcrumb-inner a{color:var(--gold-dk);transition:color .15s}
.breadcrumb-inner a:hover{color:var(--navy)}
.breadcrumb-sep{color:var(--gold);font-size:14px}
.breadcrumb-current{color:var(--navy);font-weight:600}

/* ─── PAGE HERO — fond blanc ──────────── */
.page-hero{
  background:#fff;padding:52px 0 44px;
  border-bottom:1px solid var(--gold-line);
  position:relative;overflow:hidden;
}
.page-hero::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:35%;
  background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=800&q=60&fit=crop&crop=right');
  background-size:cover;background-position:center;opacity:.1;
  mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.8) 50%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.8) 50%);
}
.page-hero-inner{position:relative;z-index:1}
.page-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--gold-pale);color:var(--gold-dk);border:1px solid var(--border-md);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:16px}
.page-h1{font-family:var(--serif);font-size:clamp(32px,4vw,50px);font-weight:700;color:var(--navy);line-height:1.08;letter-spacing:-.01em;max-width:540px}
.page-h1 em{color:var(--gold);font-style:italic}
.page-stroke{width:40px;height:3px;background:var(--gold);border-radius:2px;margin:18px 0}
.page-desc{font-size:15px;color:var(--ink-md);line-height:1.75;max-width:500px}
.page-desc strong{color:var(--navy);font-weight:600}

/* ─── CONTACT RAPIDE — 3 cartes haut ─── */
.contact-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  padding:36px 0;
}
.contact-card{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:28px 24px;text-align:center;
  transition:all .2s;box-shadow:var(--shadow-sm);
}
.contact-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.contact-card-icon{
  width:52px;height:52px;border-radius:50%;
  background:var(--navy);margin:0 auto 14px;
  display:flex;align-items:center;justify-content:center;
}
.contact-card-title{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:6px}
.contact-card-value{font-size:16px;font-weight:700;color:var(--gold-dk);margin-bottom:4px}
.contact-card-sub{font-size:12px;color:var(--ink-mt);line-height:1.5;margin-bottom:16px}
.contact-card-cta{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;color:var(--navy);
  padding:8px 18px;border-radius:8px;border:1.5px solid var(--border-navy);
  transition:all .18s;
}
.contact-card-cta:hover{background:var(--gold-pale);border-color:var(--gold);color:var(--gold-dk)}

/* ─── MAIN GRID — Formulaire + Infos ─── */
.contact-grid{
  display:grid;grid-template-columns:1fr 380px;gap:40px;
  padding:64px 0 80px;
}

/* ─── FORMULAIRE ─────────────────────── */
.form-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.form-card-header{
  background:var(--navy);padding:24px 28px;
  border-bottom:2px solid var(--gold);
}
.form-card-title{
  font-family:var(--serif);font-size:22px;font-weight:700;color:#fff;margin-bottom:4px;
}
.form-card-sub{font-size:13px;color:rgba(255,255,255,.5)}
.form-card-body{padding:28px 28px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}
.form-group-full{grid-column:span 2}
.form-label{
  font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-mt);
}
.form-req{color:var(--gold);margin-left:2px}
.form-input,
.form-select,
.form-textarea{
  padding:12px 14px;background:var(--off);
  border:1.5px solid var(--border-navy);border-radius:8px;
  font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(196,157,116,.12);
  background:#fff;
}
.form-input::placeholder,
.form-textarea::placeholder{color:var(--ink-mt)}
.form-select{color:var(--ink-md);cursor:pointer}
.form-textarea{resize:vertical;min-height:120px;line-height:1.65}

/* Radio type de travaux */
.form-radios{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
.form-radio{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:8px;border:1.5px solid var(--border-navy);
  cursor:pointer;transition:all .15s;
  font-size:13px;color:var(--ink-md);
}
.form-radio:hover{border-color:var(--gold);background:var(--gold-ultra)}
.form-radio input{accent-color:var(--gold);width:15px;height:15px;flex-shrink:0}
.form-radio.selected{border-color:var(--gold);background:var(--gold-pale);color:var(--navy);font-weight:600}

/* Budget slider */
.form-budget-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-mt);margin-top:4px}
.form-range{width:100%;accent-color:var(--gold);height:4px;cursor:pointer;margin-top:6px}

.form-submit-row{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;padding-top:8px;
  border-top:1px solid var(--border);margin-top:20px;
}
.form-notice{font-size:11px;color:var(--ink-mt);max-width:300px;line-height:1.5}
.form-notice svg{display:inline-block;vertical-align:middle;margin-right:4px}

/* ─── SIDEBAR INFOS ──────────────────── */
.contact-sidebar{display:flex;flex-direction:column;gap:16px}

/* Card info */
.info-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.info-card-header{
  background:var(--navy);padding:18px 22px;
  border-bottom:2px solid var(--gold);
}
.info-card-title{
  font-family:var(--serif);font-size:18px;font-weight:700;
  color:var(--gold-lt);
}
.info-card-body{padding:20px 22px;display:flex;flex-direction:column;gap:16px}

.info-row{display:flex;align-items:flex-start;gap:12px}
.info-icon{
  width:36px;height:36px;border-radius:8px;
  background:var(--gold-pale);border:1px solid var(--border-md);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.info-content{}
.info-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mt);margin-bottom:2px}
.info-value{font-size:14px;font-weight:600;color:var(--navy)}
.info-sub{font-size:12px;color:var(--ink-mt);margin-top:2px;line-height:1.5}
.info-link{color:var(--gold-dk);transition:color .15s}
.info-link:hover{color:var(--navy)}

/* Horaires */
.horaires-grid{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.horaire-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.horaire-row:last-child{border-bottom:none}
.horaire-day{color:var(--ink-md);font-weight:500}
.horaire-time{color:var(--navy);font-weight:600}
.horaire-time.closed{color:var(--ink-mt);font-weight:400}

/* Card EEAT Damien */
.eeat-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:22px;box-shadow:var(--shadow-sm);
}
.eeat-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.eeat-avatar{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--navy-md));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--serif);font-size:20px;font-weight:700;flex-shrink:0;
}
.eeat-name{font-weight:700;color:var(--navy);font-size:15px}
.eeat-role{font-size:12px;color:var(--ink-mt)}
.eeat-body{font-size:13px;color:var(--ink-md);line-height:1.75;margin-bottom:14px}
.eeat-body strong{color:var(--navy);font-weight:600}
.eeat-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.eeat-stat{background:var(--off);border-radius:8px;padding:10px;text-align:center;border:1px solid var(--border)}
.eeat-stat-num{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--navy);display:block;line-height:1}
.eeat-stat-lbl{font-size:10px;color:var(--ink-mt);margin-top:3px}

/* Zone mini */
.zone-mini{
  background:var(--navy);border-radius:var(--r-lg);
  padding:20px 22px;
}
.zone-mini-title{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--gold-lt);margin-bottom:8px}
.zone-mini-tags{display:flex;flex-wrap:wrap;gap:5px}
.zone-mini-tag{font-size:11px;font-weight:600;padding:4px 11px;border:1px solid rgba(196,157,116,.3);color:rgba(255,255,255,.58);border-radius:6px}

/* ─── SUCCESS MESSAGE ────────────────── */
.form-success{
  display:none;text-align:center;padding:40px 20px;
}
.form-success-icon{
  width:64px;height:64px;border-radius:50%;
  background:var(--gold-pale);border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:28px;
}
.form-success-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--navy);margin-bottom:8px}
.form-success-sub{font-size:14px;color:var(--ink-mt);line-height:1.7}

/* ─── FOOTER ─────────────────────────── */
.footer{background:var(--navy-dk);border-top:2px solid var(--gold-line)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;padding:52px 0 40px}
.footer-brand{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--gold-lt);margin-bottom:4px}
.footer-tagline{font-size:11px;color:rgba(255,255,255,.28);font-style:italic;margin-bottom:14px}
.footer-about{font-size:13px;color:rgba(255,255,255,.32);line-height:1.8}
.footer-head{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.32);transition:color .15s}
.footer-links a:hover{color:var(--gold-lt)}
.footer-contact-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.32);line-height:1.65;margin-bottom:10px}
.footer-contact-row a{color:rgba(255,255,255,.32);transition:color .15s}
.footer-contact-row a:hover{color:var(--gold-lt)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:16px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}
.footer-copy{font-size:11px;color:rgba(255,255,255,.2)}
.footer-legal a{font-size:11px;color:rgba(255,255,255,.2);transition:color .15s}
.footer-legal a:hover{color:var(--gold)}

/* ─── FLOAT ──────────────────────────── */
.float-call{display:none;position:fixed;bottom:16px;right:14px;z-index:999;background:var(--gold);color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(0,0,0,.25);align-items:center;gap:8px}

/* ─── ANIMATIONS ─────────────────────── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ─── RESPONSIVE ─────────────────────── */
@media(max-width:960px){
  .nav-links{display:none}
  .contact-grid{grid-template-columns:1fr}
  .contact-cards{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .float-call{display:flex}
}
@media(max-width:640px){
  .wrap,.wrap-md{padding:0 18px}
  .form-grid{grid-template-columns:1fr}
  .form-group-full{grid-column:span 1}
  .form-radios{grid-template-columns:1fr}
}
