/* Neue Haas Grotesk Display Pro */
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayXXThin.ttf') format('truetype');
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayXXThinItalic.ttf') format('truetype');
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayXThin.ttf') format('truetype');
  font-weight: 200;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayXThinItalic.ttf') format('truetype');
  font-weight: 200;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayThin.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayThinItalic.ttf') format('truetype');
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayLight.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayLightItalic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayRoman.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayRomanItalic.ttf') format('truetype');
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayMediu.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayMediumItalic.ttf') format('truetype');
  font-weight: 600;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayBold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayBoldItalic.ttf') format('truetype');
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayBlack.ttf') format('truetype');
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: 'NeueHaasDisplay';
  src: url('../fonts/NeueHaasDisplayBlackItalic.ttf') format('truetype');
  font-weight: 900;
  font-style: italic;
}

/* Fixed navbar — shared across all pages */
#wrapper .navbar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  z-index: 200 !important;
  background: #fff !important;
}

/* Editors page — hide the navbar bunny (separate anchored bunny used instead) */
#wrapper.directors-page .logo-cat { display: none !important; }
#wrapper .navbar .container-xxl {
  padding-left: 48px !important;
  padding-right: 24px !important;
  max-width: 100% !important;
  align-items: center !important;
}
#wrapper .navbar-brand {
  width: 250px !important;
  min-width: 250px !important;
}
#wrapper .btn-contact { display: none !important; }
.bg-black .navbar { background: #000 !important; }

/* Offset page content below fixed navbar */
#main { padding-top: 160px; }

/* Logo live text */
.navbar-brand {
  width: auto !important;
  min-width: 0 !important;
}
.logo-text {
  
  text-transform: uppercase;
  color: #000;
   font-family: 'NeueHaasDisplay', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-size: 28px;
    font-weight: 800;
  
    letter-spacing: 0.02em;
    -moz-osx-font-smoothing: grayscale;
    transform: translateZ(0);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  
}




.bg-black .logo-text,
[data-bs-theme="dark"] .logo-text {
  color: #fff;
}

.list-player a.active,
.list-player a:focus,
.list-player a:hover {
  font-weight: normal
}
.btn-contact{
	color:#000;
}
.featured_work h3{
	font-family: "source_serif_pro" !important;
	font-size: 28px !important;
}
.featured_work p{
	font-size:18px !important;
}
.featured_work .readmore{
	font-weight: 700;
border: 1px solid #000;
padding: 5px 10px;
border-radius: 30px;
font-size: 12px;
}
.js-video-thumb .mejs-player::after {
  visibility: hidden;
}
.mejs-player.ready .mejs__overlay-poster img {
  opacity: unset;
}
/*
.video-thumbnails-row .mejs-player:after {
    opacity: 1;
  visibility: visible;
}*/
.video-thumbnails-row .mejs-player.hover:after {
    opacity: 0;
}
@media (min-width: 1400px) {
  .homepage .hero-video {
    padding-top: 113px;
  }
}

.video-title .title-video {
  font-size: .8125rem;
}
@media (min-width:480px) {
  .video-title .title-video {
    font-size: .9375rem
  }
}
@media (min-width:768px) {
  .video-title .title-video {
    font-size: 1rem
  }
}
@media (min-width:992px) {
  .video-title .title-video {
    font-size: 18px
  }
}
@media (min-width:1280px) {
  .video-title .title-video {
    font-size: 18px
  }
}
@media (min-width:1400px) {
  .video-title .title-video {
    font-size: 18px
  }
}

.js-video-title .title-video {
  font-size: .8125rem;
}
@media (min-width:480px) {
  .js-video-title .title-video {
    font-size: .9375rem
  }
}
@media (min-width:768px) {
  .js-video-title .title-video {
    font-size: 1rem
  }
}
@media (min-width:992px) {
  .js-video-title .title-video {
    font-size: 18px
  }
}
@media (min-width:1280px) {
  .js-video-title .title-video {
    font-size: 18px
  }
}
@media (min-width:1400px) {
  .js-video-title .title-video {
    font-size: 18px
  }
}
.video-box iframe,
.video-box img,
.video-box video {
  top: 0!important;
  left: 0!important;
  width: 100%!important;
  height: 100%!important;
}
.mejs-player.ready .js-video-short-player img{
	display:none !important;
}
.forMobile{
	display:none;
}
@media (max-width:768px) {
	.forMobile{
		display:block;
	}
	.forDesktop{
		display:block;
	}
}

/* ── Homepage layout ── */
#wrapper.homepage .hero-video { display: none !important; }

#main .homepage-content {
  display: flex !important;
  flex-direction: row !important;
  padding: 24px 24px 40px 48px;
  align-items: flex-start;
  width: 100%;
  box-sizing: border-box;
}

#main .home-sidebar {
  width: 190px;
  flex-shrink: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between;
  align-self: stretch;
}

#main .directors-list {
  display: flex !important;
  flex-direction: column !important;
  list-style: none;
  margin: 0;
  padding: 0;
}

#main .directors-list a {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
  font-size: 18px;
  font-weight: 400 !important;
  color: #000 !important;
  line-height: 1.6;
  text-decoration: none !important;
  display: block;
}

#main .directors-list a:hover,
#main .directors-list a.active {
  font-weight: 700 !important;
}

#main .home-bottom-links {
  padding-top: 48px;
  display: flex !important;
  flex-direction: column !important;
}

#main .home-bottom-links a {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.03em;
  color: #000 !important;
  line-height: 1.75;
  text-decoration: none !important;
  display: block;
}

#main .home-bottom-links a:hover { font-weight: 700; }

#main .home-image-area {
  flex: 1 !important;
  min-width: 0;
  position: relative;
}

#main .home-video-box {
  display: none;
  width: 100%;
  aspect-ratio: 16 / 9;
  max-height: 75vh;
  position: relative;
  overflow: hidden;
}

#main .home-video-box.active {
  display: block;
}

.home-video-poster {
  display: block;
  width: 100%;
  height: auto;
  max-height: 75vh;
  object-fit: cover;
}

.home-vimeo-player {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.home-vimeo-player iframe {
  width: 100% !important;
  height: 100% !important;
}

.logo-cat { display: block; height: 60px; width: auto; margin-right: 0; }
#wrapper.homepage .logo-cat { margin-right: 100px; }

/* 20260218 */

.list-player li:last-child{
	padding-top: 0;
}
.hero-video {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  position: relative;
  align-items: flex-start;
  justify-content: start;
}
.hero-video .list-player.js-video-bg-list {
  display: block;
  /*column-gap: 6rem;*/
  margin: 0;
  column-count: 1;
  line-height: 1.2;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  padding-left: 0;
  padding-top:2rem;
}

.scroll-down {
  position: absolute;
  right: 5%;
  bottom: 4%;
  margin: 0;
  padding: 0;
  text-align: right;
}

.scroll-down .link-anchor {
  font-size: 2rem;
  color: #000;
  transition: transform 0.3s ease;
}

.scroll-down .link-anchor:hover {
  transform: translateY(6px);
}
/* stills page */
.stills-page .navbar {
  position: absolute;
  z-index: 99;
  left: 0;
  top: 0;
  width: 100%;
}
.stills-list {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  position: relative;
  align-items: flex-start;
  justify-content: start;
}
.stills-list .list-player.js-video-bg-list {
  display: block;
  /*column-gap: 6rem;*/
  margin: 0;
  column-count: 1;
  line-height: 1.2;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  padding-left: 0;
  padding-top:2rem;
}
.stills-list .js-video-bg-list .mejs__overlay-poster::after{
	backdrop-filter:none;
}
@media (min-width: 1400px) {
  .stills-list {
    padding-top: 113px;
  }
}

/* photographer page */
.photographer-single .page-header{
	padding: 0 0 30px;
}
.photographer-single .page-header h1{
	font-family: "source_serif_pro" !important;
  font-size: 20px;
  font-weight: 400;
}
/* Gallery Carousel */
.gallery-carousel {
  width: 100%;
  overflow: hidden;
}

.gallery-carousel .slide{
  padding:0 10px;
}

.slick-slide{
  opacity:.5;
  transition:opacity .4s ease, transform .4s ease;
}

.slick-center{
  opacity:1;
}

.gallery-item {
  width: 100%;
  height: 560px;      
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gallery-image {
  width: 100%;
  height: 100%;
  object-fit: cover;          
  object-position: center;
  transition: transform 0.7s ease;
}

.back-to-grid{
	padding: 50px 0px;
}
.back-to-grid img{
	width:35px;
}
/* Mobile adjustments */
@media (max-width: 991px) {
  .gallery-item {
    height: 420px;        
  }
}

/* Toggle Button */
.btn-toggle-view {
  background: none;
  border: none;
}

/* Views switching */
.view-carousel,
.view-grid {
  display: none;
}

.view-carousel.active,
.view-grid.active {
  display: block;
}

/* masonry container */
.masonry-gallery{
  column-count:3;
  column-gap:24px;
}

.masonry-item{
  break-inside:avoid;
  margin-bottom:24px;
  overflow:hidden;
}

/* random height options */

.h-sm{ height:200px; }
.h-md{ height:300px; }
.h-lg{ height:400px; }
.h-xl{ height:500px; }

.masonry-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .4s ease;
}

.masonry-item:hover img{
  transform:scale(1.05);
}

/* responsive */
@media (max-width:1200px){
  .masonry-gallery{ column-count:2; }
}

@media (max-width:768px){
  .masonry-gallery{ column-count:1; }
}

/* ── Lock all video containers to 16:9 ── */

/* Thumbnail containers (reels, director pages) */
.video-box,
.player-container,
.vimeo-thumb-wrap,
.featured-item {
  aspect-ratio: 16 / 9;
  height: auto;
}

/* Vimeo player init divs inside the player wrapper — fill their container */
.js-video-player > div[data-vimeoid] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* All iframes and native video elements inside video containers */
.video-box iframe,
.video-box video,
.player-container iframe,
.player-container video,
.vimeo-thumb-wrap iframe,
.home-video-box iframe,
.home-video-box video,
[data-vimeoid] iframe {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
}

/* ── Shared responsive navbar + logo breakpoints ── */
@media (max-width: 1200px) {
  #wrapper .navbar .container-xxl {
    padding-left: 28px !important;
  }
  #wrapper.homepage .logo-cat { margin-right: 40px; }
}

@media (max-width: 768px) {
  #wrapper .navbar .container-xxl {
    padding-left: 16px !important;
    padding-right: 16px !important;
    flex-direction: column !important;
    align-items: center !important;
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    gap: 8px !important;
  }
  #wrapper .navbar-brand {
    width: auto !important;
    min-width: 0 !important;
    margin: 0 !important;
  }
  .logo-text { font-size: 22px !important; }
  .logo-cat { height: 48px !important; }
}
