/* ============================================================
   VIDEOMAKER GRAPHIC — Vincenzo Giannino — Portfolio site
   Tokens
   - bg light:    #ECEDE7 (warm paper grey)
   - bg dark:     #0B0B0C (intro / hero)
   - ink:         #111111
   - line grey:   #9A9A93
   - accent gold: #E2B23C
   - accent blue: #2E5BD7
   - accent red:  #D5483B
   - accent green:#3C8A5B
   Type
   - display: "Archivo Black" (wordmark, big numerals)
   - heading: "Archivo" (section titles)
   - body:    "Inter"
   - mono:    "Space Mono" (labels / eyebrows / nav)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Archivo:wght@500;600;700;800&family=Inter:wght@400;500;600&family=Space+Mono:wght@400;700&display=swap');

:root{
  --bg:        #ECEDE7;
  --bg-dark:   #0B0B0C;
  --ink:       #111111;
  --ink-soft:  #4a4a46;
  --line:      #9A9A93;
  --gold:      #E2B23C;
  --blue:      #2E5BD7;
  --red:       #D5483B;
  --green:     #3C8A5B;
  --pink:      #E07FB0;

  --display: "Archivo Black", "Archivo", sans-serif;
  --head:    "Archivo", sans-serif;
  --body:    "Inter", sans-serif;
  --mono:    "Space Mono", monospace;

  --maxw: 1180px;
  --pad: 6vw;
}

@media (min-width: 1100px){
  :root{ --pad: 64px; }
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }

::selection{ background:var(--gold); color:var(--ink); }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}

/* ---------- INTRO OVERLAY (text on background, then gives way to the photo) ---------- */
#intro{
  position:fixed; inset:0; z-index:999;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg);
  transition:background 0.9s ease, opacity 0.45s ease;
}
#intro.dark{ background:var(--bg-dark); }
#intro.hide{ opacity:0; pointer-events:none; }

.intro-photo{
  position:absolute; inset:0;
  opacity:0;
  transition:opacity 1.1s ease;
}
.intro-photo.show{ opacity:1; }
.intro-photo img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover; object-position:center 18%;
  filter:grayscale(0.25) contrast(1.08);
}
.intro-photo::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(11,11,12,0.92) 0%, rgba(11,11,12,0.35) 38%, rgba(11,11,12,0.15) 60%, rgba(11,11,12,0.55) 100%);
}

.intro-word{
  position:relative; z-index:2;
  text-align:center;
  font-family:var(--display);
  line-height:0.9;
  color:var(--ink);
  transition:color 0.9s ease;
}
#intro.dark .intro-word{
  color:transparent;
  -webkit-text-stroke:1.5px var(--line);
  text-stroke:1.5px var(--line);
}

/* ---------- HERO TEXT REVEAL (extra lines fade in once the intro is gone) ---------- */
.fade-el{ opacity:0; transition:opacity 1s ease; }
.fade-el.show{ opacity:1; }

.intro-row{ display:flex; align-items:baseline; overflow:hidden; white-space:nowrap; width:fit-content; margin-left:auto; margin-right:auto; }
.intro-row .letter-main{ font-size:clamp(48px,11vw,128px); line-height:1; }
.intro-row .letter-rest{
  font-size:clamp(48px,11vw,128px); line-height:1;
  display:inline-block;
  max-width:0;
  overflow:hidden;
  white-space:nowrap;
  transition:max-width 0.8s cubic-bezier(.65,0,.35,1);
}
.intro-row.expand .letter-rest{ max-width:1200px; }
.intro-row:first-child{ margin-bottom:0.02em; }

/* ---------- HEADER / NAV ---------- */
header{
  position:fixed; top:0; left:0; right:0; z-index:300;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--pad);
  background:transparent;
  transition:background 0.4s ease, padding 0.4s ease, border-color .4s ease;
  border-bottom:1px solid transparent;
}
header.scrolled{
  background:rgba(11,11,12,0.92);
  border-bottom:1px solid rgba(255,255,255,0.08);
  padding-top:16px; padding-bottom:16px;
  backdrop-filter:blur(8px);
}
.logo{
  display:flex; align-items:center;
  height:30px;
}
.logo img{
  height:100%; width:auto; display:block;
  filter:brightness(0) invert(1); /* render the grey logo as white on the dark header */
}
nav.mainnav{ display:flex; gap:34px; }
nav.mainnav a{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--bg);
  opacity:0.75;
  position:relative;
  padding-bottom:4px;
}
nav.mainnav a:hover{ opacity:1; }
nav.mainnav a.active{ opacity:1; }
nav.mainnav a.active::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height:2px; background:var(--gold);
}
.burger{ display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; }
.burger span{ width:24px; height:2px; background:var(--bg); display:block; }

@media (max-width:760px){
  nav.mainnav{ display:none; }
  .burger{ display:flex; }
}

/* mobile menu yellow overlay (homage to the original gold nav screen) */
#mobileMenu{
  position:fixed; inset:0; z-index:400;
  background:var(--gold);
  display:flex; align-items:center; justify-content:center;
  transform:translateY(-100%);
  transition:transform .55s cubic-bezier(.76,0,.24,1);
}
#mobileMenu.open{ transform:translateY(0); }
#mobileMenu nav{ display:flex; flex-direction:column; gap:18px; text-align:center; }
#mobileMenu a{
  font-family:var(--head); font-weight:800;
  font-size:34px; letter-spacing:0.02em;
  color:var(--ink);
}
#mobileMenu .close{
  position:absolute; top:24px; right:var(--pad);
  font-family:var(--mono); font-size:13px; letter-spacing:.08em;
  background:none;border:none;cursor:pointer;color:var(--ink);
}

/* ---------- HERO (dark, post-intro) ---------- */
.hero{
  position:relative;
  background:var(--bg-dark);
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden;
  padding-top:110px; padding-bottom:70px;
}
.hero-photo{
  position:absolute; inset:0;
  z-index:1;
}
.hero-photo img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover; object-position:center 18%;
  filter:grayscale(0.25) contrast(1.08);
}
.hero-photo::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to top, rgba(11,11,12,0.92) 0%, rgba(11,11,12,0.35) 38%, rgba(11,11,12,0.15) 60%, rgba(11,11,12,0.55) 100%);
}
.hero-word{
  position:relative; z-index:2;
  text-align:center;
  font-family:var(--display);
  line-height:0.9;
  color:transparent;
  -webkit-text-stroke:1.5px var(--line);
  text-stroke:1.5px var(--line);
}
.hero-word span{ display:block; font-size:clamp(48px,11vw,128px); }
.hero-tagline{
  position:relative; z-index:2;
  text-align:center;
  margin:26px auto 0;
  font-family:var(--mono);
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-size:13px;
  color:var(--bg);
  opacity:0.7;
}
.hero-tagline b{ color:var(--gold); opacity:1; font-weight:700; }

.scroll-cue{
  position:relative; z-index:2;
  margin:46px auto 0;
  width:fit-content;
  font-family:var(--mono); font-size:12px; letter-spacing:0.2em;
  color:var(--bg); opacity:0.55;
  display:flex; align-items:center; gap:10px;
  text-transform:uppercase;
}
.scroll-cue .bar{ width:1px; height:26px; background:var(--bg); opacity:0.55; animation:scrollbar 1.6s infinite; }
@keyframes scrollbar{ 0%{ transform:scaleY(0); transform-origin:top;} 50%{ transform:scaleY(1); transform-origin:top;} 51%{transform-origin:bottom;} 100%{ transform:scaleY(0); transform-origin:bottom;} }

/* ---------- MARQUEE (tool icons) ---------- */
.marquee-section{
  background:var(--bg-dark);
  border-top:1px solid rgba(255,255,255,0.08);
  padding:26px 0;
  overflow:hidden;
}
.marquee{
  display:flex; width:max-content;
  animation:scrollx 28s linear infinite;
}
.marquee:hover{ animation-play-state:paused; }
@keyframes scrollx{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
.tool{
  display:flex; align-items:center; gap:10px;
  margin:0 22px;
  font-family:var(--mono); font-size:13px; letter-spacing:.04em;
  color:var(--bg); opacity:0.85; white-space:nowrap;
}
.tool .badge{
  width:38px; height:38px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--head); font-weight:800; font-size:14px;
  letter-spacing:-0.02em;
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.08) inset;
}

/* ---------- SECTION generic ---------- */
section{ position:relative; }
.eyebrow{
  font-family:var(--mono); font-size:12px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--ink-soft);
  display:flex; align-items:center; gap:10px;
  margin-bottom:18px;
}
.eyebrow::before{ content:""; width:24px; height:1px; background:var(--ink-soft); }

/* ---------- BIO ---------- */
.bio{
  background:var(--bg);
  padding:120px 0 100px;
}
.bio .wrap{ display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:start; }
.bio-photo-wrap{ position:relative; }
.bio-photo-wrap img{ filter:contrast(1.05); width:100%; aspect-ratio:3/4; object-fit:cover; }
.bio-photo-wrap::after{
  content:""; position:absolute; top:18px; left:18px; right:-18px; bottom:-18px;
  border:1.5px solid var(--ink); z-index:-1;
}
h2.title{
  font-family:var(--head); font-weight:800;
  font-size:clamp(32px,4.4vw,52px);
  line-height:1.05; margin:0 0 24px;
  letter-spacing:-0.01em;
}
.bio p{
  font-size:17px; line-height:1.7; color:var(--ink-soft);
  max-width:540px; margin:0 0 18px;
}
.skill-list{
  margin-top:30px; display:flex; flex-wrap:wrap; gap:10px;
}
.skill-list span{
  font-family:var(--mono); font-size:12px; letter-spacing:.04em;
  border:1px solid var(--ink); padding:7px 14px; border-radius:30px;
}


/* ---------- COLLAB / TIRITITTITTÌ ---------- */
.collab{
  background:#ffffff;
  position:relative;
  padding:130px 0 160px;
  /* clip laterally but NOT vertically so the palazzo translateY(100%) is still observed */
  overflow-x:clip;
  overflow-y:visible;
}

/* ---- palazzo: anchored right, full height of section, slides up from bottom ---- */
.collab-palazzo{
  position:absolute;
  right:0; top:0; bottom:0;
  width:48vw;
  transform:translateY(110%);
  opacity:0;
  transition:transform 1.2s cubic-bezier(.16,.86,.32,1), opacity .9s ease;
  pointer-events:none;
  z-index:1;
}
.collab-palazzo.in{
  transform:translateY(0);
  opacity:1;
}
.collab-palazzo img{
  width:100%; height:100%;
  object-fit:contain; object-position:bottom right;
  display:block;
}

/* ---- cineforum poster: starts right, lands on left ---- */
.collab-cinema{
  position:absolute;
  left:clamp(20px,4vw,60px);
  top:60%;
  width:clamp(160px,18vw,260px);
  transform:translateX(130vw);
  opacity:0;
  transition:transform 1s cubic-bezier(.16,.86,.32,1), opacity .6s ease;
  z-index:3;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.15);
}
.collab-cinema.slide-in{
  transform:translateX(0);
  opacity:1;
}
.collab-cinema img{ width:100%; height:auto; display:block; }

/* clickable wrapper on cinema poster */
.collab-cinema-link{
  display:block; position:relative; text-decoration:none;
}
.collab-cinema-link:hover img{ opacity:.88; }
.collab-cinema-hint{
  position:absolute; bottom:10px; left:50%; transform:translateX(-50%);
  white-space:nowrap;
  background:rgba(0,0,0,.72); color:#fff;
  font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  padding:5px 12px; border-radius:20px;
  opacity:0;
  transition:opacity .22s ease;
  pointer-events:none;
}
.collab-cinema-link:hover .collab-cinema-hint{ opacity:1; }

/* Pop Core logo — slides in from left with the text body */
.popcore-logo{
  margin-bottom:28px;
  transform:translateX(-60px);
  opacity:0;
  transition:transform .9s cubic-bezier(.2,.8,.2,1) .15s, opacity .7s ease .15s;
}
.collab-body.in .popcore-logo{
  transform:translateX(0);
  opacity:1;
}
/* placeholder shown until real logo PNG is dropped in */
.popcore-logo-ph{
  display:inline-block;
  font-family:var(--head); font-weight:900; font-size:22px; line-height:1.1;
  letter-spacing:-0.02em; color:var(--ink);
  border:2px solid var(--ink); border-radius:8px;
  padding:8px 16px;
}
.popcore-logo-ph span{ color:var(--gold); }
/* real logo image (when provided) */
.popcore-logo img{ height:64px; width:auto; display:block; }



/* ---- text block: slightly left of center, clear of palazzo ---- */
.collab-body{
  position:relative; z-index:2;
  width:44%;
  margin:0 auto 0 clamp(60px,20vw,260px);
  padding-left:0;
  transform:translateX(-70px);
  opacity:0;
  transition:transform .9s cubic-bezier(.2,.8,.2,1), opacity .7s ease;
  display:flex;
  align-items:flex-start;
  gap:28px;
}
.collab-body.in{
  transform:translateX(0);
  opacity:1;
}

/* Pop Core logo — sits to the LEFT of the text, slides in with body */
.popcore-logo{
  flex:0 0 auto;
  transform:translateX(-60px);
  opacity:0;
  transition:transform .9s cubic-bezier(.2,.8,.2,1) .15s, opacity .7s ease .15s;
}
.collab-body.in .popcore-logo{
  transform:translateX(0);
  opacity:1;
}
/* placeholder */
.popcore-logo-ph{
  display:inline-block; text-align:center;
  font-family:var(--head); font-weight:900; font-size:15px; line-height:1.2;
  letter-spacing:-0.01em; color:var(--ink);
  border:2px solid var(--ink); border-radius:8px;
  padding:10px 12px;
}
.popcore-logo-ph span{ color:var(--gold); }
/* real logo image (when provided) */
.popcore-logo img{ width:80px; height:auto; display:block; }

.collab-text p{
  font-size:17px; line-height:1.75; color:var(--ink-soft);
  margin:0 0 22px;
}
.collab-text strong{ color:var(--ink); font-weight:700; }

.collab-cta{
  display:inline-flex; align-items:center; gap:12px;
  margin-top:36px;
  font-family:var(--mono); font-size:13px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink);
  border-bottom:1.5px solid var(--ink); padding-bottom:6px;
  text-decoration:none;
  transition:color .2s ease, border-color .2s ease;
}
.collab-cta:hover{ color:var(--gold); border-color:var(--gold); }
.collab-cta-icon{
  font-size:18px; line-height:1;
  display:inline-block;
  transition:transform .25s ease;
}
.collab-cta:hover .collab-cta-icon{ transform:translate(3px,-3px); }

@media (max-width:860px){
  .collab-palazzo{ display:none; }
  .collab-cinema{
    position:relative; left:auto; top:auto;
    width:100%; max-width:320px;
    margin:30px auto 0;
    transform:none; opacity:1;
  }
  .collab-body{
    flex-direction:column;
    margin-left:0; width:100%;
    transform:none; opacity:1;
    padding-left:clamp(20px,5vw,40px);
    padding-right:clamp(20px,5vw,40px);
  }
  .popcore-logo{ transform:none; opacity:1; }
}

/* ---------- PASSION / DRONE PARALLAX ---------- */
.passion{
  background:var(--bg-dark); color:var(--bg);
  padding:140px 0; overflow:hidden; position:relative;
}
.passion .wrap{ position:relative; z-index:2; }
.passion .eyebrow{ color:var(--gold); }
.passion .eyebrow::before{ background:var(--gold); }
.passion h2.title{ color:var(--bg); max-width:680px; }
.passion p{ color:#cfcfc9; font-size:17px; line-height:1.7; max-width:520px; }
.drone{
  position:absolute; top:8%; left:-14%;
  width:240px; opacity:0; z-index:1;
  will-change:transform, opacity;
}
.drone img{ width:100%; display:block; filter:drop-shadow(0 18px 26px rgba(0,0,0,.4)); }

/* ---------- CTA QUOTE ---------- */
.cta{
  background:var(--blue); color:#fff;
  padding:130px 0; position:relative; overflow:hidden;
}
.cta .wrap{ position:relative; z-index:2; display:flex; gap:40px; align-items:flex-start; }
.cta-text{
  font-family:var(--head); font-weight:700;
  font-size:clamp(26px,3.6vw,44px); line-height:1.25;
  max-width:780px;
}
.cta-text .yes{ color:var(--gold); }
.cta-text .no{ color:rgba(255,255,255,.55); text-decoration:line-through; }
.cta-photo{
  flex:0 0 auto; width:120px; height:120px; border-radius:50%;
  overflow:hidden; border:3px solid rgba(255,255,255,.35);
  margin-top:8px;
}
.cta-photo img{ width:100%; height:100%; object-fit:cover; }
.cta-link{
  display:inline-flex; align-items:center; gap:10px; margin-top:38px;
  font-family:var(--mono); font-size:13px; letter-spacing:.1em; text-transform:uppercase;
  border-bottom:1px solid #fff; padding-bottom:6px;
}

/* ---------- FOOTER / CONTACT ---------- */
footer{
  background:var(--bg-dark); color:var(--bg);
  padding:90px 0 40px;
}
footer .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,.12); }
footer h3{ font-family:var(--head); font-size:clamp(28px,4vw,42px); margin:0 0 14px; max-width:380px; }
footer .colhead{ font-family:var(--mono); font-size:12px; letter-spacing:.15em; text-transform:uppercase; opacity:.55; margin-bottom:14px; }
footer .links a{ display:block; padding:6px 0; font-size:15px; opacity:.85; }
footer .links a:hover{ opacity:1; color:var(--gold); }
footer .bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-family:var(--mono); font-size:12px; opacity:.5; flex-wrap:wrap; gap:10px; }

@media (max-width:760px){
  .bio .wrap{ grid-template-columns:1fr; }
  .bio-photo-wrap{ max-width:340px; }
  .cta .wrap{ flex-direction:column-reverse; }
  footer .top{ grid-template-columns:1fr; gap:30px; }
}

/* ---------- OPERE / PORTFOLIO PAGE ---------- */
.opere-hero{
  background:var(--bg-dark); color:var(--bg);
  padding:170px 0 80px;
}
.opere-hero h1{
  font-family:var(--display); font-size:clamp(48px,9vw,110px);
  line-height:0.92; margin:0 0 14px; color:transparent;
  -webkit-text-stroke:1.5px var(--line);
}
.opere-hero p{ font-family:var(--mono); font-size:13px; letter-spacing:.1em; text-transform:uppercase; opacity:.6; max-width:480px; }

.grid-gallery{
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  background:var(--ink);
}
.tile{
  position:relative; aspect-ratio:4/3; overflow:hidden;
  display:flex; align-items:flex-end; padding:22px;
  isolation:isolate;
}
.tile .num{ font-family:var(--mono); font-size:12px; color:rgba(255,255,255,.7); position:absolute; top:18px; left:18px; }
.tile .name{
  font-family:var(--head); font-weight:800; color:#fff; font-size:20px;
  letter-spacing:-0.01em;
  transform:translateY(10px); opacity:0;
  transition:transform .35s ease, opacity .35s ease;
}
.tile:hover .name{ transform:translateY(0); opacity:1; }
.tile::after{
  content:""; position:absolute; inset:0; background:rgba(0,0,0,0);
  transition:background .35s ease; z-index:1;
}
.tile:hover::after{ background:rgba(0,0,0,0.18); }
.tile .tag{
  position:absolute; bottom:18px; right:18px;
  font-family:var(--mono); font-size:11px; color:rgba(255,255,255,.75);
  text-transform:uppercase; letter-spacing:.08em;
}
.c1{background:var(--blue);} .c2{background:#E8772E;} .c3{background:var(--green);}
.c4{background:#E8772E;} .c5{background:var(--pink);} .c6{background:var(--gold);}
.c7{background:var(--green);} .c8{background:var(--blue);} .c9{background:var(--gold);}

/* tile with a real photo */
.tile.has-photo{
  background-size:cover;
  background-position:center;
}
.tile.has-photo::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(to top, rgba(0,0,0,.7) 0%, rgba(0,0,0,.15) 60%, transparent 100%);
}
.tile.has-photo .num,
.tile.has-photo .name,
.tile.has-photo .tag{ position:relative; z-index:2; }

.opere-note{
  padding:70px var(--pad) 110px; max-width:var(--maxw); margin:0 auto;
  font-family:var(--mono); font-size:13px; color:var(--ink-soft); letter-spacing:.02em;
}

@media (max-width:760px){
  .grid-gallery{ grid-template-columns:repeat(2,1fr); }
}

/* ---------- STORY SECTIONS (percorso di studi / esperienze) ---------- */
.story{ background:var(--bg); padding:110px 0; }
.story.alt{ background:#E2E3DC; }
.story .wrap > .eyebrow{ justify-content:center; }
.story .story-head{
  max-width:960px; margin:0 auto 50px;
  display:flex; align-items:center; gap:48px;
}
.story .story-head .eyebrow{ justify-content:flex-start; }
.story .story-head .title{ text-align:left; margin:0; }

/* ISIS Europa logo — absolute, left edge of section, slides in from right */
#storyFormazione{ overflow:hidden; }
.story-head-logo{
  position:absolute;
  left:clamp(0px, 2vw, 30px);
  top:clamp(60px,10vw,120px);
  width:clamp(180px,24vw,300px);
  height:auto;
  z-index:2;
  /* start off right edge */
  transform:translateX(120vw);
  opacity:0;
  transition:transform 1s cubic-bezier(.16,.86,.32,1), opacity .8s ease;
}
.story-head-logo.in{
  transform:translateX(0);
  opacity:1;
}
@media(max-width:700px){
  .story-head-logo{ position:relative; left:auto; top:auto; width:130px; transform:none; opacity:1; display:block; margin:0 auto 24px; }
  #storyFormazione{ overflow:visible; }
}
.story-body{ max-width:760px; margin:0 auto; }
.story-body p{ font-size:16.5px; line-height:1.75; color:var(--ink-soft); margin:0 0 18px; }

.media-row{
  display:grid; grid-template-columns:1fr 1fr 1.2fr; gap:16px;
  margin-top:54px;
}
.media-card{
  position:relative; border-radius:4px; overflow:hidden;
  aspect-ratio:3/4; background:#1a1a1a;
}
.media-card img{ width:100%; height:100%; object-fit:cover; filter:grayscale(0.35) contrast(1.05); }
.media-card .cap{
  position:absolute; left:0; right:0; bottom:0;
  padding:14px 16px;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  color:#fff;
  background:linear-gradient(to top, rgba(0,0,0,.75), transparent);
}
.media-card.placeholder{
  display:flex; align-items:center; justify-content:center; flex-direction:column; gap:10px;
  background:repeating-linear-gradient(135deg, #1a1a1a, #1a1a1a 10px, #222 10px, #222 20px);
  color:rgba(255,255,255,.6);
  text-align:center; padding:20px;
}
.media-card.placeholder .ph-icon{
  width:44px; height:44px; border-radius:50%; border:1.5px solid rgba(255,255,255,.5);
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.media-card.placeholder span.txt{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; line-height:1.5; }

/* ---------- STORY: foto originali affiancate + placeholder video 16:9 ---------- */
.media-photos-row{
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
  margin-top:54px;
}
.media-photo-fig{
  margin:0;
  display:flex; flex-direction:column; gap:10px;
}
.media-photo-fig img{
  width:100%; height:auto; display:block;
  border-radius:4px;
  filter:grayscale(0.2) contrast(1.04);
}
.media-photo-fig figcaption{
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-soft);
}
.media-video-row{
  margin-top:20px;
}
.media-video-placeholder{
  aspect-ratio:16/9; width:100%;
  background:repeating-linear-gradient(135deg, #1a1a1a, #1a1a1a 10px, #222 10px, #222 20px);
  border-radius:4px;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.5);
}
.media-video-placeholder .ph-icon{
  width:56px; height:56px; border-radius:50%; border:1.5px solid rgba(255,255,255,.4);
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.media-video-cap{
  margin:10px 0 0;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-soft);
}
@media (max-width:600px){
  .media-photos-row{ grid-template-columns:1fr; }
}

.story-split{
  display:grid; grid-template-columns:1.2fr 1fr; gap:60px; align-items:center;
  max-width:1020px; margin:0 auto;
}
.story-split .story-body{ max-width:none; }

.work-photo{ position:relative; }
.work-photo img{ width:100%; aspect-ratio:4/3; object-fit:cover; filter:grayscale(0.15) contrast(1.05); display:block; border-radius:4px; }
.work-photo .cap{
  margin-top:12px; font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft);
}

@media (max-width:820px){
  .story-split{ grid-template-columns:1fr; gap:34px; }
  .work-photo{ max-width:420px; margin:0 auto; }
}

@media (max-width:760px){
  .media-row{ grid-template-columns:1fr 1fr; }
  .media-row .media-card:last-child{ grid-column:1 / -1; }
}

.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ---------- CONTACT FORM ---------- */
.contact-form{
  background:var(--bg-dark); color:var(--bg);
  padding:120px 0 80px;
  border-top:1px solid rgba(255,255,255,.08);
}
.contact-form .eyebrow{ color:var(--gold); justify-content:center; }
.contact-form .eyebrow::before{ background:var(--gold); }
.contact-form .title{ color:var(--bg); text-align:center; max-width:560px; margin:0 auto 50px; }
.contact-form form{ max-width:640px; margin:0 auto; display:flex; flex-direction:column; gap:30px; }
.contact-form .field-row{ display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.contact-form label{
  display:flex; flex-direction:column; gap:10px;
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.contact-form input, .contact-form textarea{
  background:transparent; border:none; border-bottom:1px solid rgba(255,255,255,.28);
  color:#fff; font-family:var(--body); font-size:16px; padding:10px 2px;
  font-weight:400; resize:vertical;
  transition:border-color .25s ease;
}
.contact-form input::placeholder, .contact-form textarea::placeholder{ color:rgba(255,255,255,.3); }
.contact-form input:focus, .contact-form textarea:focus{
  outline:none; border-color:var(--gold);
}
.contact-form button{
  align-self:flex-start;
  background:var(--gold); color:var(--ink); border:none;
  font-family:var(--mono); font-size:13px; letter-spacing:.08em; text-transform:uppercase;
  padding:14px 30px; border-radius:30px; cursor:pointer;
  transition:transform .2s ease, background .2s ease;
}
.contact-form button:hover{ background:#EFC25C; transform:translateY(-1px); }
.contact-form .form-note{ margin:0; font-size:12.5px; color:rgba(255,255,255,.45); }

@media (max-width:640px){
  .contact-form .field-row{ grid-template-columns:1fr; gap:24px; }
}

/* ---------- OPERE — black opening + scroll cue + scatter-in tiles ---------- */
.opere-hero{ background:var(--bg-dark); min-height:80vh; display:flex; align-items:center; justify-content:center; padding:0; }
.opere-hero .wrap{ display:none; }

.opere-scroll-cue{
  position:fixed; top:100px; left:50%; transform:translate(-50%,0);
  z-index:250;
  font-family:var(--mono); font-weight:700; font-size:clamp(40px,8vw,76px); letter-spacing:.18em; text-transform:uppercase;
  color:var(--bg); opacity:.9;
  transition:opacity .5s ease, transform .6s cubic-bezier(.6,0,.4,1);
  pointer-events:none;
}
.opere-scroll-cue.gone{ opacity:0; transform:translate(-50%,0) translateX(-320px); }

.tile{
  opacity:0;
  transform:translate(var(--sx,0), var(--sy,0)) rotate(var(--rot,0deg)) scale(.9);
  transition:transform .85s cubic-bezier(.2,.8,.2,1), opacity .6s ease;
  transition-delay:var(--delay,0ms);
}
.tile.in{ opacity:1; transform:translate(0,0) rotate(0deg) scale(1); }

/* ---------- TILE LIGHTBOX (opere page — shows image + description over blurred site) ---------- */
.tile-lightbox{
  position:fixed; inset:0; z-index:900;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,60px);
  opacity:0; pointer-events:none;
  transition:opacity .35s ease;
  /* blurred version of whatever is behind */
  backdrop-filter:blur(14px) brightness(0.45);
  -webkit-backdrop-filter:blur(14px) brightness(0.45);
  background:rgba(11,11,12,0.55);
}
.tile-lightbox.open{ opacity:1; pointer-events:auto; }

.tile-lb-close{
  position:absolute; top:22px; left:28px;
  background:none; border:none; color:#fff; cursor:pointer;
  font-family:var(--mono); font-size:20px; opacity:.75; line-height:1;
  padding:8px; z-index:10;
  transition:opacity .2s ease;
}
.tile-lb-close:hover{ opacity:1; }

.tile-lb-inner{
  display:flex; flex-direction:column; align-items:center; gap:28px;
  max-width:720px; width:100%;
  transform:translateY(18px);
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.tile-lightbox.open .tile-lb-inner{ transform:translateY(0); }

.tile-lb-img{
  width:100%; aspect-ratio:16/9;
  border-radius:6px; overflow:hidden;
  background:#1a1a1a;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 24px 70px rgba(0,0,0,.6);
}
.tile-lb-img img{ width:100%; height:100%; object-fit:cover; display:block; }
/* Placeholder colour swatch when no image is set */
.tile-lb-img.swatch{ border-radius:6px; }

.tile-lb-info{
  width:100%; text-align:left;
}
.tile-lb-tag{
  display:inline-block;
  font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px;
}
.tile-lb-title{
  font-family:var(--head); font-weight:800; font-size:clamp(22px,4vw,34px);
  color:#fff; margin:0 0 10px; letter-spacing:-0.01em;
}
.tile-lb-desc{
  font-family:var(--body); font-size:15.5px; line-height:1.7;
  color:rgba(255,255,255,.7); margin:0;
}

@media (max-width:600px){
  .tile-lb-close{ top:14px; left:14px; }
  .tile-lb-inner{ gap:18px; }
}

.zoomable{ cursor:zoom-in; }
.lightbox{
  position:fixed; inset:0; z-index:1000;
  background:rgba(6,6,7,0.95);
  display:flex; align-items:center; justify-content:center;
  padding:30px;
  opacity:0; pointer-events:none;
  transition:opacity .3s ease;
}
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox-inner{ max-width:92vw; max-height:88vh; display:flex; }
.lightbox-inner img, .lightbox-inner video{
  max-width:92vw; max-height:88vh; width:auto; height:auto; display:block;
  border-radius:2px; box-shadow:0 30px 90px rgba(0,0,0,.55);
}
.lightbox-close{
  position:absolute; top:24px; right:28px;
  background:none; border:none; color:#fff; cursor:pointer;
  font-family:var(--mono); font-size:22px; opacity:.8; line-height:1;
  padding:8px;
}
.lightbox-close:hover{ opacity:1; }

