:root {
  --bg: #faf9f7;
  --ink: #141414;
  --dim: #8a8782;
  --line: #e6e3de;
  --mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;
  --sans: "Archivo", -apple-system, Helvetica, sans-serif;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--ink); font-family: var(--sans); -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img, video { display: block; max-width: 100%; }

/* ---------- intro scene ---------- */
#intro {
  position: fixed; inset: 0; z-index: 100; background: #000;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: opacity 1.1s ease, visibility 1.1s;
}
#intro.gone { opacity: 0; visibility: hidden; }
#intro video {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: 0; transition: opacity 1.4s ease;
}
#intro.lit video { opacity: 0.62; }
#intro .name {
  position: relative; z-index: 2; text-align: center; color: #f5f3ef;
}
#intro .name h1 {
  font-family: var(--sans); font-weight: 600; font-size: clamp(28px, 6vw, 76px);
  letter-spacing: 0.34em; text-indent: 0.34em; text-transform: uppercase;
  opacity: 0; transform: translateY(10px); transition: opacity 1.6s ease 0.5s, transform 1.6s ease 0.5s;
}
#intro .name .role {
  font-family: var(--mono); font-size: clamp(9px, 1.3vw, 12px);
  letter-spacing: 0.5em; text-indent: 0.5em; text-transform: uppercase;
  color: rgba(245,243,239,0.7); margin-top: 18px;
  opacity: 0; transition: opacity 1.6s ease 1.4s;
}
#intro.lit .name h1 { opacity: 1; transform: none; }
#intro.lit .name .role { opacity: 1; }
#intro .skip {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.3em;
  color: rgba(245,243,239,0.45); z-index: 2;
  opacity: 0; transition: opacity 1s ease 2.4s;
}
#intro.lit .skip { opacity: 1; }

/* ---------- chrome ---------- */
header {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: baseline;
  padding: 26px clamp(18px, 4vw, 48px) 22px;
}
header .nav-l { justify-self: start; }
header .nav-r { justify-self: end; }
header .navlink {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--dim);
}
header .navlink:hover, header .navlink.active { color: var(--ink); }
header .mark {
  font-weight: 600; font-size: clamp(15px, 2.4vw, 21px);
  letter-spacing: 0.32em; text-indent: 0.32em; text-transform: uppercase; text-align: center;
  display: inline-flex; align-items: center; gap: 0.42em;
}
header .mark .markglyph {
  height: 1.45em; width: auto; display: block; text-indent: 0;
  margin-top: -0.04em; opacity: 0.92;
}
.rule { border-top: 1px solid var(--line); margin: 0 clamp(18px, 4vw, 48px); }

main { padding: 0 clamp(18px, 4vw, 48px) 60px; }
.sect { margin-top: 54px; }
.sect-head {
  display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px;
}
.sect-head h2 {
  font-family: var(--mono); font-weight: 400; font-size: 11px;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink);
}
.sect-head a { font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--dim); }
.sect-head a:hover { color: var(--ink); }

/* ---------- tiles ---------- */
.grid-films { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.row-scroll { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(150px, 190px); gap: 14px; overflow-x: auto; padding-bottom: 8px; scrollbar-width: thin; }
.grid-archive { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 14px; }
.grid-archive .tile.h { grid-column: span 2; }

.tile { cursor: pointer; }
.tile .ph { position: relative; overflow: hidden; background: #e8e5e0; }
.tile.h .ph { aspect-ratio: 16/9; }
.tile.v .ph { aspect-ratio: 9/16; }
.tile.s .ph { aspect-ratio: 1; }
.tile img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s ease, opacity 0.4s; }
.tile:hover img { transform: scale(1.025); }
.tile .meta {
  display: flex; justify-content: space-between; gap: 8px;
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--dim); margin-top: 7px;
}
.tile .ttl {
  font-size: 12.5px; font-weight: 500; margin-top: 6px; color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
@media (max-width: 720px) {
  .grid-films { grid-template-columns: 1fr; }
  .grid-archive { grid-template-columns: repeat(2, 1fr); }
  .grid-archive .tile.h { grid-column: span 2; }
}

/* ---------- filters ---------- */
.filters { display: flex; flex-wrap: wrap; gap: 14px 22px; margin: 30px 0 26px; }
.filters button {
  background: none; border: none; cursor: pointer; padding: 0;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--dim);
}
.filters button.on { color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 2px; }

/* ---------- lightbox ---------- */
#box {
  position: fixed; inset: 0; z-index: 90; background: rgba(8,8,8,0.96);
  display: none; align-items: center; justify-content: center; flex-direction: column;
}
#box.open { display: flex; }
#box video { max-width: min(92vw, 1280px); max-height: 78vh; background: #000; }
#box .boxmeta {
  display: flex; gap: 26px; align-items: baseline; margin-top: 16px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: rgba(245,243,239,0.6);
}
#box .boxmeta a { color: rgba(245,243,239,0.85); border-bottom: 1px solid rgba(245,243,239,0.3); }
#box .x {
  position: absolute; top: 20px; right: 28px; font-family: var(--mono);
  font-size: 12px; letter-spacing: 0.2em; color: rgba(245,243,239,0.7); cursor: pointer;
}
#box .x:hover { color: #fff; }

/* ---------- information ---------- */
.info { max-width: 640px; margin-top: 60px; }
.info p { font-size: 15.5px; line-height: 1.75; margin-bottom: 20px; }
.info .label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.28em;
  text-transform: uppercase; color: var(--dim); margin: 38px 0 10px;
}
.info .clients { font-size: 14px; line-height: 2; }
.info a.contact { border-bottom: 1px solid var(--line); }
.info a.contact:hover { border-color: var(--ink); }

footer {
  padding: 40px clamp(18px, 4vw, 48px); border-top: 1px solid var(--line); margin-top: 70px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px;
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--dim);
}
footer a:hover { color: var(--ink); }

/* ---------- italy hero ---------- */
.hero { position: relative; aspect-ratio: 21/9; min-height: 320px; max-height: 72vh; overflow: hidden; background: #0c0c0c; margin-top: 28px; }
.hero video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 1.2s ease; }
.hero video.on { opacity: 1; }
.hero .hero-cap {
  position: absolute; left: 18px; bottom: 14px; z-index: 2;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.28em;
  text-transform: uppercase; color: rgba(245,243,239,0.75);
}
@media (max-width: 720px) { .hero { aspect-ratio: 16/10; } }

/* ---------- bluehour work index ---------- */
.viewtoggle { display: flex; gap: 16px; }
.viewtoggle button {
  background: none; border: none; cursor: pointer; padding: 0 0 2px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--dim);
}
.viewtoggle button.on { color: var(--ink); border-bottom: 1px solid var(--ink); }
.worklist { border-top: 1px solid var(--line); }
.wrow {
  display: grid; grid-template-columns: 1fr 130px 56px 50px;
  gap: 14px; align-items: baseline; padding: 13px 2px;
  border-bottom: 1px solid var(--line); cursor: pointer;
}
.wrow:hover { background: #f2f0ec; }
.wrow .wt { font-size: 14px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wrow .wc, .wrow .wy, .wrow .wd {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--dim); text-align: right;
}
@media (max-width: 600px) { .wrow { grid-template-columns: 1fr 60px; } .wrow .wc, .wrow .wd { display: none; } }

/* ---------- featured commercials ---------- */
.grid-feat { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px 22px; }
.grid-feat .ftile:first-child { grid-column: span 2; }
.ftile { cursor: pointer; }
.ftile .ph { aspect-ratio: 16/9; overflow: hidden; background: #e8e5e0; }
.ftile img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s ease; }
.ftile:hover img { transform: scale(1.02); }
.ftile .fttl { font-size: 17px; font-weight: 600; margin-top: 10px; letter-spacing: 0.01em; }
.ftile .fmeta {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--dim); margin-top: 4px;
}
@media (max-width: 720px) { .grid-feat { grid-template-columns: 1fr; } .grid-feat .ftile:first-child { grid-column: auto; } }

/* ---------- v2 format: hero statement + editorial rows ---------- */
.hero .hero-name {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: #f5f3ef; text-shadow: 0 1px 30px rgba(0,0,0,0.35); pointer-events: none;
}
.hero .hero-name h1 {
  font-weight: 600; font-size: clamp(34px, 7vw, 92px);
  letter-spacing: 0.3em; text-indent: 0.3em; text-transform: uppercase; line-height: 1;
}
.hero .hero-role {
  font-family: var(--mono); font-size: clamp(9px, 1.2vw, 12px);
  letter-spacing: 0.5em; text-indent: 0.5em; text-transform: uppercase;
  color: rgba(245,243,239,0.85); margin-top: 16px;
}
.hero { max-height: 86vh; aspect-ratio: 16/8; margin-top: 0; }
header .mark { visibility: visible; }

.sect-head h2 { font-size: 12px; }
.featrows { display: flex; flex-direction: column; gap: clamp(56px, 8vw, 96px); margin-top: 10px; }
.frow { position: relative; cursor: pointer; }
.frow .num {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em;
  color: var(--dim); margin-bottom: 10px;
}
.frow .fph { aspect-ratio: 21/10; overflow: hidden; background: #101010; }
.frow .fph img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s ease; }
.frow:hover .fph img { transform: scale(1.018); }
.frow .fblock { display: grid; grid-template-columns: 1fr auto; align-items: baseline; gap: 4px 20px; margin-top: 16px; }
.frow .fttl { font-size: clamp(22px, 3.4vw, 40px); font-weight: 600; letter-spacing: 0.005em; grid-column: 1; }
.frow .fmeta { grid-column: 1; margin-top: 2px; }
.frow .fplay {
  grid-column: 2; grid-row: 1 / span 2; align-self: center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--dim); border-bottom: 1px solid var(--line); padding-bottom: 3px;
  transition: color 0.3s;
}
.frow:hover .fplay { color: var(--ink); }
@media (max-width: 720px) {
  .hero { aspect-ratio: 16/11; }
  .frow .fph { aspect-ratio: 16/9; }
}

/* ============ v3: typographic site ============ */
body.v3 { background: #f4f2ee; }
.grain {
  position: fixed; inset: -50%; width: 200%; height: 200%; z-index: 99; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity: 0.035; animation: grain 7s steps(10) infinite;
}
@keyframes grain {
  0%,100% { transform: translate(0,0); } 20% { transform: translate(-2%,2%); }
  40% { transform: translate(2%,-1%); } 60% { transform: translate(-1%,-2%); } 80% { transform: translate(1%,2%); }
}
::selection { background: #141414; color: #f4f2ee; }

.masthead { padding: clamp(40px, 9vh, 110px) 0 clamp(36px, 7vh, 80px); }
.masthead h1 {
  font-weight: 700; font-size: clamp(64px, 14.5vw, 200px); line-height: 0.92;
  letter-spacing: -0.025em; text-transform: uppercase; margin-left: -0.04em;
}
.mast-foot {
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px 24px;
  margin-top: clamp(20px, 4vh, 40px);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--dim);
}

.works { margin-top: clamp(10px, 3vh, 30px); }
.works-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.3em;
  text-transform: uppercase; color: var(--dim);
  border-bottom: 1px solid var(--ink); padding-bottom: 10px;
}
.prow {
  display: grid; grid-template-columns: 54px 1fr auto 64px; align-items: center; gap: 18px;
  padding: clamp(20px, 3.4vh, 34px) 4px;
  border-bottom: 1px solid var(--line); cursor: pointer; position: relative;
}
.prow .pnum { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; color: var(--dim); }
.prow .pttl {
  font-weight: 600; font-size: clamp(26px, 4.6vw, 56px); line-height: 1;
  letter-spacing: -0.015em; text-transform: uppercase;
  transition: transform 0.45s cubic-bezier(0.22,1,0.36,1), opacity 0.3s;
}
.prow:hover .pttl { transform: translateX(14px); }
.prow .pclient, .prow .pyear {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--dim); text-align: right; white-space: nowrap;
}
.prow .pthumb { display: none; }
@media (max-width: 759px) {
  .prow { grid-template-columns: 1fr; gap: 8px; }
  .prow .pnum, .prow .pyear { display: none; }
  .prow .pthumb { display: block; width: 100%; aspect-ratio: 16/9; object-fit: cover; order: -1; }
  .prow .pclient { text-align: left; }
}

#peek {
  position: fixed; top: 0; left: 0; z-index: 60; width: min(380px, 30vw); aspect-ratio: 16/9;
  object-fit: cover; pointer-events: none; opacity: 0; scale: 0.96;
  transition: opacity 0.35s ease, scale 0.35s ease;
  box-shadow: 0 30px 80px rgba(10,10,10,0.35);
}
#peek.on { opacity: 1; scale: 1; }

.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.9s ease, transform 0.9s cubic-bezier(0.22,1,0.36,1); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- v3.1: ligthelm card grid ---------- */
.wgrid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 34px 22px;
  margin-top: 30px;
}
.wcard { cursor: pointer; }
.wcard .wph { position: relative; aspect-ratio: 16/9; overflow: hidden; background: #e6e3dd; }
.wcard .wph img, .wcard .wph video {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
}
.wcard .wph video { opacity: 0; transition: opacity 0.4s ease; }
.wcard.playing .wph video { opacity: 1; }
.wcard .wph img { transition: transform 0.8s ease; }
.wcard:hover .wph img { transform: scale(1.03); }
.wcard .wdur {
  position: absolute; right: 8px; bottom: 7px; z-index: 2;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.14em;
  color: rgba(245,243,239,0.9); background: rgba(10,10,10,0.45);
  padding: 2px 6px; backdrop-filter: blur(4px);
}
.wcard .wttl {
  font-weight: 600; font-size: 14.5px; letter-spacing: 0.01em;
  text-transform: uppercase; margin-top: 11px;
}
.wcard .wmeta {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--dim); margin-top: 4px;
}
@media (max-width: 900px) { .wgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .wgrid { grid-template-columns: 1fr; } }
/* tighten the old prow leftovers if any cached */
.prow { display: none; }
