:root {
  --off-white: #f4f1e8;
  --deep-black: #111111;
  --editorial-red: #c5312e;
  --font-title: "Bebas Neue", Impact, "Arial Narrow", sans-serif;
  --font-article: "EB Garamond", Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: #0d0d0d;
  color: var(--off-white);
  font-family: var(--font-article);
  line-height: 1.8;
}

.site-main { min-height: 100svh; padding-bottom: 7rem; }
.layout { width: min(1200px, 100% - 2.2rem); margin-inline: auto; }

.hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: end;
}
.hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.06);
  transition: opacity .8s ease;
}
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.25)); }
.hero__content { position: relative; z-index: 5; padding: 0 0 4.6rem; }
.hero__title { margin: 0; font-family: var(--font-title); text-transform: uppercase; letter-spacing: .06em; font-size: clamp(2.3rem, 6vw, 5.2rem); line-height: .95; }
.hero__subtitle { margin-top: .7rem; text-transform: uppercase; font-size: .86rem; letter-spacing: .16em; opacity: .88; }
.hero__quote {
  position: absolute;
  inset-inline: 1rem;
  bottom: 2.2rem;
  z-index: 6;
  text-align: center;
  font-family: var(--font-article);
  font-style: italic;
  font-size: clamp(1rem, 2.3vw, 1.4rem);
  transition: opacity .45s ease, transform .45s ease;
}
.hero__quote.is-hidden { opacity: 0; transform: translateY(-8px); }

.logo-badge {
  position: fixed;
  top: 1rem;
  left: 1rem;
  z-index: 10;
  text-decoration: none;
  color: #fff;
  background: var(--editorial-red);
  border: 2px solid rgba(255,255,255,.45);
  border-radius: 14px;
  padding: 1rem 1.2rem;
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  opacity: 1;
  transform: translateY(0);
  transition: opacity .25s ease, transform .25s ease, background-color .25s ease, border-color .25s ease;
}
@media (max-width: 899px) {
  .logo-badge {
    display: block;
  }
  body.mobile-scrolled .logo-badge {
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
  }
}
.logo-badge__line {
  margin: 0;
  font-family: var(--font-title);
  text-transform: uppercase;
  letter-spacing: .05em;
  line-height: .94;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
}
.logo-badge__suffix {
  display: inline-block;
  margin-left: .16rem;
  font-size: .42em;
  line-height: 1;
  letter-spacing: .02em;
  text-transform: none;
  vertical-align: super;
  opacity: .9;
}
.logo-badge__sub {
  margin: .5rem 0 0;
  border-top: 1px solid rgba(255,255,255,.35);
  padding-top: .5rem;
  line-height: 1.15;
  font-size: .52rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .88;
}

/* Safety override: keep logo always visible even with stale cached classes. */
body.is-scrolling .logo-badge,
body.logo-idle .logo-badge,
body.is-top .logo-badge {
  opacity: 1 !important;
  transform: translateY(0) !important;
  background: var(--editorial-red) !important;
  border-color: rgba(255,255,255,.45) !important;
}

.lang-float {
  position: fixed;
  top: .8rem;
  right: .8rem;
  z-index: 70;
  display: inline-flex;
  gap: .3rem;
  padding: .25rem;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(0,0,0,.42);
  border-radius: 999px;
  backdrop-filter: blur(4px);
}
.lang-float a {
  text-decoration: none;
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .11em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: .32rem .7rem;
}
.lang-float a.is-active { background: #fff; color: #000; }

.four-grid {
  margin: 3rem auto;
  display: grid;
  gap: 1rem;
}
@media (min-width: 900px) {
  .four-grid { grid-template-columns: 1fr 1fr; }
}

.panel {
  border: 2px solid #171717;
  border-radius: 16px;
  background: #ece7da;
  color: #111;
  overflow: visible;
}
.panel--small {
  aspect-ratio: var(--art-ratio, 21 / 29.7);
  height: auto;
  min-height: 0;
}
.panel--large { min-height: 34rem; }
.panel--text { overflow: auto; }
.panel--image { position: relative; overflow: hidden; }
.panel__img-wrap { margin: .5rem; border-radius: 12px; overflow: hidden; height: calc(100% - 1rem); position: relative; }
.panel__ribbon {
  position: absolute;
  top: .7rem;
  right: .7rem;
  z-index: 3;
  min-width: 0;
  text-align: center;
  background: color-mix(in srgb, var(--editorial-red) 88%, black);
  color: #fff;
  font-family: var(--font-title);
  font-size: .68rem;
  letter-spacing: .09em;
  text-transform: uppercase;
  padding: .26rem .52rem;
  border: 1px solid rgba(255,255,255,.42);
  border-radius: .42rem;
  transform: none;
  box-shadow: 0 5px 16px rgba(0,0,0,.3);
}
.panel__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%) contrast(1.2);
  transition: filter .35s ease, transform .35s ease;
  display: block;
}
.panel--image:hover .panel__img-wrap img {
  filter: grayscale(0%) contrast(1.06);
}
.panel__index {
  position: absolute; left: .7rem; top: .7rem;
  width: 1.8rem; height: 1.8rem; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.75); color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--font-title);
  font-size: .9rem;
  line-height: 1;
  letter-spacing: .03em;
  font-weight: 400;
}
.panel__hover {
  position: absolute; left: .8rem; right: .8rem; bottom: .8rem;
  background: rgba(0,0,0,.65);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff; padding: .55rem .72rem; border-radius: .5rem;
  display: flex;
  flex-direction: column;
  opacity: 0; transform: translateY(6px); transition: .28s ease;
}
.panel--image:hover .panel__hover { opacity: 1; transform: translateY(0); }
.panel__hover-title { font-family: var(--font-title); font-size: 1rem; text-transform: uppercase; margin: 0; letter-spacing: .06em; }
.panel__hover-desc { margin: .25rem 0 0; font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; }
.panel__hover-row {
  margin-top: .35rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .55rem;
}
.panel__hover-row .panel__hover-desc {
  margin: 0;
}
.panel__hover-link {
  display: inline-flex;
  margin-top: 0;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 999px;
  padding: .32rem .6rem;
  font-size: .6rem;
  line-height: 1;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
  color: #fff;
}
.panel__hover-link:hover {
  background: #fff;
  color: #000;
}

.panel--text { padding: 1.3rem; display: flex; flex-direction: column; }
.panel__kicker { margin: 0 0 .6rem; font-size: .68rem; letter-spacing: .15em; text-transform: uppercase; color: #2d2d2d; }
.panel__title {
  margin: 0 0 .8rem;
  font-family: var(--font-title);
  text-transform: uppercase;
  letter-spacing: .05em;
  line-height: 1.1;
  font-size: clamp(2rem, 4vw, 3.5rem);
}
.panel__title.is-red { color: var(--editorial-red); }
.panel__body { margin: 0; font-family: var(--font-article); font-size: clamp(1.18rem, 1.5vw, 1.34rem); line-height: 1.75; color: #222; font-weight: 400; }
.panel__list {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: .45rem;
}
.panel__list li {
  margin: 0;
}
.panel__legend {
  display: block;
  margin-top: .7rem;
  font-family: var(--font-article);
  font-style: italic;
  font-weight: 400;
  font-size: .9em;
  line-height: 1.45;
  color: rgba(17, 17, 17, .78);
}
.panel__cta {
  margin-top: auto;
  text-decoration: none;
  align-self: start;
  border: 1px solid #111;
  border-radius: 999px;
  padding: .75rem 1.3rem;
  font-size: .7rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #111;
}
.panel__cta:hover { background: #111; color: var(--off-white); }
.contact-form-wrap {
  margin-top: 1.15rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(17, 17, 17, .2);
}
.contact-form__title {
  margin: 0 0 .55rem;
  font-family: var(--font-title);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 1.45rem;
  line-height: 1;
}
.contact-form__notice {
  margin: 0 0 .7rem;
  border-radius: .5rem;
  padding: .45rem .6rem;
  font-size: .95rem;
  line-height: 1.4;
}
.contact-form__notice.is-success {
  background: rgba(21, 110, 55, .12);
  border: 1px solid rgba(21, 110, 55, .35);
  color: #0f5e33;
}
.contact-form__notice.is-error {
  background: rgba(197, 49, 46, .1);
  border: 1px solid rgba(197, 49, 46, .38);
  color: #8e1b1a;
}
.contact-form {
  display: grid;
  gap: .45rem;
}
.contact-form__label {
  font-size: .88rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(17, 17, 17, .8);
}
.contact-form__input,
.contact-form__textarea {
  width: 100%;
  border: 1px solid rgba(17, 17, 17, .35);
  border-radius: .55rem;
  background: #f8f4ea;
  color: #111;
  padding: .58rem .65rem;
  font-family: var(--font-article);
  font-size: 1rem;
}
.contact-form__input:focus,
.contact-form__textarea:focus {
  outline: 2px solid rgba(197, 49, 46, .42);
  outline-offset: 0;
}
.contact-form__textarea {
  min-height: 9rem;
  resize: vertical;
}
.contact-form__checkbox {
  margin-top: .35rem;
  display: flex;
  gap: .5rem;
  align-items: flex-start;
  font-size: .95rem;
  line-height: 1.4;
}
.contact-form__checkbox input {
  margin-top: .22rem;
}
.contact-form__submit {
  margin-top: .5rem;
}
.contact-form__hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.social-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .45rem;
}
.social-item { margin: 0; }
.social-link {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}
.social-link:hover { text-decoration: underline; }
.social-icon {
  width: 1.05rem;
  height: 1.05rem;
  flex: 0 0 auto;
  fill: var(--editorial-red);
}
.social-handle {
  font-size: .95rem;
  letter-spacing: .02em;
}
.social-dot {
  width: .5rem;
  height: .5rem;
  border-radius: 999px;
  background: var(--editorial-red);
  flex: 0 0 auto;
  box-shadow: 0 0 0 1px rgba(17,17,17,.25) inset;
}
.works-intro { display: grid; gap: 1rem; margin: 3rem auto; }
@media (min-width: 900px) { .works-intro { grid-template-columns: 1.2fr .8fr; } }

.about-split {
  display: grid;
  gap: 1rem;
}
@media (min-width: 900px) {
  .about-split {
    grid-template-columns: 1fr 1fr;
  }
}

.work-extra-grid {
  margin-top: 1rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .work-extra-grid {
    grid-template-columns: 1fr 1fr;
  }
  .work-extra-grid > article.panel--small { min-height: 0; }
}

.works-grid {
  display: grid;
  gap: 1.4rem;
  grid-template-columns: 1fr;
}
@media (min-width: 760px) { .works-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1200px) { .works-grid { grid-template-columns: 1fr 1fr 1fr; } }

.work-card { text-decoration: none; color: inherit; display: block; }
.work-image { position: relative; border-radius: 16px; overflow: hidden; border: 1px solid rgba(255,255,255,.2); background: var(--off-white); aspect-ratio: var(--art-ratio, 21 / 29.7); margin-bottom: .7rem; }
.work-image__ribbon {
  position: absolute;
  top: .7rem;
  right: .7rem;
  z-index: 3;
  min-width: 0;
  text-align: center;
  background: color-mix(in srgb, var(--editorial-red) 88%, black);
  color: #fff;
  font-family: var(--font-title);
  font-size: .68rem;
  letter-spacing: .09em;
  text-transform: uppercase;
  padding: .26rem .52rem;
  border: 1px solid rgba(255,255,255,.42);
  border-radius: .42rem;
  transform: none;
  box-shadow: 0 5px 16px rgba(0,0,0,.3);
}
.work-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%) contrast(1.2);
  transition: filter .3s ease, transform .3s ease;
  display: block;
}
.work-card:hover .work-image img {
  filter: grayscale(0%) contrast(1.06);
}

/* Mobile/tactile: pas de survol souris, donc images en couleur par défaut */
@media (hover: none), (pointer: coarse) {
  .panel__img-wrap img,
  .work-image img {
    filter: grayscale(0%) contrast(1.06);
  }
}
.work-meta { border: 2px solid #171717; border-radius: 14px; background: #ece7da; color: #111; padding: .9rem; transition: .22s ease; }
.work-card:hover .work-meta { box-shadow: 0 0 0 1px var(--editorial-red); border-color: var(--editorial-red); }
.work-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: .75rem; }
.badge {
  border-radius: 999px; padding: .2rem .55rem; font-size: .58rem; text-transform: uppercase; letter-spacing: .11em; font-weight: 700;
}
.badge.is-available { background: var(--editorial-red); color: #fff; }
.badge.is-sold { background: rgba(0,0,0,.15); color: rgba(0,0,0,.65); }
.work-title { margin: 0; font-family: var(--font-title); text-transform: uppercase; font-size: 1.8rem; letter-spacing: .05em; line-height: .95; }
.work-year { margin: .2rem 0 0; font-size: .88rem; color: rgba(0,0,0,.65); }
.work-info { margin: .35rem 0 0; font-size: .68rem; text-transform: uppercase; letter-spacing: .11em; color: rgba(0,0,0,.6); }
.work-linkline { margin-top: .9rem; padding-top: .65rem; border-top: 1px solid rgba(0,0,0,.18); display: flex; justify-content: space-between; align-items: center; }
.work-linkline span { font-size: .66rem; text-transform: uppercase; letter-spacing: .11em; }
.arrow {
  width: 1.6rem; height: 1.6rem; border-radius: 999px;
  background: var(--editorial-red); color: #fff;
  display: grid; place-items: center; font-weight: 700;
}

.legal-footer {
  border-top: 1px solid rgba(255,255,255,.2);
  background: #0d0d0d;
  text-align: center;
  padding: 1.5rem 1rem;
  font-size: .72rem;
  color: rgba(244, 241, 232, .72);
}

.bottom-menu {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 50;
  transform: translateY(48px);
  opacity: 0;
  transition: .28s ease;
}
.bottom-menu.is-visible { transform: translateY(0); opacity: 1; }
.bottom-menu__inner {
  width: 100%;
  margin-inline: 0;
  border-top: 1px solid rgba(255,255,255,.25);
  background: color-mix(in srgb, var(--editorial-red) 90%, black);
  box-shadow: 0 -8px 30px rgba(0,0,0,.35);
  padding: .75rem;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}
.bottom-menu__copyright { margin: 0; font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.85); }
.bottom-menu__baseline { margin: .2rem 0 0; font-size: .56rem; letter-spacing: .02em; text-transform: uppercase; color: rgba(255,255,255,.7); white-space: nowrap; }
.bottom-menu__links { display: grid; grid-template-columns: repeat(4, 1fr); gap: .3rem; }
.bottom-menu__links { order: 1; }
.bottom-menu__meta { order: 2; text-align: center; }
.bottom-menu__baseline { display: none; }
.menu-link {
  text-decoration: none;
  text-align: center;
  border: 1px solid rgba(255,255,255,.35);
  border-radius: .42rem;
  background: rgba(0,0,0,.2);
  color: #fff;
  font-family: var(--font-title);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .02em;
  line-height: 1;
  padding: .34rem .24rem;
}
.menu-link:hover { border-color: var(--editorial-red); background: rgba(0,0,0,.45); }
.menu-link.is-active { border-color: var(--editorial-red); background: rgba(0,0,0,.55); }
@media (min-width: 900px) {
  .four-grid--statement > article.panel--small { min-height: 0; }
  .four-grid--statement > article.panel--large {
    aspect-ratio: 1 / 1.6;
    height: auto;
    min-height: 0;
  }
  .logo-badge { top: 2rem; left: 2rem; }
  .lang-float { top: 1.1rem; right: 1.2rem; }
  .bottom-menu__inner { padding: 1rem 2rem; flex-direction: row; align-items: center; justify-content: space-between; gap: .8rem; }
  .bottom-menu__links { display: flex; width: auto; gap: .45rem; }
  .bottom-menu__links { order: 2; }
  .bottom-menu__meta { order: 1; text-align: left; }
  .bottom-menu__baseline { display: block; }
  .menu-link { font-size: .95rem; line-height: 1; padding: .38rem .56rem; }
}
