/* ===========================================================
   THE ONLY G — Guillaume Doubet
   Brutalist editorial system. Shared across all pages.
   =========================================================== */

:root{
  --bg:#050505;
  --fg:#f2efe8;
  --muted:#9b968d;
  --line:#f2efe8;
  --hair:rgba(242,239,232,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;}
html,body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family:Arial, Helvetica, sans-serif;
  -webkit-font-smoothing:antialiased;
}
body{overflow-x:hidden;}
a{color:inherit;}

/* ---- film grain overlay (generated, no external asset) ---- */
.noise{
  position:fixed;inset:0;pointer-events:none;z-index:60;
  opacity:.06;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size:220px 220px;
}

/* ----------------------------- header ----------------------------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:40;
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:18px 24px;
  font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  mix-blend-mode:difference;
}
header .brand{font-weight:700;text-decoration:none;letter-spacing:.04em;}
header nav{display:flex;gap:22px;justify-self:center;}
header nav a{text-decoration:none;position:relative;padding-bottom:2px;opacity:.8;transition:opacity .2s;}
header nav a:hover{opacity:1;}
header nav a.active{opacity:1;}
header nav a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--fg);
}
header .right{justify-self:end;text-decoration:none;opacity:.8;}
header .right:hover{opacity:1;}

/* ----------------------------- shared type ----------------------------- */
.page{padding-top:78px;}

.section-head{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);
  padding:18px 22px 0;
}

.kicker{
  font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);
}

/* monster display title */
.display{
  font-weight:950;
  line-height:.72;
  letter-spacing:-.08em;
  text-transform:uppercase;
  font-size:clamp(72px, 19vw, 300px);
  transform:scaleX(1.06);
  transform-origin:left center;
}
.display span{display:block;}

/* ----------------------------- hero (MAIN) ----------------------------- */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:90px 22px 22px;
  position:relative;
}
.hero-loop{
  position:absolute;inset:0;z-index:-1;overflow:hidden;
}
.hero-loop video{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(120%) brightness(.55);
  opacity:.5;
}
.intro{
  display:grid;grid-template-columns:1.15fr .85fr;gap:32px;
  border-top:1px solid var(--line);padding-top:18px;
}
.manifesto{
  max-width:760px;font-size:11px;line-height:1.2;text-transform:uppercase;
  columns:2;column-gap:28px;text-align:justify;
}
.big-meta{
  justify-self:end;text-align:right;font-weight:900;
  font-size:clamp(24px, 3.6vw, 60px);line-height:.85;letter-spacing:-.05em;
  text-transform:uppercase;
}

/* ----------------------------- ticker ----------------------------- */
.ticker{
  border-top:1px solid var(--fg);border-bottom:1px solid var(--fg);
  overflow:hidden;white-space:nowrap;
  font-size:13px;text-transform:uppercase;letter-spacing:.08em;padding:10px 0;
}
.ticker div{animation:move 28s linear infinite;display:inline-block;}
@keyframes move{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ----------------------------- works / index rows ----------------------------- */
.works{padding-right:22px;padding-bottom:60px;padding-left:22px;}

.work{
  display:grid;
  grid-template-columns:1fr 180px 170px 70px;
  gap:18px;align-items:center;
  border-top:1px solid var(--hair);
  padding:16px 0 13px;
  text-transform:uppercase;text-decoration:none;color:inherit;
  transition:background .2s, padding .2s;
}
.works .work:last-child{border-bottom:1px solid var(--hair);}
.work:hover{background:rgba(242,239,232,.04);padding-left:10px;}
.work-title{
  font-weight:950;font-size:clamp(34px, 6.4vw, 104px);
  letter-spacing:-.07em;line-height:.8;
}
.work small{font-size:11px;color:var(--muted);line-height:1.25;}
.work .view{font-size:11px;color:var(--muted);justify-self:end;}

/* year divider for the video index */
.year-row{
  padding:34px 0 6px;border-top:1px solid var(--fg);
  font-weight:950;font-size:clamp(20px,3vw,34px);letter-spacing:-.04em;
}

/* ----------------------------- artwork grid ----------------------------- */
.grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--hair);
  border-top:1px solid var(--fg);border-bottom:1px solid var(--fg);
  margin-top:18px;
}
.grid figure{margin:0;position:relative;background:var(--bg);overflow:hidden;aspect-ratio:1/1;}
.grid img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) contrast(118%);
  transition:filter .5s, transform .8s;
}
.grid figure:hover img{filter:grayscale(0) contrast(105%);transform:scale(1.04);}
.grid figcaption{
  position:absolute;left:10px;bottom:9px;
  font-size:10px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--fg);mix-blend-mode:difference;
}

/* ----------------------------- artwork gallery (editorial, large, color) ----------------------------- */
.gallery{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:72px 56px;
  max-width:1180px;margin:0 auto;
  padding:46px 22px 90px;
}
.gallery figure{margin:0;}
.gallery .frame{
  width:100%;aspect-ratio:1/1;overflow:hidden;background:#0c0c0c;
  border:1px solid rgba(242,239,232,.14);
}
.gallery img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.gallery figcaption{
  margin-top:15px;display:flex;justify-content:space-between;align-items:baseline;gap:14px;
  font-size:12px;text-transform:uppercase;letter-spacing:.05em;
}
.gallery figcaption .t{color:var(--fg);font-weight:700;}
.gallery figcaption .n{color:var(--muted);flex:none;}
@media(max-width:680px){
  .gallery{grid-template-columns:1fr;gap:46px;}
}

/* ----------------------------- generic big section (bark / idea) ----------------------------- */
.slab{
  min-height:78vh;display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--fg);
}
.slab .copy{padding:22px;display:flex;flex-direction:column;justify-content:space-between;gap:28px;}
.slab .copy h1{
  margin:0;font-weight:950;line-height:.74;letter-spacing:-.08em;text-transform:uppercase;
  font-size:clamp(54px,11vw,180px);
}
.slab .copy p{max-width:560px;font-size:12px;text-transform:uppercase;line-height:1.35;color:var(--muted);}
.slab .panel{
  border-left:1px solid var(--fg);background:#0c0c0c;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.slab .panel img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(125%);}

.btn{
  display:inline-block;border:1px solid var(--fg);
  padding:12px 20px;font-size:12px;text-transform:uppercase;letter-spacing:.1em;
  text-decoration:none;transition:background .2s,color .2s;align-self:flex-start;
}
.btn:hover{background:var(--fg);color:var(--bg);}

/* ----------------------------- video lightbox ----------------------------- */
.lightbox{
  position:fixed;inset:0;z-index:80;
  background:rgba(5,5,5,.96);
  display:none;overflow-y:auto;
  opacity:0;transition:opacity .25s ease;
}
.lightbox.open{display:block;opacity:1;}
.lightbox-stage{
  width:100%;max-width:1180px;margin:0 auto;
  padding:60px max(22px,4vw) 80px;
}
.lightbox-meta{
  font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);
  margin-bottom:10px;padding-right:80px;
}
.lightbox-video{
  position:relative;width:100%;aspect-ratio:16/9;
  background:#000;border:1px solid var(--fg);
}
#lightbox-frame{position:absolute;inset:0;}
.lightbox-video iframe{width:100%;height:100%;border:0;display:block;}
.lightbox-close{
  position:fixed;right:24px;top:18px;z-index:81;
  background:none;border:0;color:var(--fg);cursor:pointer;
  font-size:13px;text-transform:uppercase;letter-spacing:.1em;padding:6px 2px;
}
.lightbox-close:hover{color:var(--muted);}

.lightbox-credits{margin-top:26px;}
.lightbox-credits.empty{display:none;}
.lightbox-credits h4{
  margin:0 0 14px;font-size:12px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);border-top:1px solid var(--hair);padding-top:16px;
}
.lightbox-credits ul{
  list-style:none;margin:0;padding:0;
  columns:2;column-gap:48px;
}
.lightbox-credits li{
  break-inside:avoid;margin-bottom:7px;
  font-size:11px;text-transform:uppercase;letter-spacing:.03em;
  line-height:1.4;color:var(--fg);
}
.lightbox-credits li .role{color:var(--muted);}

body.lb-lock{overflow:hidden;}
@media(max-width:620px){
  .lightbox-credits ul{columns:1;}
}

/* ----------------------------- bio ----------------------------- */
.bio{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;
  max-width:1180px;margin:0 auto;padding:42px 22px 90px;align-items:start;
}
.bio .portrait{width:100%;border:1px solid var(--hair);background:#0c0c0c;}
.bio .portrait img{width:100%;height:auto;display:block;filter:grayscale(1) contrast(108%);}
.bio .text h1{
  margin:.2em 0 .35em;font-weight:950;line-height:.82;letter-spacing:-.05em;text-transform:uppercase;
  font-size:clamp(40px,6.5vw,92px);
}
.bio .text p{
  max-width:600px;font-size:15px;line-height:1.7;letter-spacing:0;
  color:#cfcabf;margin:0 0 18px;
}
.bio .text p.lead{color:var(--fg);font-size:17px;line-height:1.6;}
.bio .text p.muted{color:var(--muted);font-size:13px;}
.bio .facts{
  margin-top:26px;border-top:1px solid var(--hair);padding-top:18px;
  display:grid;grid-template-columns:1fr 1fr;gap:10px 28px;
}
.bio .facts div{font-size:11px;text-transform:uppercase;letter-spacing:.04em;line-height:1.4;}
.bio .facts .k{color:var(--muted);display:block;margin-bottom:2px;}
@media(max-width:780px){
  .bio{grid-template-columns:1fr;gap:30px;}
  .bio .facts{grid-template-columns:1fr;}
}

/* ----------------------------- shop ----------------------------- */
.shop-notice{
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  margin:18px 22px 0;padding:20px 0;
  border-top:1px solid var(--fg);border-bottom:1px solid var(--hair);
}
.shop-notice-copy{display:flex;flex-direction:column;gap:8px;}
.shop-notice-copy p{margin:0;max-width:560px;font-size:12px;text-transform:uppercase;line-height:1.35;color:var(--muted);}

.shop{
  display:grid;grid-template-columns:repeat(3,1fr);gap:46px 36px;
  max-width:1180px;margin:0 auto;padding:40px 22px 90px;
}
.shop .item{display:flex;flex-direction:column;}
.shop .ph{
  position:relative;aspect-ratio:3/2;overflow:hidden;
  background:#0e0e0e;border:1px solid rgba(242,239,232,.14);
  display:flex;align-items:center;justify-content:center;
}
.shop .ph .big{
  font-weight:950;letter-spacing:-.04em;text-transform:uppercase;
  font-size:clamp(30px,4.5vw,58px);color:rgba(242,239,232,.10);
}
.shop .ph img{width:100%;height:100%;object-fit:cover;display:block;}
.shop .ph .tag{
  position:absolute;top:10px;left:10px;z-index:1;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg);
  background:rgba(5,5,5,.72);border:1px solid rgba(242,239,232,.25);padding:3px 8px;
}
.shop .name{
  margin-top:15px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
}
.shop .meta{
  margin-top:6px;display:flex;justify-content:space-between;
  font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
}
@media(max-width:880px){ .shop{grid-template-columns:repeat(2,1fr);} }
@media(max-width:560px){ .shop{grid-template-columns:1fr;gap:34px;} }

/* ----------------------------- spotify player (bark) ----------------------------- */
.player{padding:0 22px 70px;}
.player-embed{
  margin-top:18px;
  border:1px solid var(--fg);
  background:#0c0c0c;
}
.player-embed iframe{display:block;width:100%;border:0;}

/* ----------------------------- footer ----------------------------- */
footer{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;
  padding:22px;border-top:1px solid var(--fg);
  font-size:12px;text-transform:uppercase;line-height:1.3;
}
footer a{text-decoration:none;border-bottom:1px solid transparent;}
footer a:hover{border-bottom-color:var(--fg);}

/* ----------------------------- responsive ----------------------------- */
@media(max-width:880px){
  .grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:780px){
  header{position:absolute;grid-template-columns:auto auto;row-gap:12px;}
  .page{padding-top:96px;}
  header nav{order:3;grid-column:1 / -1;justify-self:start;flex-wrap:wrap;gap:16px;}
  .intro,.slab,footer{grid-template-columns:1fr;}
  .manifesto{columns:1;}
  .big-meta{text-align:left;justify-self:start;}
  .work{grid-template-columns:1fr;gap:8px;}
  .work .view{justify-self:start;}
  .slab .panel{border-left:0;border-top:1px solid var(--fg);min-height:48vh;}
}
