/* ===== Polices auto-hébergées (RGPD : aucun appel à Google) ===== */
@font-face{font-family:'Marcellus';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/marcellus-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('fonts/inter-latin-300-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/inter-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/inter-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/inter-latin-600-normal.woff2') format('woff2');}

/* ============================================================
   Kevin Quinsac — Avocat au barreau de Paris
   Feuille de style commune
   Charte : Anthracite #151E2B · Fumée #9CAAB5 · Nuit #111214
            Gris #E4E8EA · Blanc #FFFFFF
   Typo   : Marcellus (titres) / Inter (texte)
   ============================================================ */

:root{
  --anthracite:#151E2B;
  --nuit:#111214;
  --fumee:#9CAAB5;
  --gris:#E4E8EA;
  --blanc:#FFFFFF;
  --texte:#2A3340;
  --texte-doux:#5A6472;
  --anthracite-2:#1C2634;
  --display:'Marcellus', Georgia, serif;
  --corps:'Inter', system-ui, -apple-system, sans-serif;
  --max:1120px;
  --pad:clamp(20px, 5vw, 64px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--corps);font-weight:400;
  color:var(--texte);background:var(--blanc);line-height:1.65;
  -webkit-font-smoothing:antialiased;font-size:17px;
}
h1,h2,h3{font-family:var(--display);font-weight:400;line-height:1.15;margin:0;letter-spacing:.2px;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;max-width:100%;}

.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}

/* Libellé de section avec tiret diagonal (rappel du monogramme) */
.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--corps);font-size:.74rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--fumee);margin-bottom:22px;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--fumee);transform:skewY(-20deg);transform-origin:left center;}

/* Marqueur visuel des contenus PROVISOIRES / à compléter */
.todo{
  border-left:2px dashed var(--fumee);
  background:rgba(156,170,181,.08);
  padding:14px 18px;margin:14px 0;border-radius:0 4px 4px 0;
}
.todo::before{
  content:"À compléter / provisoire";display:block;
  font-family:var(--corps);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--fumee);margin-bottom:6px;font-weight:600;
}
.todo p{margin:.3em 0;color:var(--texte-doux);font-size:.95rem;}

/* Justification du corps de texte (césure FR pour éviter les lézardes) */
.card p, .domaine-body p, .cabinet-body p, .split .body p,
.legal-block .body p, .todo p{
  text-align:justify;
  text-justify:inter-word;
  -webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;
}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:20;
  background:rgba(21,30,43,.92);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid rgba(156,170,181,.16);
}
.navbar{display:flex;align-items:center;justify-content:space-between;height:74px;}
.brand{height:34px;}
.brand svg,.brand img{height:34px;width:auto;}
nav ul{display:flex;gap:34px;list-style:none;margin:0;padding:0;}
nav a{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gris);font-weight:400;padding:6px 0;position:relative;transition:color .2s;}
nav a:hover{color:var(--fumee);}
nav a[aria-current="page"]{color:var(--fumee);}
nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--fumee);transition:width .25s;}
nav a:hover::after,nav a[aria-current="page"]::after{width:100%;}
.nav-toggle{display:none;background:none;border:0;color:var(--gris);cursor:pointer;padding:8px;font-size:1.1rem;}

/* ---------- Hero (accueil) ---------- */
.hero{position:relative;background:var(--anthracite);color:var(--gris);overflow:hidden;}
.hero-mark{position:absolute;right:-4%;top:50%;transform:translateY(-50%);width:min(52vw,520px);opacity:.06;pointer-events:none;}
.hero-inner{position:relative;padding-top:clamp(72px,12vw,150px);padding-bottom:clamp(72px,12vw,150px);max-width:760px;}
.hero h1{font-size:clamp(2.1rem,5.2vw,3.5rem);color:var(--blanc);letter-spacing:.4px;}
.hero p.lead{margin:26px 0 0;font-size:1.12rem;color:var(--fumee);max-width:44ch;font-weight:300;}
.cta-row{margin-top:40px;display:flex;gap:18px;flex-wrap:wrap;}
.btn{display:inline-block;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;padding:15px 30px;border:1px solid var(--fumee);color:var(--blanc);transition:all .22s;}
.btn:hover{background:var(--fumee);color:var(--anthracite);}
.btn.ghost{border-color:rgba(156,170,181,.4);color:var(--gris);}
.btn.ghost:hover{border-color:var(--fumee);color:var(--fumee);background:transparent;}

/* ---------- Hero de page interne ---------- */
.page-hero{position:relative;background:var(--anthracite);color:var(--gris);overflow:hidden;}
.page-hero-inner{position:relative;padding-top:clamp(56px,8vw,96px);padding-bottom:clamp(56px,8vw,96px);max-width:760px;}
.page-hero h1{font-size:clamp(1.9rem,4.4vw,2.9rem);color:var(--blanc);}
.page-hero p.lead{margin:22px 0 0;font-size:1.08rem;color:var(--fumee);max-width:52ch;font-weight:300;}

/* ---------- Sections génériques ---------- */
.section{padding-top:clamp(64px,9vw,110px);padding-bottom:clamp(64px,9vw,110px);}
.section.alt{background:var(--gris);}
.section-head{max-width:640px;margin-bottom:52px;}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.4rem);color:var(--anthracite);}
.section-head p{color:var(--texte-doux);margin:16px 0 0;}

/* ---------- Cartes domaines (accueil) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gris);border:1px solid var(--gris);}
.card{background:var(--blanc);padding:38px 32px;}
.card .idx{font-family:var(--display);font-size:1rem;color:var(--fumee);margin-bottom:18px;}
.card h3{font-size:1.32rem;color:var(--anthracite);margin-bottom:14px;}
.card p{color:var(--texte-doux);font-size:.97rem;margin:0;}
.card .more{display:inline-block;margin-top:20px;font-family:var(--corps);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--anthracite);border-bottom:1px solid var(--fumee);padding-bottom:3px;}
.card .more:hover{color:var(--fumee);}

/* ---------- Détail d'un domaine (page Domaines) ---------- */
.domaine{border-top:1px solid var(--gris);}
.domaine:first-of-type{border-top:0;}
.domaine-grid{display:grid;grid-template-columns:0.42fr 1fr;gap:clamp(24px,5vw,64px);}
.domaine-head .idx{font-family:var(--display);font-size:1.1rem;color:var(--fumee);margin-bottom:10px;}
.domaine-head h2{font-size:clamp(1.5rem,3vw,2.1rem);color:var(--anthracite);position:sticky;top:100px;}
.domaine-body p{margin:0 0 22px;color:var(--texte);}
.domaine-body h3{font-size:1rem;font-family:var(--corps);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--anthracite);margin:0 0 14px;}
ul.tick{list-style:none;padding:0;margin:0 0 24px;}
ul.tick li{position:relative;padding-left:26px;margin-bottom:10px;color:var(--texte-doux);}
ul.tick li::before{content:"";position:absolute;left:0;top:11px;width:14px;height:1px;background:var(--fumee);transform:skewY(-20deg);}
.juris{font-size:.95rem;color:var(--texte-doux);border-top:1px solid var(--gris);padding-top:18px;}
.juris strong{color:var(--anthracite);font-weight:600;}

/* ---------- Cabinet ---------- */
.cabinet-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(32px,6vw,80px);align-items:center;}
.cabinet-photo{position:relative;}
.cabinet-photo img{width:100%;height:auto;}
.cabinet-photo::after{content:"";position:absolute;left:-14px;top:-14px;width:64px;height:64px;border-left:1px solid var(--fumee);border-top:1px solid var(--fumee);}
.cabinet-body h2{font-size:clamp(1.7rem,3.4vw,2.4rem);color:var(--anthracite);margin-bottom:22px;}
.cabinet-body p{color:var(--texte);margin:0 0 18px;}
.inline-link{color:var(--anthracite);border-bottom:1px solid var(--fumee);padding-bottom:2px;transition:color .2s;font-weight:500;}
.inline-link:hover{color:var(--fumee);}

/* Bloc "colonnes" réutilisable (parcours, méthode, honoraires…) */
.split{display:grid;grid-template-columns:0.42fr 1fr;gap:clamp(24px,5vw,64px);}
.split + .split{margin-top:clamp(40px,6vw,72px);}
.split h2{font-size:clamp(1.4rem,2.8vw,1.9rem);color:var(--anthracite);position:sticky;top:100px;align-self:start;}
.split .body p{margin:0 0 16px;color:var(--texte);}

/* ---------- Contact ---------- */
.contact{background:var(--anthracite);color:var(--gris);}
.contact.center{text-align:center;}
.contact h2{color:var(--blanc);font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:18px;}
.contact p{color:var(--fumee);margin:0 0 34px;max-width:52ch;font-weight:300;}
.contact.center p{margin-left:auto;margin-right:auto;}
.contact .mail{font-family:var(--display);font-size:clamp(1.3rem,3vw,1.9rem);color:var(--blanc);border-bottom:1px solid var(--fumee);padding-bottom:4px;}
.contact .mail:hover{color:var(--fumee);}
.contact .meta{margin-top:34px;font-size:.9rem;color:var(--texte-doux);letter-spacing:.04em;}
.coord{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:10px;}
.coord .item{border-top:1px solid rgba(156,170,181,.25);padding-top:16px;}
.coord .lbl{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fumee);margin-bottom:8px;}
.coord .val{color:var(--blanc);font-size:1.02rem;}

/* ---------- Mentions légales ---------- */
.legal .section-head{margin-bottom:36px;}
.legal-block{border-top:1px solid var(--gris);padding:26px 0;display:grid;grid-template-columns:0.42fr 1fr;gap:clamp(16px,4vw,48px);}
.legal-block h2{font-size:1.15rem;font-family:var(--corps);font-weight:600;letter-spacing:.04em;color:var(--anthracite);}
.legal-block .body{color:var(--texte-doux);font-size:.97rem;}
.legal-block .body p{margin:0 0 10px;}
.ref{font-size:.85rem;color:var(--fumee);}

/* ---------- Footer ---------- */
footer.site{background:var(--nuit);color:#7C8593;padding:52px 0;}
.foot{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.foot .brand svg,.foot .brand img{height:30px;}
.foot-links{display:flex;gap:26px;font-size:.82rem;letter-spacing:.06em;}
.foot-links a:hover{color:var(--fumee);}
.copyright{font-size:.8rem;width:100%;color:#5A6270;letter-spacing:.04em;}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .cards{grid-template-columns:1fr;}
  .cabinet-grid{grid-template-columns:1fr;}
  .cabinet-photo{max-width:360px;}
  .domaine-grid,.split,.legal-block{grid-template-columns:1fr;}
  .domaine-head h2,.split h2{position:static;}
  nav ul{gap:22px;}
}
@media (max-width:640px){
  .nav-toggle{display:block;}
  nav#menu{position:absolute;left:0;right:0;top:74px;background:var(--anthracite);border-bottom:1px solid rgba(156,170,181,.16);max-height:0;overflow:hidden;transition:max-height .3s;}
  nav#menu.open{max-height:340px;}
  nav ul{flex-direction:column;gap:0;padding:8px var(--pad);}
  nav#menu a{display:block;padding:14px 0;border-bottom:1px solid rgba(156,170,181,.1);}
  nav a::after{display:none;}
  .coord{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}*{transition:none!important;}}

/* ===== Grille domaines en 2 axes (accueil) ===== */
.cards.two{grid-template-columns:repeat(2,1fr);}

/* ===== Logo d'en-tête : compact (monogramme) sous 640px ===== */
.brand .brand-mark{display:none;}
@media (max-width:640px){
  .brand .brand-full{display:none;}
  .brand .brand-mark{display:block;height:32px;width:auto;}
}
