:root{
  --fond:#1a1b1d;
  --fond2:#202224;
  --surface:#26282b;
  --surface2:#2d3034;
  --trait:#3a3d42;
  --trait-clair:#4a4e54;
  --encre:#eceae6;
  --encre-doux:#a7a59f;
  --acier:#8c9097;
  --orange:#e8722a;
  --orange-clair:#ff8c42;
  --orange-sombre:#c25a1c;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Barlow',sans-serif;
  background:var(--fond);
  color:var(--encre);
  font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* metal grain */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
h1,h2,h3,h4,.display{font-family:'Oswald',sans-serif;font-weight:600;line-height:1.05;letter-spacing:.01em}
::selection{background:var(--orange);color:#1a1b1d}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 30px}
.label{font-family:'Oswald',sans-serif;font-size:.78rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--orange)}

/* wrought-iron ornament divider */
.ornement{display:flex;align-items:center;justify-content:center;gap:18px;color:var(--acier);margin:0 auto}
.ornement svg{width:200px;height:26px}
.ornement .pastille{width:7px;height:7px;background:var(--orange);transform:rotate(45deg);flex-shrink:0}

/* ---------- HEADER ---------- */
header{position:sticky;top:0;z-index:1000;background:rgba(26,27,29,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--trait)}
nav{display:flex;align-items:center;justify-content:space-between;padding:14px 30px;max-width:1180px;margin:0 auto}
.brand{display:flex;align-items:center;gap:14px}
.brand .crest{width:48px;height:48px;border:1.5px solid var(--trait-clair);border-radius:3px;display:grid;place-items:center;color:var(--orange);background:var(--surface)}
.brand .crest svg{width:26px;height:26px}
.brand .name{font-family:'Oswald';font-size:1.5rem;font-weight:600;line-height:1.05;letter-spacing:.06em;text-transform:uppercase}
.brand .sub{font-family:'Oswald',sans-serif;font-weight:300;font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--encre-doux)}
.nav-links{display:flex;gap:32px;align-items:center;font-family:'Oswald',sans-serif;font-weight:400;font-size:.84rem;letter-spacing:.12em;text-transform:uppercase}
.nav-links a{color:var(--encre-doux);position:relative;padding-bottom:4px;transition:color .3s}
.nav-links a:hover,.nav-links a.active{color:var(--encre)}
.nav-links a::after{content:"";position:absolute;left:50%;right:50%;bottom:0;height:2px;background:var(--orange);transition:.35s ease}
.nav-links a:hover::after,.nav-links a.active::after{left:0;right:0}
.tel-link{display:flex;align-items:center;gap:9px;font-family:'Oswald',sans-serif;font-weight:500;font-size:.95rem;letter-spacing:.06em;color:var(--orange-clair)}
.tel-link svg{width:16px;height:16px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer}
.burger span{width:25px;height:2px;background:var(--encre)}

/* ---------- HERO ---------- */
.hero{display:grid;grid-template-columns:1.05fr 1fr;min-height:88vh}
.hero-text{display:flex;flex-direction:column;justify-content:center;padding:70px 70px 70px 0;position:relative;background:
   radial-gradient(600px 400px at 0% 60%,rgba(232,114,42,.07),transparent 70%)}
.hero-text .inner{max-width:560px;margin-left:auto;padding-left:30px}
.hero h1{font-size:clamp(3rem,6vw,5.4rem);font-weight:700;text-transform:uppercase;letter-spacing:.01em;margin:24px 0 26px;line-height:.98}
.hero h1 em{font-style:normal;color:var(--orange);display:block}
.hero .intro{font-size:1.15rem;color:var(--encre-doux);max-width:470px;margin-bottom:38px}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.btn{font-family:'Oswald',sans-serif;font-weight:500;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;padding:15px 32px;cursor:pointer;border:none;transition:all .35s ease;display:inline-flex;align-items:center;gap:10px}
.btn-primary{background:var(--orange);color:#1a1b1d;border:1.5px solid var(--orange)}
.btn-primary:hover{background:var(--orange-clair);border-color:var(--orange-clair);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--encre);border:1.5px solid var(--trait-clair)}
.btn-outline:hover{border-color:var(--orange);color:var(--orange-clair)}
.hero-photo{position:relative;background:var(--fond2);overflow:hidden}
.hero-photo img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(1.05) brightness(.92)}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--fond) 0%,transparent 22%);pointer-events:none}
.hero-stamp{position:absolute;left:26px;bottom:26px;z-index:3;background:var(--surface);border:1px solid var(--trait-clair);border-left:3px solid var(--orange);padding:16px 22px;max-width:240px}
.hero-stamp .y{font-family:'Oswald';font-weight:700;font-size:2.2rem;color:var(--orange-clair);line-height:1}
.hero-stamp .d{font-family:'Oswald',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--encre-doux);margin-top:5px}

/* ---------- SECTIONS ---------- */
section{position:relative}
.pad{padding:104px 0}
.center{text-align:center}
.sec-title{font-size:clamp(2.1rem,4.2vw,3.4rem);font-weight:600;text-transform:uppercase;letter-spacing:.02em;margin:14px 0 18px}
.sec-title em{font-style:normal;color:var(--orange)}
.lede{font-size:1.1rem;color:var(--encre-doux);max-width:620px;margin:0 auto}
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- ATELIER / STORY ---------- */
.story{background:var(--fond2);border-top:1px solid var(--trait);border-bottom:1px solid var(--trait)}
.story-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
.story-photo{position:relative}
.story-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:contrast(1.05) brightness(.92);border:1px solid var(--trait-clair)}
.story-photo .cap{font-family:'Oswald',sans-serif;font-weight:300;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--encre-doux);text-align:center;margin-top:16px}
.story-body h2{font-size:clamp(2rem,3.8vw,3rem);text-transform:uppercase;margin:14px 0 22px;line-height:1.02}
.story-body p{margin-bottom:18px;color:var(--encre-doux)}
.story-body p strong{color:var(--encre);font-weight:600}
.signature{font-family:'Caveat',cursive;font-size:2.5rem;color:var(--orange-clair);margin:6px 0 2px;line-height:1}
.values{display:flex;gap:34px;margin-top:34px;flex-wrap:wrap}
.value{display:flex;gap:13px;align-items:flex-start;max-width:205px}
.value svg{width:28px;height:28px;color:var(--orange);flex-shrink:0;margin-top:2px}
.value b{font-family:'Oswald',sans-serif;font-weight:500;font-size:.84rem;letter-spacing:.08em;display:block;color:var(--encre);text-transform:uppercase}
.value span{font-size:.95rem;color:var(--encre-doux);line-height:1.45}

/* ---------- PRESTATIONS ---------- */
.prest-list{display:grid;grid-template-columns:1fr 1fr;gap:0 70px;margin-top:54px}
.prest{display:flex;gap:22px;align-items:flex-start;padding:26px 0;border-bottom:1px solid var(--trait)}
.prest .pi{width:52px;height:52px;flex-shrink:0;color:var(--orange);border:1px solid var(--trait-clair);border-radius:3px;display:grid;place-items:center;background:var(--surface);transition:.4s ease}
.prest:hover .pi{background:var(--orange);color:#1a1b1d;border-color:var(--orange)}
.prest .pi svg{width:28px;height:28px}
.prest h3{font-size:1.4rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;margin-bottom:4px}
.prest p{font-size:.98rem;color:var(--encre-doux);line-height:1.5}
.materials-note{text-align:center;margin-top:52px;font-family:'Oswald',sans-serif;font-weight:300;font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;color:var(--encre-doux)}
.materials-note b{color:var(--orange-clair);font-weight:500}

/* ---------- GALERIE ---------- */
.gal{background:var(--fond2);border-top:1px solid var(--trait);border-bottom:1px solid var(--trait)}
.frames{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.frame{background:var(--surface);padding:11px 11px 14px;border:1px solid var(--trait);transition:transform .5s ease,border-color .5s ease}
.frame:hover{transform:translateY(-5px);border-color:var(--orange)}
.frame .ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surface2)}
.frame .ph img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) brightness(.93);transition:transform .8s ease}
.frame:hover .ph img{transform:scale(1.05)}
.frame .cap{display:flex;justify-content:space-between;align-items:baseline;padding:13px 5px 2px}
.frame .cap h4{font-size:1.2rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.frame .cap span{font-family:'Oswald',sans-serif;font-weight:300;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.gal-foot{text-align:center;margin-top:48px;font-family:'Caveat',cursive;font-size:1.7rem;color:var(--acier)}
.gal-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:46px}
.gal-filter{font-family:'Oswald',sans-serif;font-weight:400;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--encre-doux);background:transparent;border:1px solid var(--trait-clair);padding:9px 20px;cursor:pointer;transition:.3s ease}
.gal-filter:hover{border-color:var(--orange);color:var(--encre)}
.gal-filter.active{background:var(--orange);border-color:var(--orange);color:#1a1b1d}
.frames{margin-top:30px}

/* ---------- METHODE ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;margin-top:56px}
.stp{text-align:center}
.stp .num{font-family:'Oswald';font-weight:600;font-size:1.05rem;color:#1a1b1d;background:var(--orange);width:48px;height:48px;border-radius:50%;display:grid;place-items:center;margin:0 auto 20px}
.stp h3{font-size:1.35rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;margin-bottom:10px}
.stp p{font-size:.97rem;color:var(--encre-doux)}

/* ---------- CONTACT ---------- */
.contact{background:#151618;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 420px at 82% 0%,rgba(232,114,42,.18),transparent)}
.contact .wrap{position:relative;z-index:2}
.contact h2{color:var(--encre)}
.contact-card{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:54px;border:1px solid var(--trait);background:var(--surface)}
.cc-left{padding:48px}
.cc-right{padding:48px;background:var(--fond2);border-left:1px solid var(--trait)}
.cc-left .big-tel{font-family:'Oswald';font-weight:600;font-size:2.3rem;letter-spacing:.02em;color:var(--encre);display:flex;align-items:center;gap:14px;margin:8px 0 24px}
.cc-left .big-tel svg{width:28px;height:28px;color:var(--orange)}
.cc-info{display:flex;flex-direction:column;gap:16px;font-size:1.02rem;color:var(--encre-doux)}
.cc-info .row{display:flex;gap:14px;align-items:flex-start}
.cc-info svg{width:20px;height:20px;color:var(--orange);flex-shrink:0;margin-top:4px}
.field{margin-bottom:18px}
.field label{font-family:'Oswald',sans-serif;font-weight:400;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);display:block;margin-bottom:7px}
.field input,.field textarea{width:100%;background:var(--fond);border:1px solid var(--trait-clair);color:var(--encre);padding:12px 14px;font-family:'Barlow',sans-serif;font-size:1rem;outline:none;transition:.3s}
.field input:focus,.field textarea:focus{border-color:var(--orange)}
.field textarea{resize:vertical;min-height:84px}
.contact .btn-primary{width:100%;justify-content:center;margin-top:6px}
.consent{font-size:.82rem;color:var(--encre-doux);margin-top:14px}
.consent a{color:var(--orange-clair)}

/* ---------- FOOTER ---------- */
footer{background:#151618;border-top:1px solid var(--trait);padding:56px 0 30px}
.foot{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.foot-links{display:flex;gap:48px;flex-wrap:wrap}
.foot-links h5{font-family:'Oswald',sans-serif;font-weight:400;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin-bottom:15px}
.foot-links a{display:block;color:var(--encre-doux);margin-bottom:9px;font-size:.92rem;transition:color .3s}
.foot-links a:hover{color:var(--encre)}
.foot-bottom{text-align:center;margin-top:46px;padding-top:22px;border-top:1px solid var(--trait);font-family:'Oswald',sans-serif;font-weight:300;font-size:.76rem;color:var(--encre-doux);letter-spacing:.06em;text-transform:uppercase}
.foot-legal{display:flex;justify-content:center;gap:8px 22px;flex-wrap:wrap;margin-top:14px;font-family:'Oswald',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}
.foot-legal a{color:var(--acier);transition:color .3s}
.foot-legal a:hover{color:var(--orange-clair)}
.foot-credit{text-align:center;margin-top:12px;font-family:'Oswald',sans-serif;font-weight:300;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--encre-doux)}
.foot-credit a{color:var(--orange-clair);transition:color .3s}
.foot-credit a:hover{color:var(--orange)}

/* ---------- COOKIE BANNER ---------- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:1200;max-width:560px;margin:0 auto;background:var(--surface);border:1px solid var(--trait-clair);border-top:3px solid var(--orange);padding:22px 24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.6)}
.cookie.hidden{display:none}
.cookie p{font-size:.92rem;color:var(--encre-doux);margin-bottom:16px}
.cookie p a{color:var(--orange-clair)}
.cookie-actions{display:flex;gap:12px;flex-wrap:wrap}
.cookie .btn{padding:11px 22px;font-size:.76rem}

/* ---------- LEGAL / CONTENT PAGES ---------- */
.page-head{padding:130px 0 56px;background:var(--fond2);border-bottom:1px solid var(--trait);text-align:center}
.page-head h1{font-size:clamp(2.2rem,5vw,3.6rem);text-transform:uppercase;letter-spacing:.02em;margin:14px 0 10px}
.page-head h1 em{font-style:normal;color:var(--orange)}
.page-head .updated{font-family:'Oswald',sans-serif;font-weight:300;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--encre-doux)}
.legal{max-width:840px;margin:0 auto;padding:64px 30px 96px}
.legal h2{font-size:1.5rem;text-transform:uppercase;letter-spacing:.02em;color:var(--encre);margin:46px 0 16px;padding-bottom:10px;border-bottom:1px solid var(--trait)}
.legal h2:first-child{margin-top:0}
.legal h3{font-size:1.12rem;font-family:'Oswald';font-weight:500;color:var(--encre);margin:26px 0 8px;letter-spacing:.02em}
.legal p{color:var(--encre-doux);margin-bottom:14px}
.legal ul{color:var(--encre-doux);margin:0 0 16px 22px}
.legal li{margin-bottom:8px}
.legal a{color:var(--orange-clair);text-decoration:underline;text-underline-offset:3px}
.legal strong{color:var(--encre);font-weight:600}
.legal table{width:100%;border-collapse:collapse;margin:8px 0 20px}
.legal table th,.legal table td{border:1px solid var(--trait);padding:10px 14px;text-align:left;font-size:.92rem;color:var(--encre-doux);vertical-align:top}
.legal table th{background:var(--surface);color:var(--encre);font-family:'Oswald';font-weight:500;letter-spacing:.04em}
.legal .todo{background:rgba(232,114,42,.08);border-left:3px solid var(--orange);padding:12px 16px;margin:6px 0 18px;font-size:.9rem;color:var(--orange-clair);font-family:'Oswald',sans-serif;font-weight:300;letter-spacing:.02em}
.legal .back{display:inline-flex;align-items:center;gap:8px;margin-top:30px;font-family:'Oswald';font-weight:500;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-clair)}

@media(max-width:920px){
  .nav-links,.tel-link{display:none}.burger{display:flex}
  .hero{grid-template-columns:1fr}.hero-photo{min-height:46vh;order:-1}
  .hero-text{padding:54px 0}.hero-text .inner{padding:0 30px;margin:0 auto}
  .hero-photo::after{background:linear-gradient(0deg,var(--fond) 0%,transparent 30%)}
  .story-grid{grid-template-columns:1fr;gap:40px}.story-photo img{aspect-ratio:16/10}
  .prest-list{grid-template-columns:1fr;gap:0}
  .frames{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:34px}
  .contact-card{grid-template-columns:1fr}.cc-right{border-left:none;border-top:1px solid var(--trait)}
}
@media(max-width:560px){
  .frames{grid-template-columns:1fr}.steps{grid-template-columns:1fr}
  .pad{padding:74px 0}.cc-left,.cc-right{padding:32px}
  .foot-links{gap:30px;flex-wrap:wrap}
}
