:root{
  --ink:#1c1814;
  --ink-soft:#403729;
  --champ-1:#f7efe0;
  --champ-2:#efe1c6;
  --champ-3:#e8d3a8;
  --gold:#b8943f;
  --gold-dark:#9a7a2e;
  --cream:#faf6ee;
  --line:#e2d4bb;
  --white:#fffdf9;
  --shadow:0 24px 60px -28px rgba(60,46,18,.45);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.1;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px,92%);margin-inline:auto}
.gold{color:var(--gold-dark)}
.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold-dark);
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.95rem 1.9rem;border-radius:2px;
  font-weight:600;font-size:.9rem;letter-spacing:.02em;
  cursor:pointer;border:1px solid transparent;
  transition:.25s ease;
}
.btn-primary{background:var(--ink);color:var(--champ-2)}
.btn-primary:hover{background:var(--gold-dark);color:#fff}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-ghost:hover{background:var(--ink);color:var(--champ-2)}

/* Header */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,246,238,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0}
.logo{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.5rem;font-weight:700}
.logo svg{width:34px;height:34px}
.logo span small{display:block;font-family:var(--sans);font-size:.55rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-dark);font-weight:600;margin-top:-2px}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{font-size:.86rem;font-weight:500;letter-spacing:.03em;transition:color .2s}
.nav-links a:hover{color:var(--gold-dark)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.menu-toggle span{width:26px;height:2px;background:var(--ink);display:block}

/* Hero */
.hero{position:relative;padding:6rem 0 5rem;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(1200px 600px at 80% -10%,var(--champ-3),transparent 60%),
    linear-gradient(160deg,var(--champ-1),var(--cream) 55%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:4rem;align-items:center}
.hero h1{font-size:clamp(2.7rem,5.4vw,4.6rem);margin:1.2rem 0 1.4rem}
.hero h1 em{font-style:italic;color:var(--gold-dark)}
.hero p.lead{font-size:1.12rem;color:var(--ink-soft);max-width:34ch;margin-bottom:2.2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-figure{position:relative}
.hero-figure img{border-radius:4px;box-shadow:var(--shadow);height:560px;object-fit:cover;width:100%}
.hero-badge{
  position:absolute;bottom:-26px;left:-26px;
  background:var(--white);border:1px solid var(--line);
  padding:1.2rem 1.5rem;border-radius:3px;box-shadow:var(--shadow);
  max-width:230px;
}
.hero-badge strong{font-family:var(--serif);font-size:2.2rem;color:var(--gold-dark);display:block;line-height:1}
.hero-badge span{font-size:.78rem;color:var(--ink-soft)}

/* Trust strip */
.trust{border-block:1px solid var(--line);background:var(--white)}
.trust-inner{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:2.4rem 0;text-align:center}
.trust-item strong{font-family:var(--serif);font-size:2.4rem;color:var(--ink);display:block}
.trust-item span{font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-dark)}

/* Section base */
section.block{padding:6rem 0}
.section-head{max-width:48ch;margin-bottom:3.4rem}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,3.6vw,3rem);margin:.8rem 0 1rem}
.section-head p{color:var(--ink-soft)}

/* Services */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.svc-card{
  background:var(--white);border:1px solid var(--line);
  border-radius:4px;padding:2.2rem 1.9rem;transition:.3s ease;
  position:relative;overflow:hidden;
}
.svc-card::after{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);transition:width .35s ease}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.svc-card:hover::after{width:100%}
.svc-num{font-family:var(--serif);font-size:1.1rem;color:var(--gold-dark);letter-spacing:.1em}
.svc-card h3{font-size:1.5rem;margin:.7rem 0 .8rem}
.svc-card p{font-size:.92rem;color:var(--ink-soft)}

/* About / split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split img{border-radius:4px;box-shadow:var(--shadow);height:480px;width:100%;object-fit:cover}
.split ul{list-style:none;margin-top:1.6rem;display:grid;gap:1rem}
.split ul li{padding-left:1.8rem;position:relative;color:var(--ink-soft)}
.split ul li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;background:var(--gold);transform:rotate(45deg)}

/* Process */
.process{background:var(--ink);color:var(--champ-1)}
.process h2,.process h3{color:var(--champ-2)}
.process .eyebrow{color:var(--champ-3)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:3rem}
.step{border:1px solid rgba(232,211,168,.25);padding:1.8rem 1.5rem;border-radius:4px;transition:.3s}
.step:hover{background:rgba(232,211,168,.08)}
.step .n{font-family:var(--serif);font-size:2.6rem;color:var(--champ-3);line-height:1}
.step h3{font-size:1.25rem;margin:.6rem 0 .5rem}
.step p{font-size:.86rem;color:rgba(247,239,224,.7)}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;align-items:start}
.price-card{
  background:var(--white);border:1px solid var(--line);border-radius:5px;
  padding:2.6rem 2rem;display:flex;flex-direction:column;transition:.3s ease;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price-card.featured{background:linear-gradient(165deg,var(--champ-1),var(--white));border-color:var(--gold);position:relative}
.price-card.featured::before{
  content:"Le plus choisi";position:absolute;top:1.4rem;right:1.4rem;
  background:var(--ink);color:var(--champ-2);font-size:.66rem;letter-spacing:.14em;
  text-transform:uppercase;padding:.35rem .7rem;border-radius:2px;
}
.price-card h3{font-size:1.7rem}
.price-tier{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold-dark);margin-bottom:1.2rem}
.price-amount{font-family:var(--serif);font-size:3.2rem;color:var(--ink);line-height:1}
.price-amount span{font-size:1rem;font-family:var(--sans);color:var(--ink-soft)}
.price-card ul{list-style:none;margin:1.8rem 0;display:grid;gap:.85rem}
.price-card ul li{font-size:.9rem;color:var(--ink-soft);padding-left:1.6rem;position:relative}
.price-card ul li::before{content:"✓";position:absolute;left:0;color:var(--gold-dark);font-weight:700}
.price-card .btn{margin-top:auto;justify-content:center}
.price-note{text-align:center;margin-top:2rem;font-size:.85rem;color:var(--ink-soft)}

/* Testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.testi{background:var(--white);border:1px solid var(--line);border-radius:4px;padding:2.2rem}
.testi p{font-family:var(--serif);font-size:1.18rem;font-style:italic;color:var(--ink);margin-bottom:1.4rem}
.testi .who{display:flex;align-items:center;gap:.8rem}
.testi .who img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.testi .who strong{display:block;font-size:.9rem}
.testi .who span{font-size:.78rem;color:var(--gold-dark)}

/* FAQ */
.faq{max-width:780px;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.faq-q .ico{font-size:1.6rem;color:var(--gold-dark);transition:transform .3s}
.faq-q[aria-expanded="true"] .ico{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 0 1.5rem;color:var(--ink-soft)}

/* Contact */
.contact{background:linear-gradient(160deg,var(--champ-1),var(--cream))}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem}
.contact-info h2{font-size:clamp(2rem,3.4vw,2.8rem);margin:.8rem 0 1.2rem}
.contact-info p{color:var(--ink-soft);margin-bottom:2rem}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.4rem}
.contact-detail .ic{width:40px;height:40px;flex:none;border:1px solid var(--gold);border-radius:50%;display:grid;place-items:center;color:var(--gold-dark)}
.contact-detail strong{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-dark)}
.contact-detail span{color:var(--ink-soft);font-size:.95rem}
form{background:var(--white);border:1px solid var(--line);border-radius:5px;padding:2.6rem;box-shadow:var(--shadow)}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.8rem;font-weight:600;letter-spacing:.04em;margin-bottom:.5rem}
.field input,.field select,.field textarea{
  width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:3px;
  font-family:var(--sans);font-size:.95rem;background:var(--cream);color:var(--ink);transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.checkbox{display:flex;gap:.7rem;align-items:flex-start;font-size:.82rem;color:var(--ink-soft);margin-bottom:1.4rem}
.checkbox input{width:auto;margin-top:.25rem}
.form-msg{display:none;padding:1rem;border-radius:3px;margin-top:1rem;font-size:.9rem;background:var(--champ-2);color:var(--ink-soft)}
.form-msg.show{display:block}

/* Footer */
footer{background:var(--ink);color:rgba(247,239,224,.78);padding:4rem 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.foot-grid h4{color:var(--champ-2);font-size:1.05rem;margin-bottom:1.2rem;font-family:var(--sans);letter-spacing:.05em}
.foot-grid a,.foot-grid p{display:block;font-size:.88rem;color:rgba(247,239,224,.7);margin-bottom:.65rem;transition:color .2s}
.foot-grid a:hover{color:var(--champ-3)}
.foot-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.6rem;color:var(--champ-2);margin-bottom:1rem}
.foot-logo svg{width:36px;height:36px}
.foot-bottom{border-top:1px solid rgba(232,211,168,.2);padding-top:1.8rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:rgba(247,239,224,.55)}

/* Cookie banner */
.cookie{
  position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%);
  width:min(960px,94%);background:var(--ink);color:var(--champ-1);
  border:1px solid var(--gold-dark);border-radius:6px;
  padding:1.4rem 1.7rem;display:none;gap:1.4rem;align-items:center;justify-content:space-between;
  z-index:100;box-shadow:0 30px 60px -20px rgba(0,0,0,.5);flex-wrap:wrap;
}
.cookie.show{display:flex}
.cookie p{font-size:.86rem;max-width:60ch;color:rgba(247,239,224,.85)}
.cookie p a{color:var(--champ-3);text-decoration:underline}
.cookie-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie .btn{padding:.7rem 1.4rem;font-size:.82rem}
.cookie .btn-ghost{border-color:var(--champ-3);color:var(--champ-3)}
.cookie .btn-ghost:hover{background:var(--champ-3);color:var(--ink)}

/* Legal pages */
.legal-hero{background:linear-gradient(160deg,var(--champ-1),var(--cream));padding:4rem 0 3rem;border-bottom:1px solid var(--line)}
.legal-hero h1{font-size:clamp(2.2rem,4vw,3.2rem)}
.legal-hero p{color:var(--ink-soft);margin-top:.6rem}
.legal-body{padding:4rem 0;max-width:820px}
.legal-body h2{font-size:1.6rem;margin:2.4rem 0 .9rem;color:var(--ink)}
.legal-body h3{font-size:1.2rem;margin:1.6rem 0 .6rem}
.legal-body p,.legal-body li{color:var(--ink-soft);margin-bottom:.9rem;font-size:.97rem}
.legal-body ul{padding-left:1.4rem;margin-bottom:1rem}
.legal-body a{color:var(--gold-dark);text-decoration:underline}
.back-link{display:inline-flex;gap:.4rem;margin-top:2rem;color:var(--gold-dark);font-weight:600;font-size:.9rem}

/* Responsive */
@media(max-width:980px){
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr;gap:2.6rem}
  .hero-figure img{height:420px}
  .services-grid,.testi-grid,.pricing-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(300px,80%);background:var(--cream);
    flex-direction:column;align-items:flex-start;padding:5rem 2rem;gap:1.4rem;
    transform:translateX(100%);transition:transform .3s ease;box-shadow:var(--shadow);
  }
  .nav-links.open{transform:translateX(0)}
  .menu-toggle{display:flex}
}
@media(max-width:560px){
  .steps,.foot-grid{grid-template-columns:1fr}
  .hero-badge{left:0;bottom:-20px}
  form{padding:1.8rem}
}
