
*{box-sizing:border-box}

body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;line-height:1.6;color:#0a0a0a;background:#fff}

img{max-width:100%;height:auto;display:block}

a{color:inherit;text-decoration:none}

a:focus-visible{outline:2px solid #000;outline-offset:3px}

.container{max-width:1200px;margin:0 auto;padding:clamp(16px,3vw,32px)}

.site-header{position:sticky;top:0;z-index:20;display:flex;gap:16px;align-items:center;justify-content:space-between;padding:12px 20px;background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid #eee}

.site-header .brand{font-weight:700}

.site-header nav{display:flex;gap:16px}

.site-header nav a{padding:8px 10px;border-radius:10px}

.site-header nav a.active,.site-header nav a:hover{background:#f2f2f2}

.site-header .lang{display:flex;gap:8px;align-items:center;color:#555}

.intro{text-align:center;margin-block:10px 20px}

.intro .lede{color:#666;margin:6px auto 0;max-width:60ch}

.grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-block:10px 40px}

.grid-6 figure{margin:0;border-radius:14px;overflow:hidden;border:1px solid #eee;box-shadow:0 1px 6px rgba(0,0,0,.04)}

.grid-6 img{aspect-ratio:3/2;object-fit:contain;background:#fafafa}


/* Responsive gallery grid for gallery pages
   Uses the same 3‑column layout as the home page but supports any number of items. */
.grid-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-block:10px 40px;
}

.grid-gallery figure{
  margin:0;
  border-radius:14px;
  overflow:hidden;
  border:1px solid #eee;
  box-shadow:0 1px 6px rgba(0,0,0,.04);
}

.grid-gallery img{
  aspect-ratio:3/2;
  object-fit:contain;
  background:#fafafa;
}


/* Category grid used on the galleries overview page */
.grid-categories{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:24px;
  margin-block:20px 40px;
}

.category-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  border:1px solid #eee;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 1px 6px rgba(0,0,0,.04);
  background:#fff;
  text-decoration:none;
  color:inherit;
}

.category-card img{
  width:100%;
  height:auto;
  aspect-ratio:3/2;
  object-fit:cover;
}

.category-card h2{
  font-size:1.1rem;
  margin:12px 0;
}

.site-footer{border-top:1px solid #eee;padding:20px;text-align:center;color:#666}

@media (prefers-reduced-motion: reduce){html:focus-within{scroll-behavior:auto}
}
@media (max-width:900px){.grid-6{grid-template-columns:1fr 1fr}
}
@media (max-width:580px){.grid-6{grid-template-columns:1fr}
}

/* === layout fixes (added by build) === */
.logo{display:flex;justify-content:center;align-items:center;text-align:center}


.bio{max-width:75ch;margin:clamp(12px,2.5vw,24px) auto;padding-inline:clamp(8px,2vw,16px)}

.bio p{margin:0 0 1em}

@media (max-width:680px){
  .bio{max-width:60ch}

}

/* === logo sizing fix (single + smaller) === */
.logo{display:flex;justify-content:center;align-items:center;text-align:center}



/* === lang flags === */
.lang img{display:inline-block; vertical-align:middle; border-radius:2px; box-shadow:0 0 0 1px rgba(0,0,0,.06)}

/* === logo encore réduit (75% de moins) === */
.logo img{
  display:block;
  margin:auto;
  max-width:clamp(60px,10vw,72px);
  height:auto;
}


/* === unified layout (auto) === */
.logo{display:flex;justify-content:center;align-items:center;text-align:center}

.logo img{display:block;margin:auto;max-width:clamp(60px,10vw,72px);height:auto}
 }

.lang img{display:inline-block;vertical-align:middle;border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.06)}

/* === SEO+UI sanity (v4.1) === */
.grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-block:10px 28px}
.grid-6 figure{margin:0;border-radius:14px;overflow:hidden;border:1px solid #eee;box-shadow:0 1px 6px rgba(0,0,0,.05);background:#fff}
.logo-card{background:#fff}
.logo-card img{width:100%;height:100%;object-fit:contain;background:#fff;aspect-ratio:1/1}
@media (min-width:901px){ .grid-6 .logo-card{grid-column:2;grid-row:1} }
@media (max-width:900px){ .grid-6{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .grid-6{grid-template-columns:1fr} }
footer{border-top:1px solid #eee;margin-top:24px;padding:16px 0;color:#666;font-size:.95rem}


/* === v4.2 additions === */
.cta{display:flex;justify-content:center;margin:12px 0 24px}
.btn{display:inline-block;padding:10px 16px;border-radius:999px;border:1px solid #ddd;text-decoration:none}
.btn:hover{box-shadow:0 2px 10px rgba(0,0,0,.06)}
