:root{
  --bg:#0a0a0b;
  --bg-alt:#111113;
  --fg:#f3f1ea;
  --muted:#8f8c86;
  --accent:#c9a24b;
  --line:rgba(243,241,234,0.1);
  --ff-display:'Anton', sans-serif;
  --ff-body:'Inter', sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--ff-body);
  overflow-x:hidden;
  cursor:default;
}

a{color:inherit;text-decoration:none;}
ul{list-style:none;}

/* grain overlay */
.grain{
  position:fixed;inset:0;
  pointer-events:none;
  z-index:9998;
  opacity:0.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* custom cursor */
.cursor-dot{
  position:fixed;top:0;left:0;
  width:10px;height:10px;
  border-radius:50%;
  background:var(--accent);
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .15s ease, opacity .3s ease, width .2s ease, height .2s ease;
  opacity:0;
}
@media (hover:hover) and (pointer:fine){
  .cursor-dot{opacity:1;}
}

/* loader */
.loader{
  position:fixed;inset:0;
  background:var(--bg);
  z-index:10000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.2rem;
  transition:transform .8s cubic-bezier(.76,0,.24,1);
}
.loader.done{transform:translateY(-100%);}
.loader-name{
  font-family:var(--ff-display);
  font-size:clamp(1.4rem,4vw,2.4rem);
  letter-spacing:.08em;
  color:var(--fg);
}
.loader-count{
  font-size:.85rem;
  color:var(--muted);
  letter-spacing:.1em;
}

/* header */
.site-header{
  position:fixed;top:0;left:0;right:0;
  z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem clamp(1.2rem,5vw,3rem);
  mix-blend-mode:difference;
}
.logo{
  font-family:var(--ff-display);
  font-size:1.4rem;
  letter-spacing:.05em;
}
.logo span{color:var(--accent);}
.header-right{display:flex;align-items:center;gap:1.6rem;}
.badge{
  display:flex;align-items:center;gap:.5rem;
  font-size:.78rem;
  letter-spacing:.03em;
  color:var(--muted);
  mix-blend-mode:normal;
}
.badge i{
  width:7px;height:7px;border-radius:50%;
  background:#5ee08a;
  box-shadow:0 0 8px #5ee08a;
}
@media (max-width:640px){ .badge{display:none;} }

.menu-btn{
  width:44px;height:44px;
  border:1px solid var(--line);
  border-radius:50%;
  background:transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;
  cursor:pointer;
}
.menu-btn span{
  width:16px;height:1.5px;background:var(--fg);
  transition:transform .3s ease, opacity .3s ease;
}
.menu-btn.open span:first-child{transform:translateY(3.25px) rotate(45deg);}
.menu-btn.open span:last-child{transform:translateY(-3.25px) rotate(-45deg);}

/* full nav overlay */
.fullnav{
  position:fixed;inset:0;
  background:var(--bg-alt);
  z-index:400;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(2rem,8vw,6rem);
  transform:translateY(-100%);
  transition:transform .6s cubic-bezier(.76,0,.24,1);
}
.fullnav.open{transform:translateY(0);}
.fullnav ul{display:flex;flex-direction:column;gap:.4rem;}
.navlink{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,8vw,5rem);
  letter-spacing:.03em;
  color:var(--fg);
  display:inline-block;
  transition:color .3s ease, transform .3s ease;
}
.navlink:hover{color:var(--accent);transform:translateX(.4em);}
.fullnav-footer{
  margin-top:3rem;
  display:flex;gap:2rem;
  color:var(--muted);
  font-size:.9rem;
}

/* hero */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:6rem 1.2rem 2rem;
  background:
    radial-gradient(ellipse at 50% 20%, rgba(201,162,75,.10), transparent 60%),
    linear-gradient(180deg,#0a0a0b,#111113 70%,#0a0a0b);
}
.hero-eyebrow{
  font-size:.85rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1.2rem;
}
.hero-title{
  font-family:var(--ff-display);
  font-size:clamp(3rem,13vw,9rem);
  line-height:.92;
  letter-spacing:.01em;
  display:flex;flex-direction:column;
}
.hero-sub{
  margin-top:1.4rem;
  font-size:clamp(1rem,2vw,1.25rem);
  color:var(--muted);
  font-weight:300;
}
.scroll-cue{
  position:absolute;
  bottom:2.2rem;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.75rem;
  letter-spacing:.15em;
  color:var(--muted);
}
.scroll-cue i{
  width:1px;height:36px;
  background:linear-gradient(var(--muted), transparent);
  position:relative;
  overflow:hidden;
}
.scroll-cue i::after{
  content:'';
  position:absolute;top:-100%;left:0;right:0;height:100%;
  background:var(--accent);
  animation:scrollline 1.8s ease-in-out infinite;
}
@keyframes scrollline{
  0%{top:-100%;}
  60%{top:100%;}
  100%{top:100%;}
}

/* marquee */
.marquee{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  padding:1.4rem 0;
  white-space:nowrap;
}
.marquee-track{
  display:inline-flex;
  gap:1.6rem;
  animation:marquee 22s linear infinite;
  font-family:var(--ff-display);
  font-size:clamp(1.1rem,2.4vw,1.6rem);
  letter-spacing:.04em;
  color:var(--muted);
}
.marquee-track span:nth-child(odd){color:var(--accent);}
@keyframes marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* section shared */
section{padding:8rem clamp(1.2rem,6vw,4rem);}
.section-head{margin-bottom:3.5rem;}
.section-kicker{
  color:var(--accent);
  font-size:.85rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:.8rem;
}
.section-head h2, .about-copy h2, .contact h2{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem,5.5vw,4rem);
  letter-spacing:.01em;
  line-height:1.05;
}

/* work grid */
.work-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px,1fr));
  gap:2.4rem;
}
.work-card{cursor:pointer;}
.work-thumb{
  aspect-ratio:4/3;
  border-radius:6px;
  background:linear-gradient(135deg, hsl(var(--hue) 55% 18%), hsl(var(--hue) 40% 8%));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  position:relative;
  transition:transform .5s cubic-bezier(.16,1,.3,1);
}
.work-thumb span{
  font-family:var(--ff-display);
  font-size:4rem;
  color:rgba(243,241,234,0.18);
}
.work-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.work-card:hover .work-thumb{transform:scale(1.03);}
.work-thumb::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.55));
  opacity:0;
  transition:opacity .4s ease;
}
.work-card:hover .work-thumb::after{opacity:1;}
.work-meta{padding-top:1.1rem;}
.work-meta h3{font-size:1.15rem;font-weight:500;margin-bottom:.3rem;}
.work-meta p{color:var(--muted);font-size:.9rem;}

.play-icon{
  position:absolute;
  width:56px;height:56px;
  border-radius:50%;
  border:1px solid rgba(243,241,234,0.5);
  background:rgba(10,10,11,0.35);
  backdrop-filter:blur(4px);
  z-index:2;
  opacity:0;
  transform:scale(.8);
  transition:opacity .35s ease, transform .35s ease;
}
.play-icon::after{
  content:'';
  position:absolute;
  top:50%;left:56%;
  transform:translate(-50%,-50%);
  border-style:solid;
  border-width:9px 0 9px 15px;
  border-color:transparent transparent transparent var(--fg);
}
.work-card:hover .play-icon, .work-card:focus-visible .play-icon{
  opacity:1;
  transform:scale(1);
}

/* project modal */
.modal{
  position:fixed;inset:0;
  z-index:2000;
  display:flex;align-items:center;justify-content:center;
  padding:2rem clamp(1rem,5vw,3rem);
  opacity:0;
  pointer-events:none;
  transition:opacity .4s ease;
}
.modal.open{opacity:1;pointer-events:auto;}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(6,6,7,0.88);
  backdrop-filter:blur(6px);
}
.modal-inner{
  position:relative;
  width:min(920px, 100%);
  max-height:90vh;
  overflow-y:auto;
  background:var(--bg-alt);
  border:1px solid var(--line);
  border-radius:10px;
  padding:clamp(1.2rem,3vw,2.4rem);
  transform:translateY(24px) scale(.98);
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.modal.open .modal-inner{transform:translateY(0) scale(1);}
.modal-close{
  position:absolute;
  top:1rem;right:1rem;
  width:40px;height:40px;
  border-radius:50%;
  border:1px solid var(--line);
  background:var(--bg);
  color:var(--fg);
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
  z-index:3;
  transition:border-color .3s ease, color .3s ease;
}
.modal-close:hover{border-color:var(--accent);color:var(--accent);}

.modal-video-wrap{
  position:relative;
  aspect-ratio:16/9;
  border-radius:6px;
  overflow:hidden;
  background:linear-gradient(135deg, hsl(var(--hue) 55% 16%), hsl(var(--hue) 40% 7%));
}
.modal-video-wrap video, .modal-video-wrap iframe{
  width:100%;height:100%;
  object-fit:cover;
  display:none;
  background:#000;
  border:none;
}
.modal-video-wrap.has-video video, .modal-video-wrap.has-embed iframe{display:block;}
.modal-video-wrap.has-video .modal-video-placeholder,
.modal-video-wrap.has-embed .modal-video-placeholder{display:none;}
.modal-video-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:1.5rem;
  gap:.5rem;
}
.modal-video-placeholder span{
  font-family:var(--ff-display);
  font-size:1.2rem;
  letter-spacing:.03em;
  color:rgba(243,241,234,0.6);
}
.modal-video-placeholder p{
  color:var(--muted);
  font-size:.82rem;
  max-width:36ch;
}
.modal-video-placeholder code{
  color:var(--accent);
  font-size:.8em;
}

.video-tabs{
  display:flex;
  gap:.6rem;
  margin-top:1rem;
  flex-wrap:wrap;
}
.video-tabs:empty{display:none;}
.video-tab{
  padding:.5rem 1rem;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--bg);
  color:var(--muted);
  font-size:.82rem;
  letter-spacing:.03em;
  cursor:pointer;
  transition:border-color .25s ease, color .25s ease, background .25s ease;
}
.video-tab:hover{color:var(--fg);border-color:rgba(243,241,234,0.35);}
.video-tab.active{
  color:var(--bg);
  background:var(--accent);
  border-color:var(--accent);
}

.modal-info{margin-top:1.4rem;}
.modal-info h3{font-size:1.4rem;font-weight:500;}
.modal-info p{color:var(--muted);font-size:.9rem;margin-top:.3rem;}
.modal-desc{
  margin-top:.9rem;
  font-size:.95rem;
  line-height:1.65;
  max-width:60ch;
  color:rgba(243,241,234,0.75);
}
.modal-desc:empty{display:none;}

.filmstrip-label{
  margin-top:2rem;
  color:var(--muted);
  font-size:.78rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  margin-bottom:.9rem;
}
.filmstrip{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:.6rem;
}
.frame-thumb{
  aspect-ratio:16/9;
  border-radius:4px;
  background:linear-gradient(135deg, hsl(var(--hue) 50% 20%), hsl(var(--hue) 35% 9%));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  cursor:pointer;
  border:1px solid transparent;
  transition:border-color .25s ease, transform .25s ease;
}
.frame-thumb:hover{border-color:var(--accent);transform:translateY(-2px);}
.frame-thumb span{
  font-size:.7rem;
  color:rgba(243,241,234,0.4);
  letter-spacing:.05em;
}
.frame-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
@media (max-width:640px){
  .filmstrip{grid-template-columns:repeat(3, 1fr);}
}
body.modal-lock{overflow:hidden;}

/* image lightbox (zoomed frame view) */
.lightbox{
  position:fixed;inset:0;
  z-index:3000;
  display:flex;align-items:center;justify-content:center;
  padding:3rem clamp(1rem,5vw,4rem);
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}
.lightbox.open{opacity:1;pointer-events:auto;}
.lightbox-backdrop{
  position:absolute;inset:0;
  background:rgba(4,4,5,0.94);
  backdrop-filter:blur(4px);
}
.lightbox img{
  position:relative;
  max-width:100%;
  max-height:100%;
  border-radius:6px;
  box-shadow:0 20px 60px rgba(0,0,0,0.6);
  transform:scale(.96);
  transition:transform .35s cubic-bezier(.16,1,.3,1);
}
.lightbox.open img{transform:scale(1);}
.lightbox-close{
  position:absolute;
  top:1.6rem;right:1.6rem;
  width:44px;height:44px;
  border-radius:50%;
  border:1px solid var(--line);
  background:var(--bg-alt);
  color:var(--fg);
  font-size:1.5rem;
  line-height:1;
  cursor:pointer;
  z-index:1;
  transition:border-color .3s ease, color .3s ease;
}
.lightbox-close:hover{border-color:var(--accent);color:var(--accent);}

/* about */
.about{
  display:grid;
  grid-template-columns:.8fr 1.2fr;
  gap:4rem;
  align-items:center;
}
.portrait-box{
  aspect-ratio:3/4;
  border-radius:8px;
  background:linear-gradient(160deg,#1c1a17,#0d0c0b);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
}
.portrait-box span{
  font-family:var(--ff-display);
  font-size:5rem;
  color:rgba(201,162,75,0.35);
}
.about-text{
  margin-top:1.5rem;
  color:var(--muted);
  font-size:1.05rem;
  line-height:1.7;
  max-width:46ch;
}
.stats{
  display:flex;gap:3rem;
  margin-top:3rem;
  flex-wrap:wrap;
}
.stat{display:flex;flex-direction:column;}
.stat-num, .stat-plus{
  font-family:var(--ff-display);
  font-size:2.6rem;
  color:var(--accent);
  display:inline;
}
.stat p{color:var(--muted);font-size:.85rem;margin-top:.3rem;letter-spacing:.03em;}

@media (max-width:860px){
  .about{grid-template-columns:1fr;}
  .portrait-box{max-width:280px;}
}

/* services */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.service-card{
  background:var(--bg);
  padding:2.6rem 2rem;
  transition:background .3s ease;
}
.service-card:hover{background:var(--bg-alt);}
.service-num{color:var(--accent);font-family:var(--ff-display);font-size:.95rem;}
.service-card h3{margin:1rem 0 .7rem;font-size:1.3rem;font-weight:500;}
.service-card p{color:var(--muted);font-size:.92rem;line-height:1.6;}

/* contact */
.contact{
  text-align:center;
  padding-top:6rem;padding-bottom:6rem;
}
.contact h2{margin-top:.5rem;}
.contact-email{
  display:inline-block;
  margin-top:2.4rem;
  font-size:clamp(1.2rem,3vw,1.8rem);
  border-bottom:1px solid var(--line);
  padding-bottom:.4rem;
  transition:color .3s ease, border-color .3s ease;
}
.contact-email:hover{color:var(--accent);border-color:var(--accent);}
.socials{
  margin-top:2.6rem;
  display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;
}
.socials a{
  color:var(--muted);
  font-size:.9rem;
  letter-spacing:.05em;
  position:relative;
}
.socials a:hover{color:var(--fg);}

/* footer */
.site-footer{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  padding:2rem clamp(1.2rem,6vw,4rem) 2.6rem;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:.85rem;
}
.to-top:hover{color:var(--accent);}

/* reveal animation */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.16,1,.3,1);
  transition-delay:var(--d,0s);
}
.reveal.in{opacity:1;transform:translateY(0);}
