/* ═══════════════════════════════════════════════════════════
   PLA architectes — 2026
   Design system : éditorial sobre · palette terre & ivoire
   ═══════════════════════════════════════════════════════════ */

:root{
  --ink:#1a1814;
  --ink-2:#3a3833;
  --paper:#faf6ee;
  --paper-2:#f3ede0;
  --paper-3:#ece4d3;
  --line:#d8cfb9;
  --line-soft:#e8e0cc;
  --rust:#a6552c;     /* terre cuite — accent */
  --rust-dark:#8a4520;
  --warm:#b8956c;     /* sable chaud */
  --mute:#6e6a60;
  --soft:#9a9389;
  --shadow:0 1px 2px rgba(26,24,20,.04),0 20px 60px -28px rgba(26,24,20,.18);
  --shadow-sm:0 1px 2px rgba(26,24,20,.04),0 8px 20px -10px rgba(26,24,20,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body.pa-body{
  font-family:'Inter',-apple-system,system-ui,sans-serif;
  font-size:16px;line-height:1.6;color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ─────────── TYPO ─────────── */
.pa-serif{font-family:'Fraunces','Instrument Serif',Georgia,serif;font-weight:300;font-variation-settings:"opsz" 144}
.pa-mono{font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}

/* ─────────── SIDEBAR — éditorial portfolio architecture ─────────── */
.pa-side{
  position:fixed;top:0;left:0;
  width:300px;height:100vh;height:100dvh;
  background:#fdfbf6;
  border-right:1px solid var(--line-soft);
  padding:42px 36px 36px;
  display:flex;flex-direction:column;
  z-index:100;
  overflow-y:auto;
  transition:transform .45s cubic-bezier(.2,.9,.3,1);
}
.pa-side::-webkit-scrollbar{width:0}
.pa-side-logo{
  display:block;width:100%;max-width:220px;
  margin-bottom:64px;
  transition:opacity .25s;
}
.pa-side-logo img{width:100%;height:auto;display:block}
.pa-side-logo:hover{opacity:.75}

/* Navigation verticale numérotée */
.pa-side-nav{display:flex;flex-direction:column;gap:2px;margin-bottom:auto}
.pa-side-nav a{
  display:grid;
  grid-template-columns:32px 1fr 18px;
  align-items:baseline;
  gap:14px;padding:14px 0;
  border-bottom:1px solid var(--line-soft);
  color:var(--ink);
  position:relative;
  transition:padding .35s cubic-bezier(.2,.9,.3,1);
}
.pa-side-nav a::before{
  content:"";position:absolute;left:-36px;top:50%;
  width:24px;height:1px;background:var(--rust);
  transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.2,.9,.3,1);
}
.pa-side-nav a:hover::before,.pa-side-nav a.on::before{transform:scaleX(1)}
.pa-side-nav a:hover{padding-left:6px}
.pa-side-nav a.on{color:var(--rust)}
.pa-side-nav .num{
  font-family:ui-monospace,'SF Mono',Menlo,monospace;
  font-size:10.5px;font-weight:700;letter-spacing:.18em;
  color:var(--mute);
  transition:color .25s;
}
.pa-side-nav a:hover .num,.pa-side-nav a.on .num{color:var(--rust)}
.pa-side-nav .lbl{
  font-family:'Fraunces','Instrument Serif',Georgia,serif;
  font-weight:400;font-size:22px;letter-spacing:-.015em;
  line-height:1.1;
}
.pa-side-nav a.on .lbl{font-style:italic;font-weight:400}
.pa-side-nav .arr{
  font-size:14px;color:var(--mute);
  opacity:0;transform:translateX(-6px);transition:.3s cubic-bezier(.2,.9,.3,1);
}
.pa-side-nav a:hover .arr{opacity:1;transform:translateX(0);color:var(--rust)}

/* Pied de sidebar — coordonnées + stamp */
.pa-side-foot{
  margin-top:48px;display:flex;flex-direction:column;gap:22px;
  padding-top:24px;border-top:1px solid var(--line-soft);
}
.pa-side-foot-block .city{
  display:block;
  font-family:ui-monospace,'SF Mono',Menlo,monospace;
  font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--rust);margin-bottom:4px;
}
.pa-side-foot-block a{
  font-size:14.5px;font-weight:600;color:var(--ink);
  letter-spacing:-.005em;
  transition:color .2s;
}
.pa-side-foot-block a:hover{color:var(--rust)}
.pa-side-langs{
  display:flex;align-items:baseline;gap:10px;
  font-family:ui-monospace,'SF Mono',Menlo,monospace;
  font-size:11px;letter-spacing:.18em;font-weight:600;
  margin-top:6px;padding-top:18px;
  border-top:1px dashed var(--line-soft);
}
.pa-side-langs a{
  color:var(--mute);
  transition:color .2s;
  position:relative;
}
.pa-side-langs a.on{
  color:var(--ink);font-style:italic;font-weight:700;
}
.pa-side-langs a.on::after{
  content:'';position:absolute;left:0;right:0;bottom:-4px;
  height:1px;background:var(--rust);
}
.pa-side-langs a:not(.on):hover{color:var(--rust)}
.pa-side-langs .sep{color:var(--line);font-weight:400}
.pa-side-foot-stamp{
  font-family:ui-monospace,'SF Mono',Menlo,monospace;
  font-size:9.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mute);margin-top:8px;padding-top:14px;border-top:1px dashed var(--line-soft);
}

/* Trigger burger mobile */
.pa-side-trigger{
  display:none;
  position:fixed;top:18px;left:18px;z-index:110;
  width:44px;height:44px;border-radius:50%;
  background:#fff;border:1px solid var(--line);
  align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
  box-shadow:0 4px 12px rgba(26,24,20,.08);
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:.2s;
}
.pa-side-trigger:hover{transform:scale(1.05)}
.pa-side-trigger span{
  display:block;width:18px;height:1.5px;background:var(--ink);
  transition:.3s cubic-bezier(.2,.9,.3,1);
}
.pa-side-trigger.open span:first-child{transform:translateY(3px) rotate(45deg)}
.pa-side-trigger.open span:last-child{transform:translateY(-3px) rotate(-45deg)}
.pa-side-overlay{
  display:none;position:fixed;inset:0;z-index:99;
  background:rgba(26,24,20,.4);
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.pa-side-overlay.open{opacity:1;pointer-events:auto}

/* Body décalé pour laisser place à la sidebar */
body.pa-body{padding-left:240px}

/* ─────────── HERO ─────────── */
.pa-hero{
  position:relative;min-height:100vh;min-height:100dvh;
  display:grid;grid-template-columns:1fr 1.4fr;gap:0;
  overflow:hidden;
}
.pa-hero-text{
  padding:90px 60px 50px 6vw;
  display:flex;flex-direction:column;justify-content:center;
  z-index:2;background:var(--paper);
}
.pa-hero-eyebrow{
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--rust);font-weight:600;
  margin-bottom:28px;display:flex;align-items:center;gap:10px;
}
.pa-hero-eyebrow::before{content:"";width:30px;height:1px;background:var(--rust)}
.pa-hero-h1{
  font-family:'Fraunces',serif;font-weight:300;
  font-variation-settings:"opsz" 144;
  font-size:clamp(46px,7vw,108px);line-height:.92;letter-spacing:-.035em;
  color:var(--ink);margin-bottom:30px;
}
.pa-hero-h1 em{font-style:italic;color:var(--rust);font-weight:400}
.pa-hero-lead{
  font-size:16.5px;line-height:1.65;color:var(--ink-2);
  max-width:480px;margin-bottom:42px;font-weight:400;
}
.pa-hero-meta{
  display:flex;gap:36px;flex-wrap:wrap;
  padding-top:28px;border-top:1px solid var(--line);
  font-size:13px;color:var(--mute);
}
.pa-hero-meta b{display:block;color:var(--ink);font-weight:600;font-size:14.5px;letter-spacing:-.005em;margin-bottom:2px}
.pa-hero-img{
  position:relative;overflow:hidden;background:var(--paper-2);
}
.pa-hero-img img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  filter:saturate(.95);
}
.pa-hero-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to right,var(--paper) 0%,transparent 8%);
  pointer-events:none;
}
.pa-hero-caption{
  position:absolute;bottom:36px;right:36px;left:36px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;font-weight:600;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.pa-hero-caption b{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:18px;letter-spacing:.005em;text-transform:none}

/* ─────────── SECTION BASE ─────────── */
.pa-sec{padding:100px 36px;position:relative}
.pa-sec-in{max-width:1280px;margin:0 auto}
.pa-sec-head{margin-bottom:80px;max-width:780px}
.pa-sec-eyebrow{
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--rust);font-weight:700;
  margin-bottom:24px;display:flex;align-items:center;gap:10px;
}
.pa-sec-eyebrow::before{content:"";width:36px;height:1px;background:var(--rust);display:inline-block}
.pa-sec-h2{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(36px,5vw,72px);line-height:1.02;letter-spacing:-.025em;color:var(--ink);
  margin-bottom:24px;
}
.pa-sec-h2 em{font-style:italic;color:var(--rust)}
.pa-sec-lead{font-size:17px;line-height:1.65;color:var(--ink-2);max-width:640px}
.pa-sec-lead strong{color:var(--ink);font-weight:600}

/* ─────────── À PROPOS ─────────── */
.pa-about{background:var(--paper-2);padding:100px 36px}
.pa-about-grid{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.3fr;gap:96px;align-items:start;
}
.pa-about-side{position:sticky;top:120px}
.pa-about-year{
  font-family:'Fraunces',serif;font-weight:300;font-size:96px;line-height:1;color:var(--rust);
  margin-bottom:14px;letter-spacing:-.04em;
}
.pa-about-year sup{font-size:.35em;vertical-align:super;color:var(--ink);font-weight:400;margin-left:6px;letter-spacing:.06em}
.pa-about-tag{font-family:'Fraunces',serif;font-style:italic;font-size:24px;color:var(--ink);line-height:1.3;max-width:280px}
.pa-about-body{font-size:16.5px;line-height:1.75;color:var(--ink-2)}
.pa-about-body p{margin-bottom:24px}
.pa-about-body p:last-child{margin-bottom:0}
.pa-about-body strong{color:var(--ink);font-weight:600}
.pa-about-quote{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:clamp(26px,3vw,38px);line-height:1.25;color:var(--ink);
  margin:48px 0;padding-left:32px;border-left:2px solid var(--rust);
  letter-spacing:-.005em;
}

/* ─────────── PROJETS — GRID ÉDITORIAL ─────────── */
.pa-projects{padding:100px 36px;background:var(--paper)}
.pa-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
  max-width:1480px;margin:0 auto;
}
.pa-project{
  position:relative;overflow:hidden;background:var(--paper-2);
  cursor:pointer;
  --span:4;
  grid-column:span var(--span);
  aspect-ratio:4/3;
}
.pa-project.span-6{--span:6}
.pa-project.span-8{--span:8}
.pa-project.tall{aspect-ratio:3/4}
.pa-project.wide{aspect-ratio:16/9}
.pa-project img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.2,.9,.3,1),filter .8s;
  filter:saturate(.92) brightness(.97);
}
.pa-project:hover img{transform:scale(1.04);filter:saturate(1) brightness(1)}
.pa-project-info{
  position:absolute;left:24px;right:24px;bottom:24px;
  color:#fff;z-index:2;
  transform:translateY(8px);opacity:0;transition:.4s cubic-bezier(.2,.9,.3,1);
}
.pa-project::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(26,24,20,.85) 0%,rgba(26,24,20,.2) 40%,transparent 70%);
  opacity:0;transition:opacity .4s;
}
.pa-project:hover::after{opacity:1}
.pa-project:hover .pa-project-info{transform:translateY(0);opacity:1}
.pa-project-cat{
  font-family:ui-monospace,Menlo,monospace;
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--warm);font-weight:700;
  margin-bottom:8px;
}
.pa-project-name{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:24px;line-height:1.15;color:#fff;letter-spacing:-.005em;
}
.pa-project-loc{font-size:12.5px;color:rgba(255,255,255,.7);margin-top:4px;letter-spacing:.02em}

/* ─────────── ÉQUIPE — GRID ─────────── */
.pa-team-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px 28px;
  max-width:1280px;margin:0 auto;
}
.pa-member{display:flex;flex-direction:column;gap:16px}
.pa-member-photo{
  width:100%;aspect-ratio:1;overflow:hidden;background:var(--paper-2);
  border-radius:2px;
}
.pa-member-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center 18%;
  filter:grayscale(60%) contrast(1.02);
  transition:filter .6s,transform 1s cubic-bezier(.2,.9,.3,1);
}
.pa-member:hover .pa-member-photo img{filter:grayscale(0);transform:scale(1.03)}
.pa-member-info{padding-top:6px}
.pa-member-name{
  font-family:'Fraunces',serif;font-weight:400;font-size:20px;line-height:1.2;
  color:var(--ink);letter-spacing:-.005em;margin-bottom:4px;
}
.pa-member-role{
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--rust);font-weight:600;
}
.pa-member.associé .pa-member-name::after{
  content:" · associée";font-size:12px;color:var(--mute);font-style:italic;font-family:'Fraunces',serif;font-weight:300;letter-spacing:0;
}
.pa-member.associé-m .pa-member-name::after{content:" · associé"}

/* ─────────── POURQUOI ARCHITECTE ─────────── */
.pa-why{background:var(--ink);color:var(--paper);padding:100px 36px;position:relative;overflow:hidden}
.pa-why::before{
  content:"A";
  position:absolute;font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:80vh;color:rgba(166,85,44,.06);
  top:-10%;right:-5%;line-height:1;pointer-events:none;
}
.pa-why-in{max-width:1280px;margin:0 auto;position:relative;z-index:2}
.pa-why-head{margin-bottom:80px;max-width:780px}
.pa-why-head .pa-sec-eyebrow{color:var(--warm)}
.pa-why-head .pa-sec-eyebrow::before{background:var(--warm)}
.pa-why-head .pa-sec-h2{color:var(--paper)}
.pa-why-head .pa-sec-h2 em{color:var(--warm)}
.pa-why-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:48px;
}
.pa-why-card{padding:32px 0;border-top:1px solid rgba(232,224,204,.18)}
.pa-why-card-n{
  font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.18em;color:var(--warm);
  margin-bottom:20px;
}
.pa-why-card-t{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:28px;line-height:1.2;color:var(--paper);margin-bottom:14px;letter-spacing:-.01em;
}
.pa-why-card-d{font-size:14.5px;line-height:1.7;color:rgba(232,224,204,.72)}

/* ─────────── SUCCURSALES ─────────── */
.pa-offices{padding:100px 36px;background:var(--paper)}
.pa-offices-grid{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
}
.pa-office{background:var(--paper-2);padding:48px;border-radius:2px}
.pa-office-tag{
  font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--rust);font-weight:700;margin-bottom:18px;
}
.pa-office-city{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:48px;line-height:1;color:var(--ink);margin-bottom:24px;letter-spacing:-.02em;
}
.pa-office-tel{font-size:20px;font-weight:500;color:var(--ink);margin-bottom:18px;display:inline-block;letter-spacing:-.005em}
.pa-office-tel:hover{color:var(--rust)}
.pa-office-addr{font-style:normal;color:var(--ink-2);font-size:15px;line-height:1.7;margin-bottom:28px}
.pa-office iframe{width:100%;height:280px;border:0;border-radius:2px;filter:grayscale(.5) contrast(.95)}

/* ─────────── FORMULAIRE CONTACT ─────────── */
.pa-contact{padding:100px 36px;background:var(--paper-2)}
.pa-contact-in{max-width:680px;margin:0 auto}
.pa-form{display:flex;flex-direction:column;gap:24px;margin-top:48px}
.pa-form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.pa-fg{display:flex;flex-direction:column;gap:8px}
.pa-fg label{
  font-family:ui-monospace,Menlo,monospace;
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);font-weight:700;
}
.pa-fg input,.pa-fg textarea{
  font:inherit;font-size:16px;padding:14px 0;border:none;background:transparent;
  border-bottom:1px solid var(--line);color:var(--ink);
  transition:border-color .25s;
}
.pa-fg input:focus,.pa-fg textarea:focus{outline:none;border-color:var(--rust)}
.pa-fg textarea{resize:vertical;min-height:120px;line-height:1.6;font-family:inherit}
.pa-form-btn{
  align-self:flex-start;
  font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:18px 36px;background:var(--ink);color:var(--paper);
  border-radius:2px;transition:.25s;display:inline-flex;align-items:center;gap:12px;
}
.pa-form-btn:hover{background:var(--rust);transform:translateY(-2px)}
.pa-form-btn .arr{transition:transform .3s}
.pa-form-btn:hover .arr{transform:translateX(4px)}

/* ─────────── CARRIÈRES ─────────── */
.pa-careers-hero{padding:120px 36px 70px;background:var(--paper-2)}
.pa-careers-hero-in{max-width:880px;margin:0 auto;text-align:center}
.pa-careers-list{padding:60px 36px 100px}
.pa-careers-list-in{max-width:880px;margin:0 auto}
.pa-offer{
  padding:40px 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:160px 1fr auto;gap:40px;align-items:center;
}
.pa-offer:last-child{border-bottom:1px solid var(--line)}
.pa-offer-tag{font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--rust);font-weight:700}
.pa-offer-t{font-family:'Fraunces',serif;font-weight:400;font-size:26px;line-height:1.25;color:var(--ink)}
.pa-offer-t em{font-style:italic;color:var(--rust)}
.pa-offer-d{font-size:14px;color:var(--mute);margin-top:6px}
.pa-offer-arr{font-size:24px;color:var(--ink);transition:transform .3s}
.pa-offer:hover .pa-offer-arr{transform:translateX(8px);color:var(--rust)}

/* ─────────── FOOTER ─────────── */
.pa-foot{background:var(--ink);color:var(--paper);padding:80px 36px 36px}
.pa-foot-in{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:60px;padding-bottom:48px;border-bottom:1px solid rgba(232,224,204,.15)}
.pa-foot-mark{font-family:'Fraunces',serif;font-size:32px;font-weight:300;line-height:1;letter-spacing:-.02em}
.pa-foot-mark em{font-style:italic;color:var(--warm)}
.pa-foot-tag{font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);margin-top:14px}
.pa-foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.pa-foot-h{font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--warm);font-weight:700;margin-bottom:16px}
.pa-foot-col a{display:block;color:rgba(232,224,204,.7);font-size:14px;margin-bottom:6px;transition:color .2s}
.pa-foot-col a:hover{color:var(--paper)}
.pa-foot-col address{font-style:normal;font-size:13.5px;line-height:1.6;color:rgba(232,224,204,.6);margin-top:10px}
.pa-foot-bot{max-width:1280px;margin:32px auto 0;display:flex;justify-content:space-between;font-size:12px;color:var(--soft);font-family:ui-monospace,Menlo,monospace;letter-spacing:.04em}

/* ═══════════════════ RESPONSIVE ═══════════════════ */
@media(max-width:980px){
  .pa-side{transform:translateX(-100%);box-shadow:24px 0 40px rgba(26,24,20,.15)}
  .pa-side.open{transform:translateX(0)}
  body.pa-body{padding-left:0}
  .pa-side-trigger{display:flex}
  .pa-side-overlay{display:block}

  .pa-hero{grid-template-columns:1fr;min-height:auto}
  .pa-hero-text{padding:80px 36px 48px;min-height:80vh}
  .pa-hero-img{aspect-ratio:16/10}
  .pa-about-grid{grid-template-columns:1fr;gap:48px}
  .pa-about-side{position:relative;top:0}
  .pa-grid{grid-template-columns:repeat(6,1fr);gap:18px}
  .pa-project{--span:3}
  .pa-project.span-6{--span:6}
  .pa-project.span-8{--span:6}
  .pa-team-grid{grid-template-columns:repeat(3,1fr);gap:32px 22px}
  .pa-why-grid{grid-template-columns:1fr;gap:32px}
  .pa-offices-grid{grid-template-columns:1fr;gap:32px}
  .pa-foot-in{grid-template-columns:1fr;gap:36px}
  .pa-foot-cols{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:680px){
  /* Sidebar → drawer */
  .pa-side{transform:translateX(-100%);box-shadow:24px 0 40px rgba(26,24,20,.15)}
  .pa-side.open{transform:translateX(0)}
  body.pa-body{padding-left:0}
  .pa-side-trigger{display:flex}
  .pa-side-overlay{display:block}

  body.pa-body{font-size:15px}
  .pa-nav-in{padding:14px 20px}
  .pa-nav-links{display:none}
  .pa-nav-burger{display:flex}
  .pa-hero-text{padding:70px 24px 40px}
  .pa-hero-img{aspect-ratio:4/3}
  .pa-hero-caption{font-size:10px;bottom:20px;left:20px;right:20px}
  .pa-hero-caption b{font-size:15px}
  .pa-hero-meta{gap:24px;font-size:12px}
  .pa-sec,.pa-about,.pa-projects,.pa-why,.pa-offices,.pa-contact{padding:80px 22px}
  .pa-sec-head,.pa-why-head{margin-bottom:48px}
  .pa-about-year{font-size:64px}
  .pa-about-quote{font-size:22px;padding-left:18px;margin:32px 0}
  .pa-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .pa-project,.pa-project.span-6,.pa-project.span-8{--span:1;aspect-ratio:4/5;grid-column:span 1}
  .pa-project.tall{grid-column:span 2;aspect-ratio:3/4}
  .pa-project-info{left:14px;right:14px;bottom:14px;transform:translateY(0);opacity:1}
  .pa-project::after{opacity:.85}
  .pa-project-name{font-size:18px}
  .pa-team-grid{grid-template-columns:repeat(2,1fr);gap:28px 16px}
  .pa-member-name{font-size:16px}
  .pa-office{padding:32px 24px}
  .pa-office-city{font-size:36px}
  .pa-form-row{grid-template-columns:1fr}
  .pa-offer{grid-template-columns:1fr;gap:14px;padding:32px 0}
  .pa-foot-cols{grid-template-columns:1fr;gap:32px}
  .pa-foot-bot{flex-direction:column;gap:8px;text-align:left}
}

/* ─────────── ANIMATIONS REVEAL ─────────── */
.pa-reveal{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.2,.9,.3,1),transform .9s cubic-bezier(.2,.9,.3,1)}
.pa-reveal.pa-visible{opacity:1;transform:none}
.pa-reveal.d1{transition-delay:.08s}
.pa-reveal.d2{transition-delay:.16s}
.pa-reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.pa-reveal{opacity:1;transform:none}*{animation:none!important;transition:none!important}}

/* ═════════════ PAGE PROJETS ═════════════ */
.pa-proj-hero{
  padding: 110px 64px 50px;
  background: var(--paper);
  max-width: 1440px;
  margin: 0 auto;
}
.pa-proj-hero-in{ max-width: 1100px }
.pa-proj-eyebrow{
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 36px;
}
.pa-proj-h1{
  font-family: var(--serif, 'Fraunces', serif);
  font-weight: 400;
  font-size: clamp(42px, 6vw, 88px);
  line-height: .94;
  letter-spacing: -.025em;
  margin: 0 0 40px;
  color: var(--ink);
}
.pa-proj-h1 em{
  font-style: italic;
  color: var(--rust);
  font-feature-settings: "ss01", "dlig";
}
.pa-proj-lead{
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink-soft, var(--mute));
  max-width: 620px;
  margin: 0;
}

/* ── Filtres ── */
.pa-proj-filter{
  padding: 24px 64px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0;
  background: rgba(253, 251, 246, .92);
  backdrop-filter: blur(20px);
  z-index: 40;
  max-width: 1440px;
  margin: 0 auto;
}
.pa-proj-filter-in{
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.pa-proj-chip{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mute);
  text-decoration: none;
  padding: 10px 16px;
  border: 1px solid transparent;
  border-radius: 0;
  transition: all .25s ease;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.pa-proj-chip:hover{ color: var(--ink); border-color: var(--line) }
.pa-proj-chip.on{
  color: var(--ink);
  border-color: var(--ink);
}
.pa-proj-chip .n{
  font-size: 9px;
  opacity: .5;
  letter-spacing: 0;
}

/* ── Grille projets ── */
.pa-proj-grid-sec{ padding: 80px 64px 100px; max-width: 1440px; margin: 0 auto }
.pa-proj-grid{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 60px 40px;
}
@media (max-width: 1100px){
  .pa-proj-grid{ grid-template-columns: 1fr 1fr; gap: 50px 32px }
  .pa-proj-hero, .pa-proj-filter, .pa-proj-grid-sec, .pa-proj-foot{ padding-left: 40px; padding-right: 40px }
}
@media (max-width: 700px){
  .pa-proj-grid{ grid-template-columns: 1fr; gap: 50px }
  .pa-proj-hero, .pa-proj-filter, .pa-proj-grid-sec, .pa-proj-foot{ padding-left: 24px; padding-right: 24px }
  .pa-proj-hero{ padding-top: 72px }
}

.pa-proj-card{
  display: block;
  text-decoration: none;
  color: inherit;
  position: relative;
}
.pa-proj-card.big{ grid-column: span 2 }
@media (max-width: 1100px){ .pa-proj-card.big{ grid-column: span 2 } }
@media (max-width: 700px){ .pa-proj-card.big{ grid-column: span 1 } }

.pa-proj-img-wrap{
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--paper-2, #efeae0);
}
.pa-proj-card.big .pa-proj-img-wrap{ aspect-ratio: 16/9 }
.pa-proj-img-wrap img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .9s cubic-bezier(.2, .8, .2, 1), filter .4s;
  display: block;
}
.pa-proj-card:hover .pa-proj-img-wrap img{
  transform: scale(1.04);
  filter: brightness(1.04);
}

.pa-proj-badge{
  position: absolute; top: 14px; left: 14px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .15em;
  text-transform: uppercase;
  background: rgba(255,255,255,.92);
  color: var(--ink);
  padding: 6px 10px;
  border-radius: 0;
}

/* ── Métadonnées projet ── */
.pa-proj-meta{
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 20px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.pa-proj-num{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--mute);
  letter-spacing: .1em;
  line-height: 1.4;
}
.pa-proj-name{
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -.01em;
  margin: 0 0 6px;
  color: var(--ink);
  line-height: 1.15;
}
.pa-proj-card.big .pa-proj-name{ font-size: 28px }
.pa-proj-tags{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--mute);
  display: flex;
  gap: 8px;
  align-items: center;
}
.pa-proj-tags .dot{ opacity: .4 }
.pa-proj-side{
  text-align: right;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--mute);
  line-height: 1.4;
}
.pa-proj-side .y{ display: block; color: var(--ink); font-weight: 500 }
.pa-proj-side .a{ display: block; font-size: 10px; margin-top: 2px }

.pa-proj-card:hover .pa-proj-name{ color: var(--rust); transition: color .3s }

/* ── Footer CTA ── */
.pa-proj-foot{
  padding: 80px 64px 100px;
  max-width: 1440px;
  margin: 0 auto;
  border-top: 1px solid var(--line);
}
.pa-proj-foot-in{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 60px;
  align-items: end;
}
@media (max-width: 800px){ .pa-proj-foot-in{ grid-template-columns: 1fr } }
.pa-proj-foot-eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 24px;
}
.pa-proj-foot-h{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.05;
  letter-spacing: -.02em;
  margin: 0;
  color: var(--ink);
}
.pa-proj-cta{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  padding: 16px 28px;
  border: 1px solid var(--ink);
  transition: all .25s;
}
.pa-proj-cta:hover{
  background: var(--ink);
  color: #fff;
}
.pa-proj-cta .arr{ transition: transform .25s }
.pa-proj-cta:hover .arr{ transform: translateX(4px) }

/* ─── Suppression des eyebrows (style trop générique) ─── */
.pa-hero-eyebrow,
.pa-sec-eyebrow,
.pa-proj-eyebrow,
.pa-proj-foot-eyebrow,
.pa-careers-eyebrow{
  display: none !important;
}

/* ════════════════════════════════════════════════════════════
   PLA — DESIGN PASS v2
   Système typographique + palette + interactions
   ════════════════════════════════════════════════════════════ */

:root{
  /* Palette resserrée */
  --pa-ink: #1a1814;
  --pa-paper: #fdfbf6;
  --pa-paper-2: #f5f1e7;
  --pa-line: rgba(26, 24, 20, .12);
  --pa-mute: #6b665b;
  --pa-rust: #b8553b;          /* Pour italiques typographiques UNIQUEMENT */
  --pa-forest: #2c4733;        /* Nouveau second accent — chips, badges, indicateurs */
  --pa-warm: #c89968;          /* Conservé pour compatibilité */
}

/* ─── Hiérarchie typographique claire ─── */
.pa-h1,
.pa-sec-h2,
.pa-proj-h1,
.pa-careers-hero h1{
  font-feature-settings: "ss01" 1, "dlig" 1, "liga" 1;
  letter-spacing: -.025em;
  font-weight: 400;
}

/* H1 — plus grand, plus aéré */
.pa-h1{
  font-size: clamp(56px, 9vw, 124px);
  line-height: .92;
}

/* H2 — visiblement différencié */
.pa-sec-h2{
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: 1.05;
  font-weight: 400;
}

/* H3 — surtout pour cards / membres */
.pa-member-name{
  font-feature-settings: "liga" 1;
  letter-spacing: -.005em;
}

/* Italique = rust UNIQUEMENT — appliqué seulement aux <em> */
.pa-h1 em,
.pa-sec-h2 em,
.pa-proj-h1 em,
.pa-careers-hero h1 em{
  font-style: italic;
  color: var(--pa-rust);
  font-feature-settings: "ss01" 1, "dlig" 1, "liga" 1, "calt" 1;
  font-weight: 400;
}

/* ─── Petites capitales propres ─── */
.pa-tag,
.pa-member-role,
.pa-side-foot-block .city,
.pa-side-foot-stamp,
.pa-side-nav .num,
.pa-proj-tags,
.pa-proj-chip,
.pa-proj-num,
.pa-proj-side,
.pa-page-mark,
.pa-page-mark-mono{
  font-feature-settings: "smcp" 1, "c2sc" 1;
  text-transform: none !important;
}

/* Fallback pour navigateurs qui ne supportent pas small-caps : keep uppercase mais ajuster letter-spacing */
@supports not (font-feature-settings: "smcp" 1) {
  .pa-tag, .pa-member-role, .pa-side-foot-stamp, .pa-proj-tags,
  .pa-proj-chip, .pa-side-foot-block .city {
    text-transform: uppercase !important;
    letter-spacing: .15em;
  }
}

/* ─── Liens textes : underline reveal au hover ─── */
.pa-side-nav a,
.pa-offer,
.pa-foot-col a{
  position: relative;
}

.pa-side-nav a .lbl{
  position: relative;
  display: inline-block;
}
.pa-side-nav a .lbl::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -3px;
  height: 1px;
  background: var(--pa-ink);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .35s cubic-bezier(.2, .8, .2, 1);
}
.pa-side-nav a:hover .lbl::after{
  transform: scaleX(1);
  transform-origin: left;
}
.pa-side-nav a.on .lbl::after{
  transform: scaleX(1);
  background: var(--pa-rust);
}

/* Flèche → qui apparaît au hover de la nav */
.pa-side-nav a .arr{
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .3s, transform .3s;
  color: var(--pa-rust);
}
.pa-side-nav a:hover .arr,
.pa-side-nav a.on .arr{
  opacity: 1;
  transform: translateX(0);
}

/* ─── Curseur custom sur cards projets ─── */
.pa-cursor{
  position: fixed;
  top: 0; left: 0;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--pa-ink);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  pointer-events: none;
  z-index: 9999;
  opacity: 0;
  transition: opacity .25s cubic-bezier(.2, .8, .2, 1), transform .1s linear;
  mix-blend-mode: difference;
}
.pa-cursor svg{ display: block }
.pa-cursor.on{ opacity: 1 }
@media (pointer: coarse){ .pa-cursor{ display: none } }

/* Sur les cards projet, masquer le curseur natif */
.pa-proj-card{ cursor: none }
@media (pointer: coarse){ .pa-proj-card{ cursor: pointer } }

/* ─── Sidebar plus svelte + équilibrée ─── */
.pa-side{ width: 240px !important }


/* ─── Section dividers : traits de cotation ─── */
.pa-sec + .pa-sec,
.pa-projects + .pa-sec,
.pa-about + .pa-projects,
.pa-projects + .pa-why,
.pa-why + .pa-offices{
  border-top: 1px solid var(--pa-line);
}

/* ─── Forest accent : badges, chips actifs ─── */
.pa-proj-chip.on{
  border-color: var(--pa-forest) !important;
  color: var(--pa-forest) !important;
}
.pa-proj-badge{
  background: var(--pa-forest) !important;
  color: #fff !important;
  font-weight: 500;
}

/* Numéros séquentiels — en forest (pas rust qui est réservé italiques) */
.pa-side-nav .num{
  color: var(--pa-mute);
  font-feature-settings: "tnum" 1;
}
.pa-side-nav a.on .num{ color: var(--pa-rust) }

/* Numéros projets en mono propre */
.pa-proj-num{
  font-feature-settings: "tnum" 1;
  font-variant-numeric: tabular-nums;
}

/* ─── Curseur custom sur tout le site (cursor follow optionnel) ─── */
/* Désactivé par défaut, peut être activé plus tard */

/* ─── Refonte page "PROJET EN VEDETTÉ" qui jurait ─── */
.pa-hero-caption b,
.pa-projet-en-vedette{
  color: var(--pa-paper) !important;
}

/* ─── Drop caps sur premier paragraphe de l'intro ─── */
.pa-about p:first-of-type::first-letter{
  font-family: var(--serif, 'Fraunces', serif);
  font-size: 5.5em;
  font-weight: 400;
  float: left;
  line-height: .85;
  margin: 6px 12px 0 0;
  color: var(--pa-rust);
  font-feature-settings: "ss01" 1;
}

/* ─── Métadonnées projet : crédit photo et architecte responsable ─── */
.pa-proj-credit{
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 10px;
  letter-spacing: .08em;
  color: var(--pa-mute);
  margin-top: 6px;
  opacity: .7;
}

/* ─── Page Projets : meta réorganisée pour pas chevaucher ─── */
.pa-proj-meta{
  grid-template-columns: 36px 1fr 90px !important;
}
.pa-proj-side .y{
  font-feature-settings: "tnum" 1;
}

/* ─── Mobile : retomber sur layout single column ─── */


/* ════════════════════════════════════════════════════════════
   PHOTOS — Adoucir pixellisation par sources trop petites
   ════════════════════════════════════════════════════════════ */

/* Projets — grille 4 colonnes (au lieu de 3) → cards plus petites = moins de stretch */
@media (min-width: 1100px){
  .pa-proj-grid{
    grid-template-columns: 1fr 1fr 1fr 1fr !important;
    gap: 40px 24px !important;
  }
  /* Featured = span 2 sur 4 col = même taille relative */
  .pa-proj-card.big{ grid-column: span 2 !important }
}
@media (min-width: 1400px){
  .pa-proj-grid{
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 48px 28px !important;
  }
}

/* Photos projets — filtre subtil qui masque la pixellisation */
.pa-proj-img-wrap img{
  image-rendering: auto;
  filter: contrast(1.04) saturate(.96);
  transition: transform .9s cubic-bezier(.2, .8, .2, 1), filter .4s;
}
.pa-proj-card:hover .pa-proj-img-wrap img{
  filter: contrast(1.06) saturate(1) brightness(1.02);
}

/* Légère atténuation des bordures dures sur petites images */
.pa-proj-img-wrap{
  position: relative;
}
.pa-proj-img-wrap::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 70%, rgba(26,24,20,.06) 100%);
  pointer-events: none;
}

/* Réduire la taille du titre dans 4-col grid (plus de cards = moins de place) */
@media (min-width: 1100px){
  .pa-proj-name{ font-size: 18px !important }
  .pa-proj-card.big .pa-proj-name{ font-size: 22px !important }
}

/* ─── Photos équipe ─── */
/* Sources sont 221x230 (carré) ou 221x370 (portrait).
   Cards display naturellement à ~290px = 30% stretch.
   On réduit à ~240px max + filtre */
.pa-team-grid{
  grid-template-columns: repeat(5, 1fr) !important;
  gap: 32px 20px !important;
  max-width: 1200px;
  margin: 0 auto;
}
@media (max-width: 1100px){
  .pa-team-grid{ grid-template-columns: repeat(4, 1fr) !important }
}
@media (max-width: 800px){
  .pa-team-grid{ grid-template-columns: repeat(3, 1fr) !important; gap: 24px 14px !important }
}
@media (max-width: 500px){
  .pa-team-grid{ grid-template-columns: repeat(2, 1fr) !important }
}

.pa-member-photo img{
  image-rendering: auto;
  filter: grayscale(1) contrast(1.05);
  transition: filter .35s ease;
}
.pa-member:hover .pa-member-photo img{
  filter: grayscale(.85) contrast(1.08) brightness(1.03);
}

/* Card photo plus petite */
.pa-member-photo{
  max-height: 280px;
  aspect-ratio: 4/5;
}

/* ─── Photos accueil (hero) ─── */
/* Photo hero principale — peut bénéficier d'un léger flou si trop pixellisé */
.pa-hero-img img,
.pa-projects img,
.pa-about img,
.pa-projet-vedette img{
  image-rendering: auto;
  filter: contrast(1.03);
}

/* Effet général : éviter le crénelage typique des images JPEG petites */
img{
  image-rendering: auto;
  -webkit-backface-visibility: hidden;
}

/* ════════════════════════════════════════════
   MOBILE — Header avec logo visible
   ════════════════════════════════════════════ */
.pa-mobile-header{
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 72px;
  background: rgba(253, 251, 246, .96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 105;
  border-bottom: 1px solid var(--line);
  padding: 0 18px 0 76px; /* 76px = espace pour le burger 44+18+14 */
  align-items: center;
}
.pa-mobile-header a{
  display: inline-flex;
  align-items: center;
}
.pa-mobile-header img{
  height: 38px;
  width: auto;
  display: block;
}

@media (max-width: 980px){
  .pa-mobile-header{ display: flex }
  /* On laisse de l'espace au contenu pour que le header ne cache pas */
  body.pa-body{ padding-top: 72px }
  /* Décaler la sidebar drawer pour ne pas chevaucher le header burger */
  .pa-side-trigger{ top: 14px }
}
