/* ============================================================
   Galeria Harmonia — main.css
   Direction « Continente » (fond cobalt nuit). Réécrit le Terra Tropical.
   Classes reprises de la maquette de référence (_maquettes/continente/).
   Opacités texte relevées au plancher WCAG AA (cf. _maquettes/continente/DIRECTION.md).
   Tokens : assets/css/tokens.css · Fontes : assets/css/fonts.css
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html,body{
  width:100%;min-height:100%;
  background:var(--cobalt);color:var(--bone);
  font-family:var(--fb);font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font:inherit;}
::selection{background:var(--gold);color:var(--ink);}

:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}

/* skip link */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:999;
  background:var(--gold);color:var(--ink);padding:10px 18px;
  font-family:var(--fm);font-size:12px;letter-spacing:.05em;
}
.skip-link:focus{left:8px;top:8px;}

/* ── nav ───────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:22px 46px;
}
.nav__brand{font-family:var(--fd);font-size:23px;letter-spacing:.005em;color:var(--bone);white-space:nowrap;}
.nav__brand em,.nav__brand span{font-style:italic;color:var(--gold);}
.nav__city{
  font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);flex:1;text-align:center;
}
.nav__menu{display:flex;align-items:center;gap:30px;}
.nav__menu>a{
  font-size:12px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;
  color:var(--bone);opacity:.78;position:relative;transition:opacity .25s;
}
.nav__menu>a:hover,.nav__menu>a[aria-current]{opacity:1;}
.nav__menu>a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--gold);transition:width .3s;}
.nav__menu>a:hover::after,.nav__menu>a[aria-current]::after{width:100%;}
.nav__lang{display:inline-flex;gap:7px;font-family:var(--fm);font-size:11px;letter-spacing:.05em;color:var(--bone-3);}
.nav__lang .is-active{color:var(--gold);}
.nav__lang-sep{color:var(--bone-4);}

main{display:block;}

/* ── generic ───────────────────────────────────────────── */
.band{padding:0 46px;}
.vlabel{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.rule{height:1px;background:var(--rule);}
.bg-bone{background:var(--bone);color:var(--ink);}
.bg-cobalt-d{background:var(--cobalt-d);}

/* color-field : voile dérivé de la palette d'une œuvre (--c1..--c4).
   Source unique harmonia_work_thumbnail(). Posé en absolute dans le
   conteneur de vignette ; le cartel reste au-dessus (z-index). */
.harmonia-cf{position:absolute;inset:0;z-index:0;
  background:linear-gradient(162deg,var(--c1,#5A6B73) 0%,var(--c2,#3A4750) 56%,var(--c3,var(--c2,#1E2A33)) 100%);}
.harmonia-cf::after{content:'';position:absolute;left:0;right:0;bottom:0;height:34%;
  background:linear-gradient(transparent,var(--c4,transparent));opacity:.7;}

/* ── hero ──────────────────────────────────────────────── */
.hero{min-height:100vh;display:grid;grid-template-columns:1.15fr .85fr;align-items:stretch;}
.hero__left{padding:128px 46px 56px;display:flex;flex-direction:column;justify-content:center;position:relative;}
.hero__section-mark{position:absolute;left:46px;top:108px;writing-mode:vertical-rl;font-family:var(--fm);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}
.hero__eyebrow{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-left:38px;}
.hero__title{font-family:var(--fd);font-size:clamp(46px,5.6vw,88px);line-height:1.0;letter-spacing:-.01em;margin:18px 0 0 38px;font-weight:400;}
.hero__title em{font-style:italic;color:var(--gold);}
.hero__sub{margin:30px 0 0 38px;max-width:430px;font-size:15px;line-height:1.75;color:var(--bone-2);}
.hero__meta{margin:38px 0 0 38px;display:flex;gap:34px;font-family:var(--fm);font-size:11px;letter-spacing:.05em;color:var(--bone-3);}
.hero__meta-label{color:var(--gold);font-weight:400;margin-bottom:3px;}
.hero__right{position:relative;overflow:hidden;}
.hero__field{position:absolute;inset:0;background:var(--field-hero);}
.hero__field--has-image{background:var(--cobalt-d);}
.hero__field img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero__cartel{position:absolute;left:34px;bottom:34px;right:34px;}
.hero__cartel-no{font-family:var(--fm);font-size:10px;letter-spacing:.12em;color:var(--gold);}
.hero__cartel-title{font-family:var(--fd);font-style:italic;font-size:26px;margin-top:8px;line-height:1.15;}
.hero__cartel-meta{font-family:var(--fm);font-size:11px;color:var(--bone-2);margin-top:8px;}

/* ── current exhibition strip ──────────────────────────── */
.exhibition{display:grid;grid-template-columns:1fr 1fr;}
.exhibition__content{padding:96px 46px;display:flex;flex-direction:column;justify-content:center;}
.exhibition__label{font-family:var(--fm);font-size:11px;letter-spacing:.14em;color:var(--gold);}
.exhibition__title{font-family:var(--fd);font-size:clamp(34px,4vw,56px);line-height:1.04;margin:20px 0 0;font-weight:400;}
.exhibition__title em{font-style:italic;color:var(--gold);}
.exhibition__dates{font-family:var(--fm);font-size:12px;color:var(--bone-2);margin-top:22px;letter-spacing:.04em;}
.exhibition__intro{max-width:440px;font-size:14.5px;line-height:1.8;color:var(--bone-2);margin-top:26px;}
.exhibition__image{position:relative;overflow:hidden;min-height:440px;background:var(--field-cx);}
.exhibition__image.has-image{background:var(--cobalt-d);}
.exhibition__image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

/* CTA fantôme */
.cta,.exhibition__cta{
  display:inline-flex;align-items:center;gap:11px;margin-top:34px;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:14px 26px;border:1px solid var(--gold);color:var(--gold);background:none;
  font-family:var(--fb);transition:background .3s,color .3s;cursor:pointer;align-self:flex-start;
}
.cta:hover,.exhibition__cta:hover{background:var(--gold);color:var(--ink);}
.cta::after,.exhibition__cta::after{content:'→';}

/* ── artists row ───────────────────────────────────────── */
.artists{padding:96px 0 0;}
.artists__header{display:flex;justify-content:space-between;align-items:baseline;padding:0 46px 30px;}
.artists__title{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:400;}
.artists__link{font-family:var(--fm);font-size:11px;letter-spacing:.06em;color:var(--gold);}
.artists__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);}
.artist-card{background:var(--cobalt);position:relative;overflow:hidden;transition:background .3s;display:block;}
.artist-card:hover{background:var(--cobalt-d);}
.artist-card__image{height:230px;position:relative;overflow:hidden;}
.artist-card__image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.artist-card--frida .artist-card__image{background:var(--field-frida);}
.artist-card--tarsila .artist-card__image{background:var(--field-tarsila);}
.artist-card--forner .artist-card__image{background:var(--field-forner);}
.artist-card__caption{position:absolute;z-index:2;left:14px;bottom:12px;font-family:var(--fm);font-size:10px;letter-spacing:.04em;color:var(--bone-2);}
.artist-card__index{padding:24px 28px 0;font-family:var(--fm);font-size:10px;letter-spacing:.12em;color:var(--gold);}
.artist-card__name{font-family:var(--fd);font-size:27px;margin-top:8px;line-height:1.05;font-weight:400;padding:0 28px;}
.artist-card__dates{font-family:var(--fm);font-size:11px;color:var(--bone-3);margin-top:8px;padding:0 28px 30px;}

/* ── statement / note curatoriale home (bone) ──────────── */
.statement{padding:104px 46px;background:var(--bone);color:var(--ink);}
.statement__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;max-width:1180px;margin:0 auto;}
.statement__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.statement__text{font-family:var(--fd);font-size:clamp(26px,2.7vw,38px);line-height:1.28;letter-spacing:-.01em;color:var(--ink);font-weight:400;}
.statement__text em{font-style:italic;color:var(--crimson);}
.statement__sig{font-family:var(--fm);font-size:11px;letter-spacing:.06em;color:var(--ink-3);margin-top:30px;}

/* ── section header (pages internes) ───────────────────── */
.shead{padding:120px 46px 0;}
.shead__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:26px;}
.shead__title{font-family:var(--fd);font-size:clamp(40px,6vw,80px);line-height:.98;letter-spacing:-.01em;font-weight:400;}
.shead__title em{font-style:italic;color:var(--gold);}
.shead__sub{max-width:560px;margin-top:26px;font-size:15px;line-height:1.8;color:var(--bone-2);}

/* ── note curatoriale large (bone) ─────────────────────── */
.note{padding:104px 46px;background:var(--bone);color:var(--ink);}
.note__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;max-width:1180px;margin:0 auto;}
.note__lead{font-family:var(--fd);font-size:clamp(26px,2.7vw,38px);line-height:1.28;letter-spacing:-.01em;color:var(--ink);font-weight:400;}
.note__lead em{font-style:italic;color:var(--crimson);}
.note__body{font-size:15px;line-height:1.95;color:var(--ink-2);}
.note__body p+p{margin-top:18px;}
.note__sign{font-family:var(--fm);font-size:11px;letter-spacing:.06em;color:var(--ink-3);margin-top:30px;}

/* ── works grid (bone) ─────────────────────────────────── */
.works-band{background:var(--bone);color:var(--ink);}
.works{padding:96px 46px 110px;max-width:1320px;margin:0 auto;}
.works__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:40px;}
.works__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.works__count{font-family:var(--fm);font-size:11px;color:var(--ink-3);}
.works__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 26px;}
.wcard{display:block;}
.wcard__field{position:relative;overflow:hidden;aspect-ratio:4/5;}
.wcard__field img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.wcard__field::after{content:'';position:absolute;inset:0;background:rgba(16,36,63,0);transition:background .35s;}
.wcard:hover .wcard__field::after{background:rgba(16,36,63,.14);}
.wcard__meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;gap:14px;}
.wcard__title{font-family:var(--fd);font-style:italic;font-size:19px;line-height:1.2;color:var(--ink);}
.wcard__year{font-family:var(--fm);font-size:11px;color:var(--ink-3);white-space:nowrap;}
.wcard__artist{font-family:var(--fm);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--crimson);margin-top:6px;}

/* ── artist features ───────────────────────────────────── */
.feat{display:grid;grid-template-columns:.85fr 1.15fr;border-top:1px solid var(--rule);}
.feat--mirror{direction:rtl;}
.feat--mirror>*{direction:ltr;}
.feat__field{position:relative;overflow:hidden;min-height:420px;}
.feat__field img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.feat--frida .feat__field{background:var(--field-frida);}
.feat--tarsila .feat__field{background:var(--field-tarsila);}
.feat--forner .feat__field{background:var(--field-forner);}
.feat__body{padding:72px 56px;display:flex;flex-direction:column;justify-content:center;}
.feat__no{font-family:var(--fm);font-size:11px;letter-spacing:.14em;color:var(--gold);}
.feat__name{font-family:var(--fd);font-size:clamp(36px,4.4vw,58px);line-height:1.0;margin-top:14px;font-weight:400;}
.feat__name em{font-style:italic;color:var(--gold);}
.feat__country{font-family:var(--fm);font-size:12px;color:var(--bone-3);margin-top:14px;letter-spacing:.04em;}
.feat__bio{max-width:520px;font-size:15px;line-height:1.85;color:var(--bone-2);margin-top:26px;}
.feat__works{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px;}
.feat__tag{font-family:var(--fm);font-size:10.5px;letter-spacing:.03em;padding:6px 12px;border:1px solid rgba(244,233,210,.28);color:var(--bone-2);}
.feat__tag em{font-style:italic;}

/* ── visiter / infos ───────────────────────────────────── */
.vis{padding:110px 46px;}
.vis__grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;max-width:1140px;margin:0 auto;}
.vis__quote{font-family:var(--fd);font-size:clamp(26px,3vw,40px);line-height:1.26;letter-spacing:-.01em;font-weight:400;}
.vis__quote em{font-style:italic;color:var(--gold);}
.info{font-family:var(--fm);font-size:12.5px;color:var(--bone-2);}
.info__row{display:flex;justify-content:space-between;gap:24px;padding:14px 0;border-bottom:1px solid var(--rule);}
.info__row b{color:var(--gold);font-weight:400;}
.info__row a:hover{color:var(--gold);}

/* ── press + newsletter (bone) ─────────────────────────── */
.pn{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule-ink);border-top:1px solid var(--rule-ink);border-bottom:1px solid var(--rule-ink);}
.pn__cell{background:var(--bone);padding:64px 46px;color:var(--ink);}
.pn__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.pn__title{font-family:var(--fd);font-size:30px;color:var(--ink);margin:18px 0 14px;font-weight:400;}
.pn__text{font-size:14px;line-height:1.75;color:var(--ink-2);max-width:380px;}
.pn__form{display:flex;margin-top:22px;max-width:400px;}
.pn__form input{flex:1;background:#fff;border:1px solid rgba(16,36,63,.2);border-right:none;padding:13px 16px;font-family:var(--fb);font-size:13px;color:var(--ink);outline:none;}
.pn__form button{background:var(--crimson);color:var(--bone);border:none;padding:13px 22px;font-family:var(--fb);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;}
.pn__link{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--crimson);padding-bottom:3px;}

/* ── footer ────────────────────────────────────────────── */
.footer{background:var(--cobalt-d);padding:72px 46px 40px;}
.footer__top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:30px;}
.footer__brand{font-family:var(--fd);font-size:42px;}
.footer__brand em,.footer__brand span{font-style:italic;color:var(--gold);}
.footer__cols{display:flex;gap:64px;flex-wrap:wrap;}
.footer__col h5{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:400;}
.footer__col a,.footer__col p{display:block;font-size:13px;color:rgba(244,233,210,.72);margin-bottom:9px;line-height:1.5;}
.footer__col a:hover{color:var(--bone);}
.footer__bottom{display:flex;justify-content:space-between;margin-top:56px;padding-top:22px;border-top:1px solid var(--rule);font-family:var(--fm);font-size:10.5px;letter-spacing:.04em;color:var(--bone-4);flex-wrap:wrap;gap:10px;}

/* ============================================================
   PAGES INTERNES — direction Continente
   ============================================================ */

/* ── hero d'archive / single (cobalt) ──────────────────── */
.archive-hero{padding:150px 46px 0;}
.archive-hero__section-mark{font-family:var(--fm);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}
.archive-hero__eyebrow{font-family:var(--fm);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-3);margin-top:22px;}
.archive-hero__title{font-family:var(--fd);font-size:clamp(40px,6vw,82px);line-height:.98;letter-spacing:-.01em;font-weight:400;margin-top:14px;}
.archive-hero__title em{font-style:italic;color:var(--gold);}
.archive-hero__intro{max-width:560px;margin-top:26px;font-size:15px;line-height:1.8;color:var(--bone-2);}
.single-exhibition__subtitle{font-family:var(--fd);font-style:italic;font-size:clamp(20px,2.2vw,28px);color:var(--bone-2);margin-top:14px;}

/* méta (dl mono) */
.single-exhibition__meta{display:flex;flex-wrap:wrap;gap:34px 48px;margin-top:44px;font-family:var(--fm);font-size:12px;}
.single-exhibition__meta dt{color:var(--gold);letter-spacing:.04em;margin-bottom:6px;}
.single-exhibition__meta dd{color:var(--bone-2);line-height:1.6;}
.single-exhibition__meta a:hover{color:var(--gold);}

/* ── essay / note curatoriale (bone) ───────────────────── */
.essay{padding:104px 46px;background:var(--bone);color:var(--ink);}
.essay__inner{display:grid;grid-template-columns:1fr 1.9fr;gap:64px;max-width:1180px;margin:0 auto;}
.essay__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.essay__heading{font-family:var(--fd);font-size:clamp(26px,2.6vw,36px);line-height:1.2;color:var(--ink);font-weight:400;margin-bottom:24px;}
.essay__body{font-size:15px;line-height:1.95;color:var(--ink-2);max-width:620px;}
.essay__p{margin-bottom:18px;}
.essay__p em{font-style:italic;color:var(--crimson);}

/* ── works on view / work-tile (bone) ──────────────────── */
.works-on-view{padding:96px 46px 110px;max-width:1320px;margin:0 auto;background:var(--bone);color:var(--ink);}
.works-on-view__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:40px;gap:20px;flex-wrap:wrap;}
.works-on-view__mark{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.works-on-view__title{font-family:var(--fd);font-size:clamp(26px,2.6vw,38px);font-weight:400;color:var(--ink);}
.works-on-view__grid{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:30px 26px;}
.work-tile__link{display:block;}
.work-tile__image{position:relative;overflow:hidden;aspect-ratio:4/5;}
.work-tile__image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.work-tile__cartel{position:absolute;z-index:2;left:14px;right:14px;bottom:14px;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;}
.work-tile__image::after{z-index:1;}
.work-tile__link:hover .work-tile__cartel{opacity:1;transform:translateY(0);}
.work-tile__image::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(16,36,63,.55));opacity:0;transition:opacity .3s;}
.work-tile__link:hover .work-tile__image::after{opacity:1;}
.work-tile__artist{position:relative;font-family:var(--fm);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--bone);}
.work-tile__title{position:relative;font-family:var(--fd);font-style:italic;font-size:18px;color:var(--bone);margin-top:4px;}
.work-tile__medium{position:relative;font-family:var(--fm);font-size:10px;color:var(--bone-2);margin-top:4px;}
.works__note{font-family:var(--fm);font-size:11px;color:var(--ink-3);margin-top:30px;line-height:1.6;max-width:620px;}

/* ── roster (liste artistes) — feat alternées ──────────── */
.roster{border-top:1px solid var(--rule);}
.roster-row{display:grid;grid-template-columns:80px .85fr 1.15fr;align-items:stretch;border-bottom:1px solid var(--rule);}
.roster-row__index{font-family:var(--fm);font-size:11px;letter-spacing:.1em;color:var(--gold);padding:72px 0 0 46px;}
.roster-row__image{position:relative;overflow:hidden;min-height:360px;display:block;}
.roster-row--frida .roster-row__image{background:var(--field-frida);}
.roster-row--tarsila .roster-row__image{background:var(--field-tarsila);}
.roster-row--forner .roster-row__image{background:var(--field-forner);}
.roster-row__caption{position:absolute;left:16px;bottom:14px;font-family:var(--fm);font-size:10px;letter-spacing:.04em;color:var(--bone-2);}
.roster-row__content{padding:72px 56px;display:flex;flex-direction:column;justify-content:center;}
.roster-row__name{font-family:var(--fd);font-size:clamp(32px,3.6vw,48px);line-height:1.0;font-weight:400;}
.roster-row__dates{font-family:var(--fm);font-size:12px;color:var(--bone-3);margin-top:12px;letter-spacing:.04em;}
.roster-row__bio{font-size:15px;line-height:1.85;color:var(--bone-2);margin-top:22px;max-width:520px;}
.roster-row__stats{display:flex;flex-wrap:wrap;gap:30px;margin-top:28px;font-family:var(--fm);font-size:11px;}
.roster-row__stat dt{color:var(--gold);margin-bottom:5px;letter-spacing:.04em;}
.roster-row__stat dd{color:var(--bone-2);line-height:1.5;}
.roster-row__cta{display:inline-flex;align-self:flex-start;margin-top:30px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:13px 24px;border:1px solid var(--gold);color:var(--gold);transition:background .3s,color .3s;}
.roster-row__cta:hover{background:var(--gold);color:var(--ink);}

/* ── bande de clôture (roster-closing) — cobalt-d ──────── */
.roster-closing{background:var(--cobalt-d);padding:96px 46px;}
.roster-closing__inner{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;max-width:1180px;margin:0 auto;}
.roster-closing__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.roster-closing__text{font-family:var(--fd);font-size:clamp(22px,2.4vw,32px);line-height:1.32;color:var(--bone);font-weight:400;}
.roster-closing__text em{font-style:italic;color:var(--gold);}
.roster-closing__cta{display:inline-flex;margin-top:30px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:13px 24px;border:1px solid var(--gold);color:var(--gold);transition:background .3s,color .3s;}
.roster-closing__cta:hover{background:var(--gold);color:var(--ink);}

/* ── exhibition CTA (presse / lettre) — bone ────────────── */
.exhibition-cta{background:var(--bone);color:var(--ink);padding:96px 46px;}
.exhibition-cta__inner{max-width:1180px;margin:0 auto;}
.exhibition-cta__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);margin-bottom:36px;}
.exhibition-cta__grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;}
.exhibition-cta__title{font-family:var(--fd);font-size:26px;font-weight:400;color:var(--ink);}
.exhibition-cta__text{font-size:14px;line-height:1.75;color:var(--ink-2);margin:14px 0 18px;max-width:380px;}
.exhibition-cta__action{display:inline-flex;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--crimson);padding-bottom:3px;}

/* ── past-list (archive expositions) — cobalt ──────────── */
.past-list{padding:96px 46px 110px;}
.past-list__header{margin-bottom:40px;}
.past-list__title{font-family:var(--fd);font-size:clamp(26px,2.6vw,38px);font-weight:400;}
.past-list__intro{font-size:14px;line-height:1.7;color:var(--bone-2);margin-top:12px;max-width:560px;}
.past-list__items{list-style:none;}
.past-list__link{display:grid;grid-template-columns:80px 60px 1fr auto;gap:24px;align-items:baseline;padding:26px 0;border-top:1px solid var(--rule);transition:padding-left .25s;}
.past-list__item:last-child .past-list__link{border-bottom:1px solid var(--rule);}
.past-list__link:hover{padding-left:10px;}
.past-list__year{font-family:var(--fm);font-size:13px;color:var(--gold);}
.past-list__index{font-family:var(--fm);font-size:11px;color:var(--bone-3);}
.past-list__name{font-family:var(--fd);font-size:22px;font-weight:400;line-height:1.1;}
.past-list__name em{font-style:italic;color:var(--gold);}
.past-list__sub{font-size:13px;color:var(--bone-2);margin-top:6px;}
.past-list__meta{font-family:var(--fm);font-size:11px;color:var(--bone-3);margin-top:8px;}
.past-list__dates{font-family:var(--fm);font-size:11px;color:var(--bone-3);text-align:right;white-space:nowrap;}

/* ── team (about) ──────────────────────────────────────── */
.team{padding:0 46px 104px;}
.team__header{padding:60px 0 36px;}
.team__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.team__title{font-family:var(--fd);font-size:clamp(26px,2.6vw,38px);font-weight:400;margin-top:14px;}
.team__grid{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.team-tile__portrait{aspect-ratio:1/1;margin-bottom:20px;background:var(--cobalt-d);}
.team-tile--ink{background:var(--field-forner);}
.team-tile--terra{background:var(--field-frida);}
.team-tile--cool{background:var(--field-tarsila);}
.team-tile__name{font-family:var(--fd);font-size:22px;font-weight:400;}
.team-tile__role{font-family:var(--fm);font-size:11px;letter-spacing:.06em;color:var(--gold);margin-top:6px;}
.team-tile__bio{font-size:14px;line-height:1.7;color:var(--bone-2);margin-top:14px;}

/* ── method (about) — bone ─────────────────────────────── */
.method{padding:104px 46px;background:var(--bone);color:var(--ink);}
.method__inner{display:grid;grid-template-columns:1fr 1.9fr;gap:64px;max-width:1180px;margin:0 auto;}
.method__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.method__body{max-width:620px;}
.method__title{font-family:var(--fd);font-size:clamp(26px,2.6vw,36px);font-weight:400;color:var(--ink);margin-bottom:24px;}
.method__p{font-size:15px;line-height:1.95;color:var(--ink-2);margin-bottom:18px;}
.method__list-title{font-family:var(--fm);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--crimson);margin:30px 0 14px;}
.method__list{list-style:none;counter-reset:m;}
.method__list li{counter-increment:m;padding:12px 0 12px 38px;position:relative;border-top:1px solid var(--rule-ink);font-size:14px;line-height:1.6;color:var(--ink-2);}
.method__list li::before{content:counter(m,decimal-leading-zero);position:absolute;left:0;top:12px;font-family:var(--fm);font-size:11px;color:var(--crimson);}

/* ── channels (contact) — cobalt ───────────────────────── */
.channels{padding:96px 46px;}
.channels__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:36px;}
.channels__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.channel__title{font-family:var(--fd);font-size:20px;font-weight:400;}
.channel{min-width:0;}
.channel__body{font-family:var(--fm);font-size:12px;line-height:1.7;color:var(--bone-2);margin-top:12px;overflow-wrap:break-word;}
.channel__body a:hover{color:var(--gold);}

/* ── visit (contact) — cobalt ──────────────────────────── */
.visit{padding:96px 46px 0;}
.visit__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:36px;}
.visit__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.visit__block dt{font-family:var(--fm);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.visit__block dd{font-family:var(--fm);font-size:12.5px;line-height:1.7;color:var(--bone-2);}

/* ── form-section / contact-form (bone) ────────────────── */
.form-section{padding:104px 46px;margin-top:96px;background:var(--bone);color:var(--ink);}
.form-section__inner{display:grid;grid-template-columns:1fr 1.9fr;gap:64px;max-width:1180px;margin:0 auto;}
.form-section__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.form-section__title{font-family:var(--fd);font-size:clamp(26px,2.6vw,36px);font-weight:400;color:var(--ink);}
.form-section__intro{font-size:15px;line-height:1.8;color:var(--ink-2);margin:14px 0 30px;max-width:520px;}
.contact-form{max-width:620px;}
.contact-form__row--double{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.contact-form__field{display:block;margin-bottom:20px;}
.contact-form__label-text{display:block;font-family:var(--fm);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--crimson);margin-bottom:8px;}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;background:#fff;border:1px solid rgba(16,36,63,.2);padding:13px 16px;font-family:var(--fb);font-size:14px;color:var(--ink);outline:none;}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--crimson);}
.contact-form__actions{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:8px;}
.contact-form__submit{background:var(--crimson);color:var(--bone);border:none;padding:14px 28px;font-family:var(--fb);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;}
.contact-form__note{font-family:var(--fm);font-size:11px;color:var(--ink-3);}

/* ── single-work : cartel de galerie (cobalt) ──────────── */
.single-exhibition__meta + .works-on-view,.single-work__hero{padding-top:64px;}
.single-work__hero{padding:64px 46px 96px;}
.single-work__figure{max-width:860px;margin:0 auto;}
.single-work__image,.single-work__zoom{display:block;width:100%;position:relative;overflow:hidden;border:none;background:var(--cobalt-d);padding:0;}
.single-work__zoom{cursor:zoom-in;}
.single-work__image--cf{aspect-ratio:4/5;}
.single-work__zoom img,.single-work__image img{width:100%;height:100%;object-fit:contain;max-height:72vh;}
.single-work__figure--cf .single-work__image img{object-fit:cover;}
.single-work__zoom-hint{position:absolute;right:14px;top:14px;font-family:var(--fm);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--bone);background:rgba(16,36,63,.5);padding:6px 10px;}
.single-work__caption{margin-top:28px;text-align:center;}
.single-work__cartel{font-family:var(--fd);font-size:21px;color:var(--bone);}
.single-work__cartel em{font-style:italic;}
.single-work__cartel-medium{display:block;font-family:var(--fm);font-size:11px;color:var(--bone-3);margin-top:8px;letter-spacing:.04em;}
.single-work__credit-note{font-family:var(--fm);font-size:11px;color:var(--bone-3);margin:14px auto 0;max-width:520px;line-height:1.6;}
.single-work__exhibitions{list-style:none;}
.single-work__exhibitions li{border-bottom:1px solid var(--rule);}
.single-work__exhibitions a{display:flex;gap:18px;align-items:baseline;padding:14px 0;}
.single-work__exhibitions a:hover .single-work__exh-name{color:var(--gold);}
.single-work__exh-year{font-family:var(--fm);font-size:12px;color:var(--gold);}
.single-work__exh-name{font-family:var(--fd);font-style:italic;font-size:19px;}

/* lightbox (dialog) */
.lightbox{border:none;padding:0;width:100%;height:100%;max-width:100vw;max-height:100vh;background:rgba(8,22,48,.94);}
.lightbox::backdrop{background:rgba(8,22,48,.9);}
.lightbox__img{max-width:90vw;max-height:90vh;margin:auto;object-fit:contain;}
.lightbox__close{position:fixed;top:20px;right:24px;width:42px;height:42px;border:1px solid rgba(244,233,210,.3);background:none;color:var(--bone);font-size:22px;cursor:pointer;}
.lightbox__close:hover{border-color:var(--gold);color:var(--gold);}

/* ── single-artist : breadcrumb / head / bio / works / cta ─ */
.breadcrumb{padding:120px 46px 0;font-family:var(--fm);font-size:11px;letter-spacing:.05em;color:var(--bone-3);display:flex;gap:12px;align-items:center;}
.breadcrumb a{color:var(--gold);}
.head{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;padding:40px 46px 96px;align-items:center;}
.head__index{font-family:var(--fm);font-size:11px;letter-spacing:.1em;color:var(--gold);}
.head__name{font-family:var(--fd);font-size:clamp(40px,5vw,72px);line-height:1.0;font-weight:400;margin-top:14px;}
.head__name span{display:block;}
.head__meta{display:flex;flex-wrap:wrap;gap:34px 48px;margin-top:34px;font-family:var(--fm);font-size:12px;}
.head__meta-label{color:var(--gold);margin-bottom:6px;letter-spacing:.04em;}
.head__meta-value{color:var(--bone-2);line-height:1.6;white-space:pre-line;}
.head__portrait{position:relative;overflow:hidden;min-height:420px;background:var(--cobalt-d);}
.head__portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.head__portrait--frida{background:var(--field-frida);}
.head__portrait--tarsila{background:var(--field-tarsila);}
.head__portrait--forner{background:var(--field-forner);}
.bio{padding:96px 46px;background:var(--bone);color:var(--ink);}
.bio__inner{display:grid;grid-template-columns:auto 1fr 1fr;gap:48px;max-width:1180px;margin:0 auto;}
.bio__label{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);}
.bio__col{font-size:15px;line-height:1.95;color:var(--ink-2);}
.bio__col p{margin-bottom:18px;}
.bio__col em{font-style:italic;color:var(--crimson);}
.bio + .works,.works{padding:96px 46px 110px;max-width:1320px;margin:0 auto;}
.works__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:40px;gap:20px;flex-wrap:wrap;}
.works__title{font-family:var(--fd);font-size:clamp(26px,2.6vw,38px);font-weight:400;}
.work{display:block;}
.work__index{font-family:var(--fm);font-size:10px;letter-spacing:.12em;color:var(--gold);margin-bottom:10px;}
.work__image{position:relative;overflow:hidden;aspect-ratio:4/5;}
.work__image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.work__title{font-family:var(--fd);font-style:italic;font-size:18px;margin-top:14px;}
.work__year{font-family:var(--fm);font-size:11px;color:var(--bone-3);margin-top:6px;}
.exhibitions{padding:0 46px 104px;}
.exhibitions__inner{display:grid;grid-template-columns:1fr 2.2fr;gap:48px;max-width:1180px;margin:0 auto;}
.exhibitions__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.exhibitions__list{list-style:none;}
.exhibitions__item{display:grid;grid-template-columns:80px 1fr;gap:24px;padding:18px 0;border-top:1px solid var(--rule);}
.exhibitions__year{font-family:var(--fm);font-size:12px;color:var(--gold);}
.exhibitions__name{font-family:var(--fd);font-style:italic;font-size:18px;}
.exhibitions__venue{font-family:var(--fm);font-size:11px;color:var(--bone-3);margin-top:4px;grid-column:2;}
.cta{padding:104px 46px;text-align:center;display:block;}
.cta__label{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.cta__title{font-family:var(--fd);font-size:clamp(30px,4vw,54px);line-height:1.05;font-weight:400;margin:20px 0 0;}
.cta__title em{font-style:italic;color:var(--gold);}
.cta__button{display:inline-flex;margin-top:34px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:14px 28px;border:1px solid var(--gold);color:var(--gold);transition:background .3s,color .3s;}
.cta__button:hover{background:var(--gold);color:var(--ink);}
.cta__contact{font-family:var(--fm);font-size:11px;color:var(--bone-3);margin-top:20px;}

/* ── responsive ────────────────────────────────────────── */
@media(max-width:980px){
  .head,.roster-row{grid-template-columns:1fr;}
  .roster-row__index{padding:40px 20px 0;}
  .roster-row__image{min-height:280px;}
  .head__portrait{min-height:300px;}
  .bio__inner{grid-template-columns:1fr;}
}
@media(max-width:860px){
  .nav{padding:16px 20px;flex-wrap:wrap;gap:10px 16px;}
  .nav__city{display:none;}
  .nav__menu{gap:14px;}
  .nav__menu>a{font-size:11px;letter-spacing:.05em;}
  .band,.hero__left,.exhibition__content,.note,.works,.feat__body,.vis,.footer,.shead,.pn__cell,.statement,
  .archive-hero,.essay,.works-on-view,.roster-closing,.exhibition-cta,.past-list,.team,.method,.channels,.visit,.form-section,
  .breadcrumb,.head,.bio,.exhibitions,.cta,.roster-row__content,.single-work__hero{padding-left:20px;padding-right:20px;}
  .hero{grid-template-columns:1fr;}
  .hero__right{min-height:54vh;}
  .hero__eyebrow,.hero__title,.hero__sub,.hero__meta{margin-left:0;}
  .hero__section-mark{display:none;}
  .exhibition,.artists__grid,.note__grid,.works__grid,.feat,.vis__grid,.pn,.statement__inner,
  .essay__inner,.works-on-view__grid,.roster-closing__inner,.exhibition-cta__grid,.method__inner,
  .team__grid,.channels__grid,.visit__grid,.form-section__inner,.exhibitions__inner,.contact-form__row--double{grid-template-columns:1fr;}
  .feat--mirror{direction:ltr;}
  .works__grid,.works-on-view__grid{gap:24px;}
  .note__grid,.vis__grid,.statement__inner{gap:36px;}
  .feat__field{min-height:280px;}
  .feat__body{padding:48px 20px;}
  .artist-card__index{padding-top:0;}
  .archive-hero{padding-top:120px;}
  .channels__grid,.visit__grid{gap:30px 24px;}
  .past-list__link{grid-template-columns:60px 1fr;gap:10px 18px;}
  .past-list__dates{text-align:left;grid-column:2;}
  .past-list__index{display:none;}
}
@media(max-width:560px){
  /* channels exclu : ses longues adresses (email/tel) ne tiennent pas en 2 col
     à 390px → reste en 1 col (hérité du palier ≤760). team/visit = contenu court. */
  .team__grid,.visit__grid{grid-template-columns:1fr 1fr;}
}
