/* ══════════════════════════════════════════════════════════════
   Sopranova — Bureau de production & d'accompagnement
   Typographie : Outfit (Google Fonts)
   ══════════════════════════════════════════════════════════════ */

:root{
  --ink:#14130f;
  --ink-soft:#45433b;
  --paper:#ffffff;
  --paper-soft:#ebe6db;
  --line:rgba(20,19,15,.18);
  --accent:#14130f;
  --accent-2:#14130f;
  --sec:#14130f; /* secondary colour — overridden on load by inline JS in header */
  --fig-placeholder:#3a3a3a;
  --serif:"Outfit", -apple-system, "Helvetica Neue", Arial, sans-serif;
  --serif-display:"Outfit", -apple-system, "Helvetica Neue", Arial, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, Menlo, monospace;
  --text:16px; --lh:1.55;
  --gutter: clamp(20px, 3.2vw, 56px);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:var(--serif);font-size:var(--text);line-height:var(--lh);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-variant-numeric:tabular-nums}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
/* All H1 across pages pick up the secondary colour by default */
h1{color:var(--sec);transition:color .4s ease}
h1 em{color:inherit}

/* ───── Masthead ───── */
.mast{
  position:sticky;top:0;z-index:50;background:var(--paper);
  border-bottom:1px solid var(--line);
  padding:14px var(--gutter);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
}
.mast .brand{position:relative;display:flex;align-items:center;justify-self:center}
.mast .brand-logo{display:block;line-height:0;cursor:pointer}
/* The anim iframe captures clicks by default — disable pointer events so the
   clicks bubble up to the wrapping <a class="brand-logo"> and navigate home. */
.mast .brand-anim{display:block;border:0;width:220px;height:54px;background:transparent;pointer-events:none}
.mast .left{display:flex;gap:22px}
.mast .right{display:flex;gap:22px;justify-content:flex-end;align-items:center}
.mast a:hover{color:var(--accent)}
.mast .nav a.active{color:var(--accent)}
.mast .dot{width:6px;height:6px;border-radius:50%;background:var(--sec);display:inline-block;margin-right:8px;transform:translateY(-1px);transition:background-color .4s ease}
.mast .cta{border:1px solid var(--line);padding:7px 14px;border-radius:999px;transition:background-color .4s ease,color .4s ease,border-color .4s ease}
.mast .cta:hover{background:var(--sec);color:var(--paper);border-color:var(--sec)}
/* Mobile hamburger — hidden on desktop, shown on ≤ 720px.
   Decorative border-radius: top bar rounded at top-left, middle flat, bottom
   rounded at bottom-right — echoes the pill silhouette of the brand logo.
   All three bars carry the secondary colour. */
.mast-burger{
  display:none;width:28px;height:22px;padding:0;background:transparent;border:0;cursor:pointer;
  flex-direction:column;justify-content:space-between;align-items:stretch;
  justify-self:flex-end;
}
.mast-burger span{
  display:block;width:100%;height:5px;background:var(--sec);
  transition:transform .3s ease,opacity .2s ease,border-radius .3s ease,background-color .4s ease;
  transform-origin:center;
}
.mast-burger span:nth-child(1){border-radius:5px 0 0 0}
.mast-burger span:nth-child(2){border-radius:0}
.mast-burger span:nth-child(3){border-radius:0 0 5px 0}
.mast-burger.open span{border-radius:5px}
.mast-burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.mast-burger.open span:nth-child(2){opacity:0}
.mast-burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media (max-width:720px){
  .mast{grid-template-columns:auto 1fr;gap:14px}
  .mast .left,.mast .right{display:none}
  .mast .brand{justify-self:flex-start;grid-column:1}
  .mast .brand-anim{width:160px;height:40px}
  .mast-burger{display:flex;grid-column:2;justify-self:flex-end}
}

/* Drawer + backdrop (mobile menu) */
.drawer-backdrop{
  position:fixed;inset:0;z-index:99;
  background:rgba(0,0,0,.4);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  width:min(82vw,360px);background:var(--paper);color:var(--ink);
  transform:translateX(-100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;
  box-shadow:20px 0 60px -20px rgba(0,0,0,.25);
  overflow-y:auto;overscroll-behavior:contain;
}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:flex-end;padding:14px var(--gutter) 0}
.drawer-close{
  width:36px;height:36px;border:0;background:transparent;cursor:pointer;
  font-size:28px;line-height:1;color:var(--ink);
}
.drawer-nav{
  display:flex;flex-direction:column;gap:2px;
  padding:clamp(20px,5vw,40px) var(--gutter);
  font-family:var(--serif-display);
}
.drawer-nav a{
  font-size:clamp(28px,6vw,40px);font-weight:400;letter-spacing:-.01em;
  padding:10px 0;border-bottom:1px solid var(--line);
  color:var(--ink);transition:color .25s ease;
}
.drawer-nav a.active,.drawer-nav a:hover{color:var(--sec)}
.drawer-foot{
  margin-top:auto;padding:clamp(20px,4vw,32px) var(--gutter);
  border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
}
.drawer-foot .drawer-status{color:var(--ink-soft)}
.drawer-foot .cta{
  align-self:flex-start;border:1px solid var(--line);padding:10px 16px;border-radius:999px;
  transition:background-color .3s ease,color .3s ease,border-color .3s ease;
}
.drawer-foot .cta:hover{background:var(--sec);color:var(--paper);border-color:var(--sec)}

.ticker{border-bottom:1px solid var(--line);padding:8px var(--gutter);overflow:hidden;white-space:nowrap;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.ticker .track{display:inline-block;animation:tick 80s linear infinite}
.ticker span.sep{color:var(--sec);margin:0 18px;transition:color .4s ease}
@media (max-width:720px){
  .ticker{font-size:7.5px;letter-spacing:.06em;padding:5px var(--gutter)}
  .ticker span.sep{margin:0 10px}
}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ───── Hero ───── */
.hero{
  position:relative;
  padding: clamp(28px,5vw,72px) var(--gutter) clamp(32px,5vw,64px);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  isolation:isolate;
}
/* Random project image layered behind the hero text.
   JS picks a URL from the projects' images on every page load (so it's always
   fresh even with HTML/CDN caching). The image is desaturated, slightly blurred,
   and covered by a near-opaque paper veil so the dark headline stays crisp. */
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:grayscale(1) blur(1px);
  opacity:0;transition:opacity .9s ease;
  z-index:-1;
}
.hero-bg.loaded{opacity:1}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.70) 0%, rgba(255,255,255,.56) 55%, rgba(255,255,255,.72) 100%);
}
/* Secondary-colour accent — a soft radial glow at the top-right of the hero.
   Sits ABOVE the grayscale .hero-bg (so it isn't desaturated) but BELOW the
   text content (z-index 1), to tint the veil without affecting legibility. */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 85% 0%, var(--sec), transparent 65%),
    linear-gradient(180deg, transparent 0%, transparent 55%, var(--sec) 200%);
  opacity:.22;
  mix-blend-mode:multiply;
  transition:opacity .4s ease;
}
/* Make sure all hero content stays above the background layers */
.hero > :not(.hero-bg){position:relative;z-index:1}
.hero .kicker{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);
  display:flex;gap:22px;flex-wrap:wrap;align-items:center;
}
.hero .kicker .bullet{width:5px;height:5px;border-radius:50%;background:var(--sec);display:inline-block;transform:translateY(-1px);transition:background-color .4s ease}
.hero h1{
  font-family:var(--serif-display);font-weight:400;
  font-size: clamp(44px, 9vw, 168px);
  line-height:.92;letter-spacing:-.02em;
  margin-top:18px;max-width:16ch;
  color:var(--sec);transition:color .4s ease;
}
.hero h1 em{font-style:italic;color:inherit;font-weight:500}
.hero h1 .amp{font-style:italic;color:inherit}
.hero .lede{
  margin-top:34px;
  display:grid;grid-template-columns:2fr 3fr;gap: clamp(20px,4vw,80px);align-items:end;
}
.hero .lede p{font-size:clamp(16px,1.4vw,20px);line-height:1.5;max-width:52ch}
.hero .lede .meta{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);line-height:1.8}
.hero .lede .meta strong{color:var(--ink);font-weight:500}
@media (max-width:720px){.hero .lede{grid-template-columns:1fr}}

/* Services strip */
.services{
  padding: clamp(26px,3.5vw,48px) var(--gutter);
  border-bottom:1px solid var(--line);
  display:grid;grid-template-columns: 1fr 1fr 1fr 1fr;gap:clamp(16px,2vw,40px);
}
.services .kicker{grid-column:1/-1;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.services .svc{border-top:1px solid var(--ink);padding-top:16px}
.services .svc .n{font-family:var(--mono);font-size:11px;color:var(--sec);letter-spacing:.1em;transition:color .4s ease}
.services .svc h3{font-family:var(--serif-display);font-size:clamp(24px,2.6vw,34px);font-weight:400;line-height:1.05;letter-spacing:-.01em;margin:10px 0 10px;max-width:14ch}
.services .svc p{font-size:15px;color:var(--ink-soft);line-height:1.5}
.services .svc.principle{border-color:var(--sec);border-top-width:2px;transition:border-color .4s ease}
.services .svc.principle h3{font-style:normal}
@media (max-width:900px){.services{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.services{grid-template-columns:1fr}}

/* Index title */
.ix-title{padding: clamp(30px,4vw,56px) var(--gutter) 14px;display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:24px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.ix-title h2{font-family:var(--serif-display);font-size:clamp(30px,3.6vw,46px);font-weight:400;letter-spacing:-.01em;text-transform:none;color:var(--ink)}
.ix-title h2 em{font-style:italic}
.ix-title .rule{height:1px;background:var(--line);transform:translateY(-6px)}

/* Filters + view toggle */
.filters{
  display:flex;gap:4px;flex-wrap:wrap;padding:0 var(--gutter) 14px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
}
.filters .chip,.p-filters .chip{
  padding:6px 12px;border:1px solid var(--line);border-radius:999px;
  color:var(--ink-soft);background:transparent;
  transition:background-color .3s ease,color .3s ease,border-color .3s ease;
}
.filters .chip:hover,.p-filters .chip:hover{color:var(--ink);border-color:var(--ink)}
/* Active state (and active-while-hovered) use the secondary colour —
   the `.active:hover` pair is explicit so the inactive hover rule doesn't
   cascade and turn the text black-on-black. */
.filters .chip.active,.p-filters .chip.active,
.filters .chip.active:hover,.p-filters .chip.active:hover{
  background:var(--sec);color:var(--paper);border-color:var(--sec);
}
.filters .spacer{flex:1}
.filters .view{display:flex;gap:0}
.filters .view button{padding:6px 12px;border:1px solid var(--line);color:var(--ink-soft)}
.filters .view button:first-child{border-radius:999px 0 0 999px}
.filters .view button:last-child{border-radius:0 999px 999px 0;border-left:0}
.filters .view button.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.p-filters{
  display:flex;gap:4px;padding:18px var(--gutter);border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  flex-wrap:wrap;align-items:center;
}
.p-filters .label{color:var(--ink-soft);margin-right:12px}

/* List view */
.p-list{padding:0 var(--gutter) 40px}
.p-list .row{
  display:grid;grid-template-columns: 52px 1fr auto auto auto;gap:clamp(14px,2.5vw,36px);
  align-items:baseline;padding:22px 0;border-bottom:1px solid var(--line);
  position:relative;transition:.35s;cursor:pointer
}
.p-list .row .num{font-family:var(--mono);font-size:12px;color:var(--ink-soft);letter-spacing:.06em}
.p-list .row .ttl{font-family:var(--serif-display);font-size:clamp(24px,3.2vw,38px);line-height:1.05;letter-spacing:-.01em;font-weight:400}
.p-list .row .ttl em{font-style:italic;color:var(--ink-soft)}
.p-list .row .tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.p-list .row .yr{font-family:var(--mono);font-size:12px;color:var(--ink-soft);letter-spacing:.06em;min-width:7ch;text-align:right}
.p-list .row .arr{font-family:var(--mono);font-size:14px;color:var(--ink-soft);transition:transform .3s}
.p-list .row:hover{background:linear-gradient(90deg,transparent,rgba(0,0,0,.02))}
.p-list .row:hover .ttl{color:var(--accent)}
.p-list .row:hover .arr{transform:translateX(6px);color:var(--accent)}
.p-list .row .preview{
  position:absolute;right:clamp(120px,13vw,200px);top:50%;
  width:clamp(200px,24vw,340px);height:clamp(130px,15vw,230px);
  transform:translateY(-50%) translateX(-20px);pointer-events:none;opacity:0;transition:.35s cubic-bezier(.22,1,.36,1);
  background:var(--fig-placeholder);box-shadow:0 24px 60px -30px rgba(0,0,0,.5);z-index:2;overflow:hidden;
  background-size:cover;background-position:center;
}
.p-list .row .preview::before{
  content:attr(data-caption);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:18px;text-align:center;
  color:rgba(255,255,255,.9);font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;
}
.p-list .row:hover .preview{opacity:1;transform:translateY(-50%) translateX(0)}
@media (max-width:900px){
  .p-list .row .preview{display:none}
  .p-list .row{grid-template-columns:40px 1fr auto}
  .p-list .row .tag,.p-list .row .arr{display:none}
}

/* Grid view */
.p-grid{display:grid;padding:0 var(--gutter) 40px;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,44px) clamp(20px,2.4vw,32px)}
.p-grid.hidden{display:none}
.p-grid .card{cursor:pointer;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:12px;color:inherit}
/* Card figure — same style as the hero background (grayscale image + secondary-
   colour radial tint), but without blur and at full image opacity. The image
   sits on a child .fig-img; the colour overlay is drawn in ::before above it. */
.p-grid .card .fig{
  aspect-ratio:4/5;
  background:var(--fig-placeholder);
  overflow:hidden;position:relative;transition:.4s;
  isolation:isolate;
}
.p-grid .card .fig .fig-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  z-index:0;
}
/* Secondary-colour halo — strong coloured vignette around the card edges that
   fades into a small transparent window in the middle, so the image still
   reads in colour in its centre. */
.p-grid .card .fig::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(ellipse at center, transparent 25%, var(--sec) 95%);
  opacity:.78;
  mix-blend-mode:multiply;
  transition:opacity .4s ease;
}
.p-grid .card .fig::after{
  content:attr(data-caption);position:absolute;inset:0;z-index:2;
  display:flex;align-items:flex-end;padding:14px;
  color:rgba(255,255,255,.92);font-family:var(--mono);font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;
  background:linear-gradient(0deg,rgba(0,0,0,.45),transparent 55%);
}
.p-grid .card:hover .fig{transform:translateY(-4px)}
.p-grid .card h3{font-family:var(--serif-display);font-size:clamp(22px,2vw,28px);font-weight:400;line-height:1.1;letter-spacing:-.005em;margin-top:6px;padding-bottom:6px}
.p-grid .card .row2{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:auto;padding-top:8px}
.p-grid .card .desc{font-size:14.5px;line-height:1.45;color:var(--ink-soft);max-width:40ch}
.p-grid .card .num-line{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);padding-top:6px}
@media (max-width:960px){.p-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.p-grid{grid-template-columns:1fr}}

/* About preview block on home */
.home-about{
  display:grid;grid-template-columns: 5fr 7fr; gap:clamp(24px,4vw,80px);
  padding: clamp(40px,6vw,90px) var(--gutter);border-bottom:1px solid var(--line);
  background:var(--sec);color:var(--paper);
  transition:background-color .4s ease;
}
.home-about .lab{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff}
.home-about h2{font-family:var(--serif-display);font-size:clamp(32px,4.4vw,64px);font-weight:400;line-height:1;letter-spacing:-.01em;margin-top:12px;max-width:14ch}
.home-about h2 em{font-style:italic;color:#fff}
.home-about .body{font-size:17px;line-height:1.6;max-width:58ch;color:rgba(255,255,255,.88)}
.home-about .body p+p{margin-top:14px}
.home-about .body strong{color:#fff;font-weight:500}
.home-about .quote{font-family:var(--serif-display);font-style:italic;font-size:clamp(20px,2vw,26px);color:rgba(255,255,255,.72);line-height:1.3;margin:22px 0;padding:16px 0;border-top:1px solid rgba(255,255,255,.24);border-bottom:1px solid rgba(255,255,255,.24);max-width:44ch}
.home-about .cta{display:inline-block;margin-top:20px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;border:1px solid #fff;padding:12px 22px;border-radius:999px;color:#fff}
.home-about .cta:hover{background:#fff;color:#000}
.home-about .logo-pill{background:#fff}
@media (max-width:900px){.home-about{grid-template-columns:1fr}}

/* Footer */
.foot{
  border-top:1px solid var(--line);padding:clamp(40px,6vw,96px) var(--gutter) 28px;
  display:grid;grid-template-columns:5fr 3fr 3fr;gap:clamp(20px,4vw,80px);
  background:var(--sec);color:var(--paper);
  transition:background-color .4s ease;
}
.foot h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:color-mix(in srgb, var(--sec) 20%, #fff);margin-bottom:14px;font-weight:500}
.foot .big{font-family:var(--serif-display);font-size:clamp(34px,5vw,64px);line-height:1.02;letter-spacing:-.01em;font-weight:400;max-width:14ch}
/* Pale tint of the secondary colour (10 % sec mixed with white) — soft accent on the dark footer bg */
.foot .big em{font-style:italic;color:color-mix(in srgb, var(--sec) 20%, #fff);transition:color .4s ease}
.foot .big a{border-bottom:2px solid color-mix(in srgb, var(--sec) 20%, #fff);color:color-mix(in srgb, var(--sec) 20%, #fff);font-size:clamp(18px,1.6vw,24px);display:inline-block;margin-top:22px;transition:color .4s ease,border-color .4s ease}
.foot .people{display:grid;gap:18px;grid-template-columns:1fr;margin-top:6px}
.foot .person .name{font-family:var(--serif-display);font-size:20px;margin-bottom:2px}
.foot .person .role{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:color-mix(in srgb, var(--sec) 20%, #fff);margin-bottom:4px}
.foot .person a{border-bottom:1px solid rgba(244,241,234,.25);display:inline-block;font-size:14px;padding-bottom:1px;transition:color .4s ease,border-color .4s ease}
.foot .person a:hover{color:color-mix(in srgb, var(--sec) 20%, #fff);border-color:color-mix(in srgb, var(--sec) 20%, #fff)}
.foot .links a{display:block;padding:3px 0;border-bottom:1px solid transparent;transition:color .4s ease,border-color .4s ease}
.foot .links a:hover{color:color-mix(in srgb, var(--sec) 20%, #fff);border-color:color-mix(in srgb, var(--sec) 20%, #fff)}
.foot .big a:hover{color:color-mix(in srgb, var(--sec) 20%, #fff);border-color:color-mix(in srgb, var(--sec) 20%, #fff)}
.foot .bottom{grid-column:1/-1;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:40px;padding-top:18px;border-top:1px solid rgba(244,241,234,.18);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in srgb, var(--sec) 20%, #fff)}
@media (max-width:900px){.foot{grid-template-columns:1fr}}

/* Brand signature strip — Hype animated logo in iframe, tinted via CSS filter
   (--sec-filter set by the header palette script) so the black Hype SVGs follow
   the secondary colour of the page load. */
.brand-mark{
  border-top:1px solid var(--line);
  padding:clamp(48px,8vw,120px) 0 clamp(32px,4vw,56px);
  background:var(--paper);overflow:hidden;
}
.brand-mark .bm-wrap{
  position:relative;
  width:100vw;margin:0;
  aspect-ratio:436/106;
  overflow:hidden;
}
.brand-mark .bm-anim{
  display:block;border:0;background:transparent;
  width:100%;height:100%;
}
.brand-mark .bm-rule{
  display:flex;gap:16px;flex-wrap:wrap;justify-content:center;
  margin-top:clamp(20px,3vw,40px);padding-top:clamp(18px,2vw,28px);
  padding-left:var(--gutter);padding-right:var(--gutter);
  border-top:1px solid var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-soft);
}
.brand-mark .bm-rule{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:clamp(20px,3vw,40px);padding-top:clamp(18px,2vw,28px);border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.brand-mark.on .bm-anim{opacity:1}

/* ───── Logo-ribbon (Hype `pillrepeat` scene — full viewport width) ───── */
.logo-ribbon{
  display:block;position:relative;
  background:var(--paper);
  padding:clamp(14px,2vw,26px) 0;
  overflow:hidden;
}
.logo-ribbon .lr-anim{
  display:block;border:0;background:transparent;
  width:100%;height:clamp(40px,5vw,70px);
}
.logo-ribbon .lr-meta{
  position:absolute;left:var(--gutter);top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);background:var(--paper);padding:0 10px;z-index:2;
}
.logo-ribbon .lr-meta.right{left:auto;right:var(--gutter)}

.logo-pill{
  display:inline-block;vertical-align:middle;
  width:22px;height:10px;border-radius:999px;
  background:var(--sec);margin-right:10px;
  transform:translateY(-1px);
  transition:background-color .4s ease;
}
.logo-pill.hollow{background:transparent;border:1px solid var(--sec)}

/* ───── Project detail page ───── */
.p-head{padding:clamp(24px,4vw,48px) var(--gutter) 0;display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,80px);align-items:end}
.p-head .meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.p-head .meta strong{color:var(--ink);font-weight:500}
.p-head h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(38px,5.8vw,92px);line-height:.98;letter-spacing:-.015em;max-width:16ch;text-align:right;margin-left:auto;color:var(--sec);transition:color .4s ease}
.p-head h1 em{font-style:italic;color:inherit}
.p-head .year{font-family:var(--mono);font-size:13px;color:var(--ink-soft);letter-spacing:.1em}
@media (max-width:720px){.p-head{grid-template-columns:1fr}.p-head h1{text-align:left}}

.p-lead{padding:clamp(28px,4vw,64px) var(--gutter);display:grid;grid-template-columns:4fr 7fr;gap:clamp(24px,4vw,60px);align-items:start;border-bottom:1px solid var(--line)}
.p-lead .col-left{position:relative;min-height:260px}
.p-lead .col-left .y{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--ink-soft)}
.p-lead .col-left h2{font-family:var(--serif-display);font-weight:500;font-size:clamp(26px,3.2vw,40px);line-height:1.05;letter-spacing:-.01em;margin:14px 0 22px;max-width:14ch}
.p-lead .col-left p{font-size:16px;line-height:1.55;max-width:42ch;margin-bottom:14px}
.p-lead .col-left .label{font-style:italic;font-weight:500}
.p-lead .col-left .pagenum{font-family:var(--serif-display);font-size:clamp(46px,6vw,92px);line-height:1;font-weight:400;margin-top:clamp(24px,4vw,64px)}
.p-lead .col-right{aspect-ratio:5/4;background:var(--fig-placeholder);position:relative;overflow:hidden;background-size:cover;background-position:center}
.p-lead .col-right::after{content:attr(data-caption);position:absolute;left:0;right:0;bottom:0;padding:16px 18px;color:rgba(255,255,255,.85);font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:linear-gradient(0deg,rgba(0,0,0,.45),transparent)}
@media (max-width:900px){.p-lead{grid-template-columns:1fr}}

.p-bleed{margin:0 var(--gutter);aspect-ratio:16/9;background:var(--fig-placeholder);position:relative;background-size:cover;background-position:center}
.p-bleed::after{content:attr(data-caption);position:absolute;left:0;right:0;bottom:0;padding:18px 20px;color:rgba(255,255,255,.85);font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:linear-gradient(0deg,rgba(0,0,0,.45),transparent)}
.p-caption{padding:10px var(--gutter) 0;font-family:var(--mono);font-size:11px;color:var(--ink-soft);letter-spacing:.06em;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}

.p-narr{padding:clamp(40px,5vw,80px) var(--gutter);display:grid;grid-template-columns:1fr 2fr;gap:clamp(20px,4vw,80px);border-top:1px solid var(--line);margin-top:clamp(24px,3vw,40px)}
.p-narr h3{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.p-narr .body{font-size:18px;line-height:1.6;max-width:58ch}
.p-narr .body p+p{margin-top:14px;text-indent:2em}
.p-narr .body > p:first-child::first-letter{font-family:var(--serif-display);font-size:4.2em;line-height:.9;float:left;padding:6px 10px 0 0;font-weight:500;color:var(--accent)}
.p-narr .body blockquote,.p-narr .body .pull{margin:22px 0;padding:14px 0;font-family:var(--serif-display);font-style:italic;font-size:26px;line-height:1.25;color:var(--sec);border-top:1px solid var(--sec);border-bottom:1px solid var(--sec);transition:color .4s ease,border-color .4s ease;text-indent:0!important}
@media (max-width:720px){.p-narr{grid-template-columns:1fr}}

.p-facts{padding:0 var(--gutter) clamp(40px,5vw,80px);display:grid;grid-template-columns:repeat(4,1fr);gap:16px 24px}
.p-facts .fact{border-top:1px solid var(--line);padding-top:10px}
.p-facts .fact .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.p-facts .fact .v{font-family:var(--serif-display);font-size:20px;line-height:1.2;margin-top:6px}
@media (max-width:720px){.p-facts{grid-template-columns:1fr 1fr}}

.p-gallery{padding:0 var(--gutter) clamp(40px,5vw,80px);display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.p-gallery .tile{background:var(--fig-placeholder);position:relative;overflow:hidden;background-size:cover;background-position:center}
.p-gallery .tile::after{content:attr(data-caption);position:absolute;left:0;right:0;bottom:0;padding:10px 12px;color:rgba(255,255,255,.85);font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase}
.p-gallery .tile:nth-child(4n+1){grid-column:span 8;aspect-ratio:4/3}
.p-gallery .tile:nth-child(4n+2){grid-column:span 4;aspect-ratio:3/4}
.p-gallery .tile:nth-child(4n+3){grid-column:span 5;aspect-ratio:4/3}
.p-gallery .tile:nth-child(4n+4){grid-column:span 7;aspect-ratio:16/10}
@media (max-width:720px){.p-gallery .tile{grid-column:span 12!important;aspect-ratio:4/3!important}}

.p-nav{border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr auto 1fr;padding:clamp(24px,3vw,40px) var(--gutter);gap:20px;align-items:center;margin:0 0 clamp(40px,5vw,60px)}
.p-nav .side{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.p-nav .side.prev{text-align:left}
.p-nav .side.next{text-align:right}
.p-nav .side strong{display:block;color:var(--ink);font-family:var(--serif-display);font-size:clamp(20px,2.4vw,28px);margin-top:6px;font-weight:400;letter-spacing:-.005em}
.p-nav .side:hover strong{color:var(--accent)}
.p-nav .to-index{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);padding:10px 16px;border-radius:999px}
.p-nav .to-index:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ───── Projets index page ───── */
.p-intro{padding:clamp(40px,6vw,90px) var(--gutter) clamp(24px,3vw,48px);border-bottom:1px solid var(--line);display:grid;grid-template-columns:5fr 7fr;gap:clamp(24px,4vw,80px);align-items:end}
.p-intro .kicker{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.p-intro h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(54px,9vw,150px);line-height:.9;letter-spacing:-.02em}
.p-intro h1 em{font-style:italic}
.p-intro .lede{font-family:var(--serif);font-size:clamp(17px,1.4vw,20px);line-height:1.5;max-width:50ch;margin-bottom:20px}
.p-intro .stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);padding-top:14px;gap:16px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.p-intro .stats strong{font-family:var(--serif-display);font-size:clamp(24px,2.6vw,36px);color:var(--ink);font-weight:400;letter-spacing:-.005em;text-transform:none;display:block;margin-top:4px}
@media (max-width:720px){.p-intro{grid-template-columns:1fr}}

/* ───── About page ───── */
.abt-hero{padding:clamp(28px,4vw,64px) var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,80px);align-items:end;border-bottom:1px solid var(--line)}
.abt-hero .kicker{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.abt-hero h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(44px,6.8vw,112px);line-height:.96;letter-spacing:-.015em;margin-top:16px;max-width:12ch}
.abt-hero h1 em{font-style:italic;color:inherit}
.abt-hero p{font-size:clamp(17px,1.4vw,20px);line-height:1.5;max-width:46ch}
@media (max-width:720px){.abt-hero{grid-template-columns:1fr}}

.abt-manif{padding:clamp(32px,4.5vw,72px) var(--gutter);display:grid;grid-template-columns:1fr 2fr;gap:clamp(20px,4vw,80px);border-bottom:1px solid var(--line)}
.abt-manif h2{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.abt-manif .body{font-size:18px;line-height:1.6;max-width:58ch}
.abt-manif .body p+p{margin-top:14px}
.abt-manif .body strong{color:var(--ink);font-weight:500;font-style:italic;background:linear-gradient(transparent 60%, rgba(20,19,15,.18) 60%)}
.abt-manif .body blockquote,.abt-manif .body .pull{margin:26px 0;padding:18px 0;font-family:var(--serif-display);font-style:italic;font-size:28px;line-height:1.25;color:var(--sec);border-top:1px solid var(--sec);border-bottom:1px solid var(--sec);transition:color .4s ease,border-color .4s ease}
@media (max-width:720px){.abt-manif{grid-template-columns:1fr}}

.people-2{padding:clamp(40px,5vw,96px) var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px);border-bottom:1px solid var(--line)}
.people-2 .p{display:flex;flex-direction:column;gap:16px}
.people-2 .portrait{aspect-ratio:4/5;background:var(--fig-placeholder);position:relative;overflow:hidden;background-size:cover;background-position:center;isolation:isolate}
/* Secondary-colour halo — same recipe as the .fig cards in p-grid */
.people-2 .portrait::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;background:radial-gradient(ellipse at center, transparent 25%, var(--sec) 95%);opacity:.78;mix-blend-mode:multiply;transition:opacity .4s ease}
.people-2 .portrait::after{content:attr(data-caption);position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 18px;color:rgba(255,255,255,.92);font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:linear-gradient(0deg,rgba(0,0,0,.45),transparent)}
.people-2 .role{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.people-2 h3{font-family:var(--serif-display);font-size:clamp(32px,3.6vw,52px);font-weight:400;letter-spacing:-.01em;line-height:1}
.people-2 .bio{font-size:16px;line-height:1.6;color:var(--ink-soft)}
.people-2 .links{display:flex;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;margin-top:4px}
.people-2 .links a{border-bottom:1px solid var(--line);padding-bottom:2px}
.people-2 .links a:hover{color:var(--accent);border-color:var(--accent)}
@media (max-width:720px){.people-2{grid-template-columns:1fr}}

.met-date{padding:clamp(24px,3vw,48px) var(--gutter);text-align:center;font-family:var(--serif-display);font-style:italic;color:var(--ink-soft);font-size:clamp(20px,2vw,26px);max-width:56ch;margin:0 auto}
.met-date em{color:var(--accent);font-style:italic}

/* ───── Contact page ───── */
.ct-people{padding:clamp(32px,4vw,72px) var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,80px);border-bottom:1px solid var(--line)}
.ct-people .lab{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.ct-people .role{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.ct-people a.mail{font-family:var(--serif-display);font-size:clamp(26px,2.6vw,38px);display:inline-block;margin-top:10px;border-bottom:1px solid var(--line);padding-bottom:4px}
.ct-people a.mail:hover{border-color:var(--accent)}
@media (max-width:720px){.ct-people{grid-template-columns:1fr}}

.ct-info{padding:clamp(32px,4vw,64px) var(--gutter);display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,4vw,60px)}
.ct-info .lab{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.ct-info .v{font-family:var(--serif);font-size:18px;line-height:1.5}
.ct-info .links{display:grid;gap:6px}
@media (max-width:720px){.ct-info{grid-template-columns:1fr}}

