
:root{
  --bg:#050505;
  --text:#f4f0e8;
  --muted:#aaa39a;
  --line:rgba(255,255,255,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.nav{
  position:fixed;
  z-index:50;
  top:0;left:0;right:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:26px clamp(20px,4vw,58px);
  color:#fff;
  mix-blend-mode:difference;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
}
.nav nav{display:flex;gap:28px}
.logo{font-size:14px;letter-spacing:.12em}

.hero{
  min-height:100svh;
  position:relative;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:#111;
}
.hero img{position:absolute;inset:0}
.hero-vignette{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.44) 34%,rgba(0,0,0,.10) 100%),
    linear-gradient(180deg,rgba(0,0,0,.04) 0%,rgba(0,0,0,.72) 100%);
}
.hero-copy{
  position:relative;
  z-index:2;
  padding:0 clamp(26px,7vw,140px) clamp(58px,8vw,112px);
  max-width:980px;
}
span{
  display:block;
  color:var(--muted);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.hero-copy span{color:#e4ded3}
.hero-copy h1{
  font-size:clamp(54px,8vw,124px);
  line-height:.88;
  letter-spacing:-.075em;
  font-weight:500;
  margin:0 0 24px;
}
.hero-copy p{
  font-size:clamp(17px,1.5vw,24px);
  margin:0 0 44px;
  color:rgba(244,240,232,.78);
}
.hero-copy a,.contact-section a,.text-link,.reel-note a{
  display:inline-block;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(244,240,232,.85);
  padding-bottom:10px;
}
p{
  font-size:15px;
  line-height:1.65;
  color:rgba(244,240,232,.72);
}
h1,h2,h3{font-weight:300;margin:0}
h2{font-size:clamp(26px,4vw,54px);line-height:1.06}
h3{font-size:clamp(19px,2vw,30px);line-height:1.08}

.reel-section,.work-section,.contact-section,.project-video{
  padding:clamp(70px,10vw,130px) clamp(22px,6vw,90px);
  border-top:1px solid var(--line);
}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:30px;
  margin-bottom:34px;
}
.section-head h2{max-width:760px}
.reel-frame{
  aspect-ratio:16/9;
  width:100%;
  overflow:hidden;
  border:1px solid var(--line);
  background:#111;
}
.reel-frame iframe{width:100%;height:100%;border:0;display:block}
.reel-note{margin-top:18px}

.about-section{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:clamp(32px,6vw,92px);
  align-items:center;
  padding:clamp(70px,10vw,130px) clamp(22px,6vw,90px);
  border-top:1px solid var(--line);
}
.about-image{
  aspect-ratio:16/10;
  overflow:hidden;
  background:#111;
}
.about-copy h2{margin-bottom:26px}
.about-copy p{max-width:660px}

.project-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--line);
}
.project-card{
  position:relative;
  display:block;
  aspect-ratio:2.39/1;
  overflow:hidden;
  background:#111;
}
.project-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.77),rgba(0,0,0,0) 58%);
}
.project-card img{
  opacity:.9;
  transition:transform 1.05s cubic-bezier(.2,.8,.2,1), opacity .45s ease;
}
.project-card:hover img{transform:scale(1.035);opacity:1}
.card-copy{
  position:absolute;
  z-index:2;
  left:clamp(18px,3vw,42px);
  right:clamp(18px,3vw,42px);
  bottom:clamp(18px,3vw,42px);
}
.card-copy span{margin-bottom:10px;color:#d0c8bd}
.more-work{padding-top:0}

.contact-section h2{max-width:860px;margin-bottom:34px}
footer{
  display:flex;
  justify-content:space-between;
  padding:26px clamp(22px,6vw,90px);
  border-top:1px solid var(--line);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
footer p{font-size:11px;margin:0;color:var(--muted)}

.project-hero{
  position:relative;
  min-height:76svh;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:#111;
}
.project-hero img{position:absolute;inset:0}
.project-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.80),rgba(0,0,0,.05) 62%);
}
.project-title{
  position:relative;
  z-index:2;
  padding:0 clamp(22px,6vw,90px) clamp(46px,7vw,90px);
}
.project-title h1{
  font-size:clamp(38px,7vw,96px);
  line-height:.93;
  letter-spacing:-.05em;
}
.project-text{
  display:grid;
  grid-template-columns:.72fr 1.28fr;
  gap:42px;
  padding:clamp(60px,8vw,108px) clamp(22px,6vw,90px);
  border-top:1px solid var(--line);
}
.project-text h2{max-width:980px;margin-bottom:24px}
.video-placeholder{
  aspect-ratio:16/9;
  display:grid;
  place-items:center;
  background:#111;
  border:1px solid var(--line);
  color:var(--muted);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.gallery,.stills-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1px;
  background:var(--line);
}
.gallery a,.stills-grid a{
  display:block;
  position:relative;
  min-height:42vw;
  overflow:hidden;
  background:#111;
}
.gallery img,.stills-grid img{transition:transform 1s ease}
.gallery a:hover img,.stills-grid a:hover img{transform:scale(1.025)}
.stills-grid span{
  position:absolute;
  left:22px;
  bottom:18px;
  z-index:2;
  color:#fff;
  text-shadow:0 1px 16px rgba(0,0,0,.7);
}
.stills-intro{
  padding:150px clamp(22px,6vw,90px) 70px;
}
.stills-intro h1{
  font-size:clamp(40px,7vw,92px);
  letter-spacing:-.06em;
}

@media(max-width:820px){
  .nav{padding:18px 18px;font-size:10px}
  .nav nav{gap:14px}
  .hero-copy h1{font-size:clamp(46px,15vw,72px)}
  .section-head{display:block}
  .about-section,.project-text,.project-grid,.gallery,.stills-grid{grid-template-columns:1fr}
  .project-card{aspect-ratio:16/9}
  .gallery a,.stills-grid a{min-height:58vw}
  footer{display:block}
  footer p + p{margin-top:8px}
}


/* v2 cleanup: smaller, cleaner type and corrected Vimeo-friendly embed sizing */
.hero-copy h1{
  font-size:clamp(42px,6.2vw,88px) !important;
  line-height:.94 !important;
  letter-spacing:-.055em !important;
  font-weight:460 !important;
}
.hero-copy p{
  font-size:clamp(15px,1.2vw,19px) !important;
}
h2{
  font-size:clamp(22px,3vw,40px) !important;
}
.project-title h1{
  font-size:clamp(32px,5.4vw,72px) !important;
}
.card-copy h3{
  font-size:clamp(17px,1.7vw,25px) !important;
}
.section-head h2{
  font-size:clamp(22px,2.8vw,38px) !important;
}
.about-copy h2,
.contact-section h2{
  font-size:clamp(24px,3.2vw,42px) !important;
}
span{
  font-size:9.5px !important;
  letter-spacing:.26em !important;
}
.reel-frame iframe{
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
}
@media(max-width:820px){
  .hero-copy h1{
    font-size:clamp(38px,12vw,58px) !important;
  }
}


/* About page + clickable homepage about image */
.about-image-link{
  display:block;
  transition:opacity .35s ease, transform .7s ease;
}
.about-image-link:hover{
  opacity:.88;
  transform:scale(.992);
}
.about-more-link{
  display:inline-block;
  margin-top:18px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(244,240,232,.85);
  padding-bottom:10px;
}
.about-page-hero{
  min-height:78svh;
  position:relative;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:#111;
}
.about-page-hero img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.about-page-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.20)),
    linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.78));
}
.about-page-title{
  position:relative;
  z-index:2;
  padding:0 clamp(22px,6vw,90px) clamp(48px,7vw,90px);
}
.about-page-title h1{
  font-size:clamp(42px,7vw,92px);
  line-height:.95;
  letter-spacing:-.055em;
  margin:0 0 18px;
  font-weight:420;
}
.about-page-title p{
  font-size:clamp(15px,1.4vw,21px);
  color:rgba(244,240,232,.76);
}
.about-page-copy{
  display:grid;
  grid-template-columns:.72fr 1.28fr;
  gap:42px;
  padding:clamp(64px,9vw,120px) clamp(22px,6vw,90px);
  border-top:1px solid var(--line);
}
.about-page-copy h2{
  font-size:clamp(25px,3.5vw,46px) !important;
  line-height:1.08;
  margin-bottom:28px;
}
.about-page-copy p{
  max-width:850px;
}
.about-page-experience{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:42px;
  padding:clamp(50px,7vw,90px) clamp(22px,6vw,90px);
  border-top:1px solid var(--line);
}
.about-page-experience h2{
  font-size:clamp(24px,3.2vw,42px) !important;
}
.about-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--line);
}
.about-gallery a{
  display:block;
  aspect-ratio:4/5;
  overflow:hidden;
  background:#111;
}
.about-gallery img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1s ease;
}
.about-gallery a:hover img{
  transform:scale(1.025);
}
@media(max-width:900px){
  .about-page-copy,
  .about-page-experience,
  .about-gallery{
    grid-template-columns:1fr;
  }
  .about-gallery a{
    aspect-ratio:16/11;
  }
}


/* v7 About page: masonry-style original image ratios + click-to-enlarge lightbox */
.masonry-gallery{
  display:block !important;
  columns:3 320px;
  column-gap:14px;
  padding:14px;
  background:#050505;
  border-top:1px solid var(--line);
}
.masonry-gallery a{
  display:block;
  break-inside:avoid;
  margin:0 0 14px;
  background:#111;
  overflow:hidden;
  aspect-ratio:auto !important;
  min-height:0 !important;
}
.masonry-gallery img{
  width:100%;
  height:auto !important;
  object-fit:contain !important;
  display:block;
  transition:transform .8s ease, opacity .35s ease;
}
.masonry-gallery a:hover img{
  transform:scale(1.015);
  opacity:.9;
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:clamp(20px,4vw,70px);
  background:rgba(0,0,0,.92);
}
.lightbox:target{
  display:flex;
}
.lightbox img{
  width:auto;
  height:auto;
  max-width:94vw;
  max-height:90vh;
  object-fit:contain;
  box-shadow:0 20px 80px rgba(0,0,0,.65);
}
.lightbox-close{
  position:absolute;
  inset:0;
  cursor:zoom-out;
}
.lightbox-close:after{
  content:"×";
  position:absolute;
  top:22px;
  right:32px;
  color:#fff;
  font-size:38px;
  line-height:1;
  font-weight:200;
  opacity:.8;
}
@media(max-width:760px){
  .masonry-gallery{
    columns:1;
    padding:10px;
  }
}


/* v9 Photography page */
.photography-intro p{
  max-width:720px;
  margin-top:18px;
}
.photography-gallery{
  display:block !important;
  columns:3 320px;
  column-gap:14px;
  padding:14px;
  background:#050505;
  border-top:1px solid var(--line);
}
.photography-gallery a{
  display:block;
  break-inside:avoid;
  margin:0 0 14px;
  background:#111;
  overflow:hidden;
  min-height:0 !important;
}
.photography-gallery img{
  width:100%;
  height:auto !important;
  object-fit:contain !important;
  display:block;
  transition:transform .8s ease, opacity .35s ease;
}
.photography-gallery a:hover img{
  transform:scale(1.015);
  opacity:.9;
}
@media(max-width:760px){
  .photography-gallery{
    columns:1;
    padding:10px;
  }
}


/* v10 About side image + no-new-window lightbox with arrows */
.about-page-copy-with-image{
  grid-template-columns:.85fr 1.15fr !important;
  align-items:start;
}
.about-copy-side-image{
  width:100%;
  overflow:hidden;
  background:#111;
}
.about-copy-side-image img{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
}
.lightbox-thumb{
  display:block;
  width:100%;
  padding:0;
  border:0;
  background:#111;
  cursor:zoom-in;
  break-inside:avoid;
  margin:0 0 14px;
  overflow:hidden;
}
.lightbox-thumb img{
  width:100%;
  height:auto !important;
  display:block;
  object-fit:contain !important;
  transition:transform .8s ease, opacity .35s ease;
}
.lightbox-thumb:hover img{
  transform:scale(1.015);
  opacity:.9;
}
.modal-open{
  overflow:hidden;
}
.modal-lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:clamp(18px,4vw,68px);
  background:rgba(0,0,0,.94);
}
.modal-lightbox.is-open{
  display:flex;
}
.modal-lightbox img{
  max-width:92vw;
  max-height:88vh;
  width:auto;
  height:auto;
  object-fit:contain;
  box-shadow:0 20px 90px rgba(0,0,0,.65);
}
.modal-close,
.modal-arrow{
  position:absolute;
  z-index:10000;
  border:0;
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
  font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  transition:background .25s ease, opacity .25s ease;
}
.modal-close:hover,
.modal-arrow:hover{
  background:rgba(255,255,255,.18);
}
.modal-close{
  top:22px;
  right:28px;
  width:46px;
  height:46px;
  border-radius:999px;
  font-size:34px;
  line-height:42px;
  font-weight:200;
}
.modal-arrow{
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:70px;
  border-radius:999px;
  font-size:56px;
  line-height:54px;
  font-weight:200;
}
.modal-prev{left:24px}
.modal-next{right:24px}
@media(max-width:900px){
  .about-page-copy-with-image{
    grid-template-columns:1fr !important;
  }
  .modal-arrow{
    width:44px;
    height:58px;
    font-size:44px;
  }
  .modal-prev{left:10px}
  .modal-next{right:10px}
  .modal-close{top:12px;right:12px}
}


/* v11 cleanup: no white borders, clean lift on click/hover, stronger lightbox nav */
.lightbox-thumb,
.lightbox-thumb:focus,
.lightbox-thumb:active{
  appearance:none !important;
  -webkit-appearance:none !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}
.lightbox-thumb{
  position:relative;
  cursor:zoom-in;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.lightbox-thumb:hover{
  transform:translateY(-6px);
}
.lightbox-thumb:active{
  transform:translateY(-2px);
}
.lightbox-thumb img{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}
.modal-lightbox{
  background:rgba(0,0,0,.96) !important;
}
.modal-lightbox img{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}
.modal-close,
.modal-arrow,
.modal-close:focus,
.modal-arrow:focus,
.modal-close:active,
.modal-arrow:active{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.modal-arrow{
  background:rgba(0,0,0,.18) !important;
}
.modal-arrow:hover{
  background:rgba(255,255,255,.12) !important;
}
.photography-gallery,
.about-gallery,
.masonry-gallery{
  background:#050505 !important;
}


/* v12 Project pages: image lift + modal lightbox with arrow navigation */
.project-gallery{
  display:block !important;
  columns:3 320px;
  column-gap:14px;
  padding:14px;
  background:#050505 !important;
  border-top:1px solid var(--line);
}
.project-gallery .lightbox-thumb{
  display:block;
  width:100%;
  margin:0 0 14px;
  padding:0;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  cursor:zoom-in;
  break-inside:avoid;
  overflow:hidden;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.project-gallery .lightbox-thumb:hover{
  transform:translateY(-6px);
}
.project-gallery .lightbox-thumb:active{
  transform:translateY(-2px);
}
.project-gallery .lightbox-thumb img{
  width:100%;
  height:auto !important;
  display:block;
  object-fit:contain !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}
@media(max-width:760px){
  .project-gallery{
    columns:1;
    padding:10px;
  }
}

.video-embed{
  width:100%;
  max-width:1400px;
  margin:40px auto;
  padding:0 20px;
}
.video-embed iframe{
  aspect-ratio:16/9;
  height:auto;
}


/* v15 Canta Santiago restored poster layout */
.project-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);
  gap:clamp(28px,5vw,72px);
  align-items:start;
}
.project-poster img{
  width:100%;
  max-width:440px;
  height:auto;
  display:block;
  margin-left:auto;
  box-shadow:none;
  border:0;
}
.video-embed{
  width:100%;
  max-width:1400px;
  margin:40px auto;
  padding:0 20px;
}
.video-embed iframe{
  width:100%;
  aspect-ratio:16/9;
  height:auto;
  border:0;
}
@media(max-width:900px){
  .project-hero-grid{
    grid-template-columns:1fr;
  }
  .project-poster img{
    margin:0;
    max-width:360px;
  }
}

.project-meta-list{
  list-style:none;
  padding:0;
  margin:24px 0 0;
  display:grid;
  gap:10px;
  color:var(--muted);
  font-size:clamp(14px,1.1vw,16px);
  line-height:1.5;
}
.project-meta-list strong{
  color:var(--text);
  font-weight:500;
  margin-right:10px;
}


/* v24 Canta Santiago correction */
.project-hero-clean{
  display:block !important;
}
.canta-poster-bottom{
  max-width:1400px;
  margin:48px auto 20px;
  padding:0 20px;
  display:flex;
  justify-content:flex-end;
}
.canta-poster-bottom-inner{
  width:min(360px, 42vw);
}
.canta-poster-bottom img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
@media(max-width:800px){
  .canta-poster-bottom{
    justify-content:flex-start;
  }
  .canta-poster-bottom-inner{
    width:min(320px, 90vw);
  }
}


/* v25 Canta Santiago: 2 columns of 3 stills + poster on right */
.canta-feature-layout{
  max-width:1500px;
  margin:clamp(40px,6vw,80px) auto;
  padding:0 clamp(18px,4vw,48px);
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(280px,.86fr);
  gap:clamp(14px,2vw,28px);
  align-items:stretch;
}
.canta-still-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:repeat(3,1fr);
  gap:clamp(10px,1.4vw,18px);
}
.canta-feature-layout .lightbox-thumb{
  margin:0 !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  cursor:zoom-in;
  overflow:hidden;
  display:block;
  width:100%;
  padding:0;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.canta-feature-layout .lightbox-thumb:hover{
  transform:translateY(-6px);
}
.canta-feature-layout .lightbox-thumb:active{
  transform:translateY(-2px);
}
.canta-still-grid .lightbox-thumb{
  aspect-ratio:2.39/1;
}
.canta-feature-layout img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.canta-poster-column{
  display:flex;
  align-items:stretch;
}
.canta-poster-column .canta-poster-button{
  height:100%;
}
.canta-poster-column img{
  object-fit:contain;
  background:#050505;
}
@media(max-width:900px){
  .canta-feature-layout{
    grid-template-columns:1fr;
  }
  .canta-still-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
  .canta-still-grid .lightbox-thumb{
    aspect-ratio:2.39/1;
  }
  .canta-poster-column{
    max-width:420px;
  }
}


/* v28 Canta Santiago: poster left of text, 6 stills below */
.canta-info-with-poster{
  grid-template-columns:minmax(240px,.72fr) minmax(0,1.28fr) !important;
  align-items:start;
  gap:clamp(28px,5vw,70px) !important;
}
.canta-info-poster img{
  display:block;
  width:100%;
  max-width:420px;
  height:auto;
  object-fit:contain;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.canta-stills-only{
  grid-template-columns:1fr !important;
  max-width:1150px !important;
}
.canta-stills-only .canta-still-grid{
  width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:repeat(3,1fr);
  gap:clamp(10px,1.4vw,18px);
}
@media(max-width:900px){
  .canta-info-with-poster{
    grid-template-columns:1fr !important;
  }
  .canta-info-poster img{
    max-width:360px;
  }
  .canta-stills-only .canta-still-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
}


/* v30 poster-left layouts: Cruda + Blunose */
.cruda-info-with-poster,
.blunose-info-with-poster{
  display:grid !important;
  grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr) !important;
  gap:clamp(28px,5vw,70px) !important;
  align-items:start !important;
}
.cruda-info-poster img,
.blunose-info-poster img{
  display:block;
  width:100%;
  max-width:420px;
  height:auto;
  object-fit:contain;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.cruda-gallery,
.blunose-gallery{
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto;
  padding:0 clamp(18px,4vw,48px);
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:clamp(10px,1.4vw,18px) !important;
}
.cruda-gallery .lightbox-thumb,
.blunose-gallery .lightbox-thumb{
  margin:0 !important;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
}
.cruda-gallery img,
.blunose-gallery img{
  width:100%;
  height:auto;
  display:block;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
@media(max-width:900px){
  .cruda-info-with-poster,
  .blunose-info-with-poster{
    grid-template-columns:1fr !important;
  }
  .cruda-info-poster img,
  .blunose-info-poster img{
    max-width:360px;
  }
  .cruda-gallery,
  .blunose-gallery{
    grid-template-columns:1fr !important;
  }
}


/* v32 Cruda corrected: poster left of words, frames below */
.cruda-info-with-poster{
  display:grid !important;
  grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr) !important;
  gap:clamp(28px,5vw,70px) !important;
  align-items:start !important;
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto;
  padding:0 clamp(18px,4vw,48px);
}
.cruda-info-poster img{
  display:block;
  width:100%;
  max-width:420px;
  height:auto;
  object-fit:contain;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.cruda-gallery{
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto !important;
  padding:0 clamp(18px,4vw,48px);
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:clamp(10px,1.4vw,18px) !important;
}
.cruda-gallery .lightbox-thumb{
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
  cursor:zoom-in;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.cruda-gallery .lightbox-thumb:hover{
  transform:translateY(-6px);
}
.cruda-gallery img{
  width:100%;
  height:auto;
  display:block;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
@media(max-width:900px){
  .cruda-info-with-poster{
    grid-template-columns:1fr !important;
  }
  .cruda-info-poster img{
    max-width:360px;
  }
  .cruda-gallery{
    grid-template-columns:1fr !important;
  }
}


/* v35 Uno y Medio poster-left layout */
.uno-y-medio-info-with-poster{
  display:grid !important;
  grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr) !important;
  gap:clamp(28px,5vw,70px) !important;
  align-items:start !important;
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto;
  padding:0 clamp(18px,4vw,48px);
}
.uno-y-medio-info-poster img{
  display:block;
  width:100%;
  max-width:420px;
  height:auto;
  object-fit:contain;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.uno-y-medio-gallery{
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto !important;
  padding:0 clamp(18px,4vw,48px);
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:clamp(10px,1.4vw,18px) !important;
}
.uno-y-medio-gallery .lightbox-thumb{
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
  cursor:zoom-in;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.uno-y-medio-gallery .lightbox-thumb:hover{
  transform:translateY(-6px);
}
.uno-y-medio-gallery img{
  width:100%;
  height:auto;
  display:block;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
@media(max-width:900px){
  .uno-y-medio-info-with-poster{
    grid-template-columns:1fr !important;
  }
  .uno-y-medio-info-poster img{
    max-width:360px;
  }
  .uno-y-medio-gallery{
    grid-template-columns:1fr !important;
  }
}


/* v40 Last One Out correction */
.lastoneout-gallery{
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto !important;
  padding:0 clamp(18px,4vw,48px);
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:clamp(10px,1.4vw,18px) !important;
}
.lastoneout-gallery .lightbox-thumb{
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
  cursor:zoom-in;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.lastoneout-gallery .lightbox-thumb:hover{
  transform:translateY(-6px);
}
.lastoneout-gallery img{
  width:100%;
  height:auto;
  display:block;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
@media(max-width:900px){
  .lastoneout-gallery{
    grid-template-columns:1fr !important;
  }
}


/* v41 Last One Out menu/header safety fix */
.site-header,
.nav{
  z-index:1000;
}
.projects-page .site-header,
.project-page .site-header{
  width:100%;
}


/* v45 mobile-only hero image adjustments */

/* Homepage hero image: shift slightly left so face stays visible */
@media (max-width: 768px){
  .hero-image img,
  .home-hero img,
  .hero img{
    object-position: 42% center !important;
  }
}

/* Canta Santiago hero image: shift slightly left on mobile only */
@media (max-width: 768px){
  .project-hero img,
  .canta-santiago .project-hero img{
    object-position: 40% center !important;
  }
}


/* v46 mobile-only correction: shift the crop the opposite direction */
@media (max-width: 768px){
  .hero-image img,
  .home-hero img,
  .hero img{
    object-position: 58% center !important;
  }

  .project-hero img,
  .canta-santiago .project-hero img{
    object-position: 60% center !important;
  }
}


/* v47: move Canta Santiago hero 10% more on mobile */
@media (max-width: 768px){
  .project-hero img,
  .canta-santiago .project-hero img{
    object-position: 70% center !important;
  }
}


/* v48: Shallow End hero shift 15% same direction on mobile */
@media (max-width: 768px){
  .shallow-end .project-hero img,
  .project-shallow-end .project-hero img{
    object-position: 75% center !important;
  }
}


/* v51 Diary of an African Model gallery */
.diary-gallery{
  max-width:1200px;
  margin:clamp(40px,6vw,80px) auto !important;
  padding:0 clamp(18px,4vw,48px);
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:clamp(10px,1.4vw,18px) !important;
}
.diary-gallery .lightbox-thumb{
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  outline:0 !important;
  background:transparent !important;
  cursor:zoom-in;
  transform:translateY(0);
  transition:transform .28s ease, opacity .28s ease;
}
.diary-gallery .lightbox-thumb:hover{
  transform:translateY(-6px);
}
.diary-gallery img{
  width:100%;
  height:auto;
  display:block;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
@media(max-width:900px){
  .diary-gallery{
    grid-template-columns:1fr !important;
  }
}


/* v54 About page typography refinement */
.about-intro h2,
.about-copy h2,
.about-content h2{
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: 1.35 !important;
  max-width: 900px;
}

.about-intro .lead,
.about-copy .lead,
.about-content .lead{
  font-size: clamp(18px, 1.5vw, 22px) !important;
  line-height: 1.5 !important;
}


/* v55 mobile-only Last One Out hero crop adjustment */
@media (max-width: 768px){
  .last-one-out-get-the-lights .project-hero img,
  .project-last-one-out-get-the-lights .project-hero img{
    object-position: 30% center !important;
  }
  .selected-recognition{
    grid-template-columns: 1fr;
    gap: 18px;
  }
}
