/* ── HOME PAGE — Hero + Category Cards + Work Preview ── */

/* ── HERO (Editorial White) ── */
.hero{
  position:relative;
  min-height:120vh;        /* taller hero = video visible longer */
  display:flex;
  align-items:center;
  justify-content:center;
  padding:var(--nav-h) 0 clamp(100px,12vw,180px);
  background:#000;
  /* clip-path keeps the fixed video clipped to hero bounds */
  clip-path:inset(0);
  -webkit-clip-path:inset(0);
  z-index:1;
}
.hero-video{
  position:fixed;
  top:0;
  left:0;
  width:100vw;
  height:100vh;
  object-fit:cover;
  z-index:0;
  filter:saturate(1.15) contrast(1.05);
}

/* Sections after hero scroll OVER the fixed video */
[data-page="home"] .marquee,
[data-page="home"] .section-light,
[data-page="home"] .clients-section,
[data-page="home"] .cta-eye{
  position:relative;
  z-index:2;
}
.hero-video::-webkit-media-controls{display:none!important}
.hero-video::-webkit-media-controls-start-playback-button{display:none!important}
.hero-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(to bottom,
    rgba(0,0,0,.15) 0%,
    rgba(0,0,0,.05) 40%,
    rgba(0,0,0,.1) 70%,
    rgba(0,0,0,.5) 100%
  );
}
/* ── 35mm Film Grain on Hero Video ── */
.hero::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.1;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:150px 150px;
  animation:grainShift 0.4s steps(3) infinite;
}
@keyframes grainShift{
  0%{transform:translate(0,0)}
  33%{transform:translate(-2px,1px)}
  66%{transform:translate(1px,-2px)}
  100%{transform:translate(0,0)}
}
.hero-content{position:relative;z-index:2}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:clamp(1.5rem,4vw,3rem);
  color:rgba(255,255,255,.7);
}
.hero-badge-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:var(--green);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.85)}
}

.hero-title{
  font-family:var(--sans);
  font-size:clamp(2.8rem,8vw,7rem);
  font-weight:200;
  line-height:.94;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--white);
  margin-bottom:clamp(2rem,4vw,3.5rem);
}
.hero-line{display:block}

.hero-highlight{
  display:inline-block;
  background:#C1574E;
  color:var(--white);
  padding:.05em .25em;
  border-radius:.08em;
  margin-left:.1em;
}
.hero-outline{
  -webkit-text-stroke:2px var(--white);
  color:transparent;
}

.hero-bottom{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:2rem;
}
.hero-tagline{
  max-width:480px;
  font-size:clamp(.95rem,1.2vw,1.1rem);
  color:rgba(255,255,255,.7);
  line-height:1.6;
}

.hero-scroll{
  position:absolute;
  bottom:clamp(30px,4vw,50px);
  right:clamp(20px,4vw,48px);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.6rem;
  font-family:var(--sans);
  font-size:.65rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.15em;
  color:rgba(255,255,255,.5);
  z-index:2;
}
.hero-scroll-line{
  width:1px;
  height:50px;
  background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);
  animation:scrollLine 1.8s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* ── ABOUT TEASER (Editorial Big Portrait) ── */
.about-teaser-editorial{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,3vw,3.5rem);
  align-items:center;
}
.about-teaser-left .editorial-title{
  font-size:clamp(1.8rem,4vw,3.2rem);
  margin-bottom:1.5rem;
}
.about-teaser-desc{
  font-size:clamp(.95rem,1.1vw,1.05rem);
  color:var(--text-body);
  line-height:1.75;
  margin-bottom:2rem;
  max-width:480px;
}
.about-teaser-portrait{
  border-radius:0;
  overflow:hidden;
}
.about-teaser-portrait img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  border-radius:0;
}

/* ── SERVICE MENU — Editorial List Layout ── */
.service-menu{
  border-top:1px solid rgba(232,228,223,.1);
}
.service-menu-item{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:clamp(1rem,2vw,2rem);
  padding:clamp(1.5rem,2.5vw,2.5rem) 0;
  border-bottom:1px solid rgba(232,228,223,.1);
  text-decoration:none;
  color:var(--text-body);
  position:relative;
  transition:all .4s var(--ease);
  cursor:pointer;
}
@media(hover:hover){
  .service-menu-item:hover{
    padding-left:clamp(.5rem,1vw,1rem);
  }
  .service-menu-item:hover .service-menu-title{
    color:var(--coral);
  }
  .service-menu-item:hover .service-menu-arrow{
    opacity:1;
    transform:translateX(4px);
    color:var(--coral);
  }
  /* Preview show/hide handled by JS (moved to body) */
}
.service-menu-num{
  font-family:var(--sans);
  font-size:.75rem;
  font-weight:300;
  letter-spacing:.1em;
  color:var(--text-muted);
  min-width:2rem;
}
.service-menu-text{
  min-width:0;
}
.service-menu-title{
  font-family:var(--sans);
  font-size:clamp(1.4rem,3vw,2.8rem);
  font-weight:300;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--white);
  line-height:1.2;
  transition:color .4s var(--ease);
}
.service-menu-desc{
  font-size:clamp(.8rem,.9vw,.9rem);
  color:var(--text-muted);
  margin-top:.3rem;
  line-height:1.5;
}
/* Thumbs — hidden on desktop, shown on mobile */
.service-menu-thumb{
  display:none;
}
.service-menu-thumb img,
.service-menu-thumb video{
  width:100%;
  height:100%;
  object-fit:cover;
}
.service-menu-arrow{
  width:clamp(18px,2vw,28px);
  height:clamp(18px,2vw,28px);
  opacity:.3;
  transition:all .4s var(--ease);
  flex-shrink:0;
  justify-self:end;
}
/* Desktop hover preview — big fixed image, viewport-clamped */
.service-menu-preview{
  position:fixed;
  top:50%;
  left:50%;
  transform:scale(.92);
  width:clamp(260px,20vw,380px);
  aspect-ratio:3/4;
  border-radius:0;
  overflow:hidden;
  pointer-events:none;
  z-index:9999;
  opacity:0;
  transition:opacity .4s var(--ease), transform .4s var(--ease), top .3s var(--ease);
  box-shadow:0 20px 60px rgba(0,0,0,.6);
}
.service-menu-preview img,
.service-menu-preview video{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

/* Coming Soon section */
.service-menu-soon{
  margin-top:clamp(2rem,3vw,3rem);
  padding-top:clamp(1rem,2vw,1.5rem);
}
.service-menu-item--soon{
  border-bottom:1px solid rgba(232,228,223,.05);
}
.service-menu-item--soon .service-menu-desc{
  opacity:.5;
  transition:opacity .4s var(--ease);
}
.service-menu-item--soon:hover .service-menu-desc{
  opacity:.7;
}
.service-menu-title-row{
  display:flex;
  align-items:baseline;
  gap:.5em;
  flex-wrap:wrap;
}
.coming-soon-badge{
  font-family:var(--sans);
  font-size:clamp(.5rem,.55vw,.55rem);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--coral);
  opacity:.6;
  white-space:nowrap;
  line-height:1;
}

/* Legacy — keep for courses page */
.coming-soon-banner{
  position:absolute;
  top:62%;
  left:50%;
  transform:translate(-50%,-50%) rotate(-16deg);
  font-family:var(--sans);
  font-size:clamp(1.6rem,3.5vw,2.5rem);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.15em;
  color:var(--coral);
  border:clamp(4px,.5vw,6px) solid var(--coral);
  border-radius:8px;
  padding:clamp(.5rem,1vw,.8rem) clamp(1.2rem,2.2vw,2rem);
  white-space:nowrap;
  z-index:2;
  pointer-events:none;
  line-height:1;
  opacity:.92;
  background:rgba(0,0,0,.4);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}
.coming-soon--overlay{
  position:absolute;
  top:12px;
  left:12px;
  z-index:2;
}
.work-blocks-row .work-block-media img{
  aspect-ratio:3/2;
  object-fit:cover;
}
.work-block{
  display:block;
  text-decoration:none;
  cursor:pointer;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  will-change:transform;
}
/* Image links — pointer and zoom */
.work-block a{cursor:pointer}

.work-block-title{
  font-family:var(--sans);
  font-size:clamp(.85rem,1.2vw,1.1rem);
  font-weight:600;
  line-height:1.1;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--terracotta);
  margin-bottom:clamp(.4rem,.5vw,.5rem);
  transition:opacity .3s var(--ease);
}
.work-block:hover .work-block-title{opacity:.7}
.work-block-media{
  border-radius:0;
  overflow:hidden;
}
.work-block-media img{
  width:100%;
  aspect-ratio:3/2;
  object-fit:cover;
  transition:transform .6s cubic-bezier(.19,1,.22,1), filter .6s cubic-bezier(.19,1,.22,1);
  border-radius:0;
}
.work-block:hover .work-block-media img{
  transform:scale(1.03);
  filter:brightness(1.05);
}
.work-block-media--split{
  display:grid;
  grid-template-columns:3fr 2fr;
  gap:clamp(6px,.8vw,12px);
}
.work-block-media--split img{
  aspect-ratio:auto;
  height:100%;
  min-height:180px;
}
.work-block-desc{
  font-size:clamp(.75rem,.8vw,.85rem);
  color:var(--text-body);
  margin-top:.4rem;
  line-height:1.5;
}

/* ── PORTRAIT WORK BLOCK ── */
.work-block--portrait .work-block-media img,
.work-block--portrait .work-block-media video{
  aspect-ratio:3/4;
  width:100%;
  object-fit:cover;
}

/* ── VIDEO WORK BLOCK ── */
.work-block-media video{
  width:100%;
  aspect-ratio:3/2;
  object-fit:cover;
  border-radius:0;
  transition:transform .6s cubic-bezier(.19,1,.22,1), filter .6s cubic-bezier(.19,1,.22,1);
}
.work-block:hover .work-block-media video{
  transform:scale(1.03);
  filter:brightness(1.05);
}
.work-block-media{position:relative}
/* ── SOUND TOGGLE BUTTON ── */
.work-block-sound{
  position:absolute;
  bottom:12px;right:12px;
  width:36px;height:36px;
  border-radius:50%;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1.5px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all .3s var(--ease);
  z-index:2;
  color:#fff;
}
.work-block-sound svg{
  width:18px;height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:2;
}
.work-block-sound:hover{
  background:rgba(0,0,0,.75);
  transform:scale(1.1);
}
.work-block-sound .icon-unmuted{display:none}
.work-block-sound.unmuted .icon-muted{display:none}
.work-block-sound.unmuted .icon-unmuted{display:block}

/* ── CLIENT LOGOS MARQUEE ── */
.clients-section{
  padding-bottom:clamp(1rem,2vw,2rem);
}
.clients-section .section-title{
  margin-bottom:clamp(2.5rem,4vw,4rem);
}
.clients-marquee{
  position:relative;
  width:100%;
  overflow:clip visible;
  overflow-x:clip;
  padding:clamp(12px,2vw,24px) 0;
  mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}
.clients-track{
  display:flex;
  align-items:center;
  gap:clamp(3rem,5vw,5rem);
  width:max-content;
  animation:clientsScroll 35s linear infinite;
}
.clients-track img{
  height:clamp(50px,7vw,85px);
  width:auto;
  max-width:220px;
  object-fit:contain;
  filter:grayscale(1) opacity(.5) invert(1) brightness(1.2);
  mix-blend-mode:screen;
  transition:filter .4s var(--ease), transform .4s var(--ease);
  flex-shrink:0;
}
.clients-track img:hover{
  filter:grayscale(1) invert(1) brightness(2) opacity(1);
  transform:scale(1.15);
}
.clients-track img.logo-sm{
  height:clamp(35px,5vw,60px);
  max-width:160px;
}
@keyframes clientsScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ── WORK PREVIEW ── */
.work-preview-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(12px,1.5vw,20px);
}

/* ── CTA EYE ── */
.cta-eye{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(50px,8vw,120px) var(--gutter) clamp(60px,8vw,120px);
  background:var(--cream);
}
.cta-eye-link{
  display:flex;
  align-items:center;
  gap:clamp(2rem,4vw,4rem);
  text-decoration:none;
  cursor:pointer;
}
.cta-eye-video-wrap{
  width:clamp(160px,18vw,260px);
  aspect-ratio:16/9;
  border-radius:clamp(12px,1.5vw,20px);
  overflow:hidden;
  flex-shrink:0;
}
.cta-eye-video-wrap video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
  transition:transform .6s var(--ease);
}
.cta-eye-link:hover .cta-eye-video-wrap video{
  transform:scale(1.03);
}
.cta-eye-video-wrap video::-webkit-media-controls{display:none!important}
.cta-eye-video-wrap video::-webkit-media-controls-start-playback-button{display:none!important}
.cta-eye-text{
  font-family:var(--sans);
  font-size:clamp(1.4rem,2.8vw,2.4rem);
  font-weight:200;
  text-transform:uppercase;
  letter-spacing:.15em;
  line-height:1.2;
  color:var(--text-dark);
  transition:color .3s var(--ease);
}
.cta-eye-link:hover .cta-eye-text{
  color:var(--coral);
}
/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .work-preview-grid{grid-template-columns:repeat(2,1fr)}
  .about-teaser-editorial{grid-template-columns:1fr;gap:2.5rem}
  .work-block-media--split{grid-template-columns:1fr 1fr}
  .work-row-portraits{gap:clamp(1.2rem,2vw,2rem)}
  .work-row-landscape{gap:clamp(1.2rem,2vw,2rem)}
}

@media(max-width:768px){
  .clients-section .section-title{
    font-size:clamp(1.5rem,4vw,2.5rem);
  }
  .hero{
    align-items:center;
    padding-top:calc(var(--nav-h) + 2rem);
    padding-bottom:3rem;
    min-height:100svh;
  }
  .hero-video{
    position:fixed;
    top:0;
    left:0;
    width:100vw;
    height:100vh;
    object-fit:cover;
  }
  .hero-bottom{
    flex-direction:column;
    align-items:flex-start;
    gap:1.5rem;
  }
  .hero-outline{-webkit-text-stroke-width:1.5px}
  .about-teaser-editorial{grid-template-columns:1fr;text-align:center}
  .about-teaser-portrait{max-width:400px;margin:0 auto}
  .about-teaser-desc{margin:0 auto 2rem}
  .work-row-portraits{grid-template-columns:1fr}
  .work-row-landscape{grid-template-columns:1fr}
  .work-row--right .work-block{grid-column:1}
  .work-row-courses{justify-content:center}
  .work-row-courses .work-block{width:100%;max-width:none}
  .work-block--portrait .work-block-media img,
  .work-block--portrait .work-block-media video{aspect-ratio:3/4;height:auto}
  .work-block-media--split{grid-template-columns:1fr 1fr}
  .work-block-media--split img{min-height:140px}
  .cta-eye-link{flex-direction:row;text-align:left}
  .cta-eye-video-wrap{width:clamp(120px,20vw,200px)}

  /* Service menu mobile */
  .service-menu-item{
    grid-template-columns:auto 1fr auto auto;
    gap:.75rem;
    padding:1rem 0;
  }
  .service-menu-item:hover .service-menu-preview{
    opacity:0;
    transform:translateY(-50%) scale(.92);
  }
  .service-menu-desc{
    display:none;
  }
  .service-menu-title{
    font-size:clamp(1.1rem,5vw,1.5rem);
    max-width:15ch;
  }
  .service-menu-thumb{
    display:block;
    width:50px;
    aspect-ratio:3/4;
    border-radius:3px;
    overflow:hidden;
  }
  .service-menu-preview{
    display:none;
  }
  .service-menu-arrow{
    width:16px;
    height:16px;
  }
  .service-menu-num{
    font-size:.65rem;
    min-width:1.5rem;
  }
  .service-menu-title-row{
    flex-wrap:wrap;
  }
  .service-menu-item--soon .service-menu-title{
    max-width:none;
  }
  .coming-soon-badge{
    font-size:.45rem;
    margin-left:0;
    width:100%;
  }
}

@media(max-width:480px){
  .hero-title{font-size:clamp(2rem,10vw,3rem)}
  .work-preview-grid{grid-template-columns:1fr}
  .work-block-title{font-size:clamp(.9rem,4vw,1.1rem)}
  .work-block-media--split{grid-template-columns:1fr}
  .clients-track{gap:2rem}
  .clients-track img{height:40px;max-width:150px}
  .cta-eye-link{flex-direction:column;text-align:center;gap:1.5rem}
  .cta-eye-video-wrap{width:clamp(140px,40vw,200px)}
  .cta-eye-text{font-size:clamp(1.2rem,5vw,1.6rem)}
}
