:root{
  --bg:#000;--text:#f2f2f2;--muted:#8d8d8d;--line:#262626;--red:#d6452f;
  --maxw:1120px;--gutter:clamp(20px,4vw,40px);--ease:cubic-bezier(.2,.7,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:"Century Gothic","Jost","URW Gothic","Futura",sans-serif;
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit}
.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(0,0,0,.8);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header .bar{display:flex;align-items:center;justify-content:space-between;padding-top:20px;padding-bottom:20px}
.brand{font-weight:700;font-size:17px;letter-spacing:.01em;text-decoration:none}
nav ul{display:flex;gap:28px;list-style:none}
nav a{text-decoration:none;color:var(--muted);font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding-bottom:4px;position:relative;transition:color .3s var(--ease)}
nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--red);transition:width .35s var(--ease)}
nav a:hover,nav a.active{color:var(--text)}
nav a:hover::after,nav a.active::after{width:100%}
.menu-btn{display:none;background:none;border:none;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--text);cursor:pointer}
.mobile-nav{display:none;border-bottom:1px solid var(--line)}
.mobile-nav.open{display:block}
.mobile-nav ul{list-style:none;padding:10px 0}
.mobile-nav a{display:block;padding:12px var(--gutter);color:var(--muted);text-decoration:none;font-size:13px;letter-spacing:.16em;text-transform:uppercase}
.mobile-nav a.active{color:var(--text)}

/* Layout */
main{padding-top:clamp(28px,4vw,52px);min-height:60vh}
.crumb{display:flex;gap:10px;align-items:center;margin-bottom:30px;flex-wrap:wrap}
.crumb span{color:var(--red)}
.crumb a{color:var(--muted);text-decoration:none}
.crumb a:hover{color:var(--text)}

.hero{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(24px,4vw,48px);align-items:end;margin-bottom:14px}
.title-block .yr{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--red)}
.title-block h1{font-weight:700;font-size:clamp(30px,4.4vw,52px);line-height:1.04;letter-spacing:-.01em;text-transform:uppercase;margin:14px 0 18px}
.title-block p{font-size:16px;color:var(--muted);max-width:52ch}
.hero-portrait{width:100%;max-width:360px;aspect-ratio:3/4;overflow:hidden;background:#111;border:1px solid var(--line);justify-self:end}
.hero-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 18%}

/* Page intro (lists) */
.pagehead{margin-bottom:40px}
.pagehead h1{font-weight:700;font-size:clamp(30px,4.4vw,52px);line-height:1.04;text-transform:uppercase;letter-spacing:-.01em;margin:12px 0 14px}
.pagehead p{color:var(--muted);max-width:64ch}

/* Gallery */
.gallery{margin-top:30px;position:relative}
.bigyear{display:block;text-align:right;font-weight:700;font-size:clamp(38px,5.5vw,68px);line-height:1;letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1.5px var(--red);margin-bottom:16px}
.frame{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;z-index:1;background:#111;border:1px solid var(--line)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .7s var(--ease)}
.slide.on{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover}
.navbtn{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border:1px solid rgba(255,255,255,.5);cursor:pointer;background:rgba(0,0,0,.35);color:#fff;font-size:18px;display:grid;place-items:center;transition:background .25s,border-color .25s;z-index:3}
.navbtn:hover{background:var(--red);border-color:var(--red)}
.prev{left:18px}.next{right:18px}
.thumbs{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.thumbs button{width:88px;height:54px;border:1px solid var(--line);cursor:pointer;padding:0;opacity:.45;transition:opacity .3s,border-color .2s;background:#111;overflow:hidden}
.thumbs button img{width:100%;height:100%;object-fit:cover}
.thumbs button.on{opacity:1;border-color:var(--red)}
.single-img{width:100%;aspect-ratio:16/9;object-fit:cover;background:#111;border:1px solid var(--line)}

/* Detail */
.detail{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(24px,4vw,48px);margin:52px 0 76px;align-items:start}
.ctx h2{font-weight:700;font-size:18px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.ctx p{color:var(--muted);margin-bottom:16px;font-size:15.5px}
.specs{border-top:1px solid var(--text);padding-top:6px}
.specs dl{display:grid;grid-template-columns:auto 1fr}
.specs dt{padding:15px 24px 15px 0;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap}
.specs dd{padding:15px 0;font-size:15px;font-weight:700;border-bottom:1px solid var(--line)}
.specs dd.accent{color:var(--red)}

/* Categories list */
.cats{border-top:1px solid var(--line);padding-top:30px;margin-bottom:76px}
.cats .label{margin-bottom:18px}
.cats ul{list-style:none;column-count:2;column-gap:48px}
.cats li{padding:9px 0;border-bottom:1px solid var(--line);break-inside:avoid}
.cats a{display:flex;gap:14px;text-decoration:none;color:var(--muted);font-size:13.5px;letter-spacing:.04em;transition:color .25s,padding-left .25s var(--ease)}
.cats a:hover{color:var(--text);padding-left:6px}
.cats a .n{color:#555;font-variant-numeric:tabular-nums}
.cats li.active a,.cats li.active a .n{color:var(--red)}

/* Card grids */
.more{border-top:1px solid var(--text);padding-top:30px;padding-bottom:90px}
.more .head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:26px}
.more h3{font-weight:700;font-size:16px;letter-spacing:.06em;text-transform:uppercase}
.more .head a{color:var(--red);text-decoration:none}
.row-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:80px}
.card{cursor:pointer;display:block;text-decoration:none;color:inherit}
.card .img{aspect-ratio:4/3;overflow:hidden;background:#111;border:1px solid var(--line);transition:transform .5s var(--ease)}
.card .img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .img img{transform:scale(1.05)}
.card .meta{display:flex;justify-content:space-between;margin-top:12px;gap:12px}
.card .meta .nm{font-weight:700;font-size:13.5px;letter-spacing:.04em;text-transform:uppercase}
.card .meta .yr{color:var(--red);font-size:13.5px;white-space:nowrap}
.card .sub{color:var(--muted);font-size:12.5px;margin-top:4px}

/* Text content blocks (agence, actualité) */
.prose{max-width:72ch;margin-bottom:60px}
.prose p{color:#cfcfcf;margin-bottom:16px;font-size:15.5px}
.section{border-top:1px solid var(--line);padding-top:36px;margin-bottom:56px}
.section h2{font-weight:700;font-size:20px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:20px}
.linklist{list-style:none;column-count:2;column-gap:48px}
.linklist li{padding:8px 0;border-bottom:1px solid var(--line);break-inside:avoid}
.linklist a{color:var(--muted);text-decoration:none;font-size:14px;transition:color .2s}
.linklist a:hover{color:var(--red)}
.meta-line{color:var(--red);font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}

/* Agence — pull-quote, timeline, stats */
/* scoped to .title-block so it outranks `.title-block p{font-size:16px}` */
.title-block .statement{font-size:clamp(19px,2.2vw,27px);line-height:1.4;font-weight:500;color:var(--text);max-width:none;margin-top:28px}
.statement::before{content:"« ";color:var(--red)}
.statement::after{content:" »";color:var(--red)}
.timeline{list-style:none}
.timeline li{display:grid;grid-template-columns:78px 1fr;gap:22px;padding:14px 0;border-bottom:1px solid var(--line);align-items:baseline}
.timeline .ty{color:var(--red);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.04em}
.timeline li span:last-child{color:#cfcfcf;font-size:15px}
.stats{display:flex;flex-direction:column}
.stat{border-top:1px solid var(--line);padding:16px 0}
.stat:first-child{border-top:0}
.stat .num{font-weight:700;font-size:clamp(28px,3.2vw,38px);line-height:1;letter-spacing:-.01em}
.stat .lab{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:80px}
.contact-grid h2{font-weight:700;font-size:18px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px}
.contact-grid p,.contact-grid a{color:var(--muted);font-size:15.5px;line-height:1.9;text-decoration:none}
.contact-grid a:hover{color:var(--red)}

/* Footer */
footer{border-top:1px solid var(--line)}
footer .fcols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;padding-top:clamp(36px,5vw,60px);padding-bottom:clamp(36px,5vw,60px)}
footer .fbrand{font-weight:700;font-size:20px}
footer .col p{font-size:14px;line-height:1.7;color:var(--muted);margin-top:12px}
footer a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:1px}
footer a:hover{border-color:var(--red)}

/* Reveal */
.rv{opacity:0;transform:translateY(20px);animation:rise .9s var(--ease) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.15s}.d3{animation-delay:.25s}.d4{animation-delay:.35s}
/* Never let the entrance animation hide content when motion is reduced/unsupported */
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;animation:none}}

@media(max-width:860px){
  .hero,.detail,.contact-grid{grid-template-columns:1fr;gap:30px}
  .row-grid,.grid{grid-template-columns:1fr;gap:26px}
  .cats ul,.linklist{column-count:1}
  nav{display:none}.menu-btn{display:block}
  footer .fcols{grid-template-columns:1fr;gap:26px}
}
