@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=Geist:wght@400;500;600&display=swap');

:root{
  --black:#0C0C0A;
  --surface:#15140F;
  --surface-2:#1C1A14;
  --paper:#F4F1EA;
  --paper-70:rgba(244,241,234,.7);
  --paper-55:rgba(244,241,234,.55);
  --paper-35:rgba(244,241,234,.35);
  --hair:rgba(244,241,234,.10);
  --hair-strong:rgba(244,241,234,.18);
  --tan:#E8A24A;
  --tan-soft:rgba(232,162,74,.14);

  --ease:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.32,.72,0,1);

  --container:1280px;
  --r-lg:28px;
  --r-md:18px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%;}

body{
  background:var(--black);
  color:var(--paper);
  font-family:'Geist', system-ui, sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* film grain overlay (fixed, never on scrolling content) */
body::after{
  content:"";
  position:fixed; inset:0; z-index:9999;
  pointer-events:none;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--container); margin:0 auto; padding:0 40px;}

h1,h2,h3,h4{
  font-family:'Bricolage Grotesque', sans-serif;
  font-weight:700;
  line-height:1.02;
  letter-spacing:-0.02em;
}
a{color:inherit; text-decoration:none;}
img{display:block; max-width:100%;}

.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:11px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--tan);
}
.eyebrow::before{content:""; width:6px; height:6px; border-radius:50%; background:var(--tan);}

/* ---------- Buttons ---------- */
.btn{
  position:relative;
  display:inline-flex; align-items:center; gap:14px;
  background:var(--tan); color:#1a1305;
  padding:13px 13px 13px 26px; border-radius:999px;
  font-family:'Geist',sans-serif; font-size:15px; font-weight:600;
  transition:transform .5s var(--ease-spring), background .35s var(--ease);
  will-change:transform;
}
.btn .arrow{
  width:30px; height:30px; border-radius:50%;
  background:rgba(26,19,5,.16);
  display:flex; align-items:center; justify-content:center;
  transition:transform .5s var(--ease-spring), background .35s var(--ease);
}
.btn .arrow svg{width:14px; height:14px;}
.btn:hover .arrow{transform:translate(3px,-3px) scale(1.06); background:rgba(26,19,5,.26);}
.btn:active{transform:scale(.97);}

.btn-ghost{
  background:transparent; color:var(--paper);
  border:1px solid var(--hair-strong);
  padding:13px 26px;
}
.btn-ghost .arrow{background:var(--hair);}
.btn-ghost:hover{background:rgba(244,241,234,.04);}
.btn-ghost:hover .arrow{background:var(--tan-soft);}

/* ---------- Nav: floating glass island ---------- */
.nav-shell{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; justify-content:center;
  padding:22px 20px;
  transition:padding .5s var(--ease);
}
.nav-shell.shrink{padding-top:14px;}
.nav{
  display:flex; align-items:center; gap:36px;
  width:min(100%, 980px);
  padding:10px 10px 10px 26px;
  border-radius:999px;
  background:rgba(18,17,12,.55);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border:1px solid var(--hair);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 20px 50px -20px rgba(0,0,0,.7);
}
.brand{
  font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:24px;
  letter-spacing:-.03em; line-height:1; position:relative; padding-right:2px;
}
.brand .dot{color:var(--tan);}
.nav-links{display:flex; gap:28px; margin-left:6px;}
.nav-links a{font-size:14px; color:var(--paper-55); transition:color .3s var(--ease);}
.nav-links a:hover{color:var(--paper);}
.nav .btn{margin-left:auto; padding:10px 10px 10px 20px; font-size:14px;}
.nav .btn .arrow{width:26px; height:26px;}

.nav-burger{
  display:none; margin-left:auto;
  width:44px; height:44px; border-radius:50%;
  background:var(--hair); border:none; cursor:pointer;
  position:relative;
}
.nav-burger span{
  position:absolute; left:13px; width:18px; height:1.6px; background:var(--paper);
  transition:transform .45s var(--ease-spring), opacity .3s var(--ease);
}
.nav-burger span:nth-child(1){top:18px;}
.nav-burger span:nth-child(2){top:25px;}
body.menu-open .nav-burger span:nth-child(1){transform:translateY(4px) rotate(45deg);}
body.menu-open .nav-burger span:nth-child(2){transform:translateY(-3px) rotate(-45deg);}

/* mobile overlay menu */
.menu-overlay{
  position:fixed; inset:0; z-index:90;
  background:rgba(8,8,6,.82);
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  display:flex; flex-direction:column; justify-content:center; gap:8px;
  padding:0 40px;
  opacity:0; visibility:hidden;
  transition:opacity .5s var(--ease), visibility .5s;
}
body.menu-open .menu-overlay{opacity:1; visibility:visible;}
.menu-overlay a{
  font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:clamp(38px,11vw,68px);
  letter-spacing:-.03em; color:var(--paper);
  transform:translateY(28px); opacity:0;
  transition:transform .6s var(--ease), opacity .6s var(--ease);
}
body.menu-open .menu-overlay a{transform:translateY(0); opacity:1;}
body.menu-open .menu-overlay a:nth-child(1){transition-delay:.08s;}
body.menu-open .menu-overlay a:nth-child(2){transition-delay:.14s;}
body.menu-open .menu-overlay a:nth-child(3){transition-delay:.2s;}
body.menu-open .menu-overlay a:nth-child(4){transition-delay:.26s;}
body.menu-open .menu-overlay a:nth-child(5){transition-delay:.32s; color:var(--tan);}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0; transform:translateY(30px); filter:blur(8px);}
.reveal.in{opacity:1; transform:none; filter:none; transition:opacity .9s var(--ease), transform .9s var(--ease), filter .9s var(--ease);}
.reveal.d1.in{transition-delay:.08s;}
.reveal.d2.in{transition-delay:.16s;}
.reveal.d3.in{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none; filter:none;}
}

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100dvh;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:0 0 64px;
  overflow:hidden;
}
.hero-media{
  position:absolute; inset:0; z-index:-2;
}
.hero-media img{
  width:100%; height:100%; object-fit:cover;
  filter:saturate(.8) contrast(1.06) brightness(.62);
}
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(12,12,10,.55) 0%, rgba(12,12,10,.15) 30%, rgba(12,12,10,.85) 78%, var(--black) 100%),
    radial-gradient(120% 80% at 80% 10%, rgba(232,162,74,.10), transparent 55%);
}
.hero .wrap{width:100%;}
.hero-top{
  padding-top:160px; margin-bottom:auto;
}
.hero h1{
  font-size:clamp(52px, 9vw, 134px);
  font-weight:800;
  max-width:14ch;
  margin:22px 0 0;
}
.hero h1 em{font-style:italic; color:var(--tan); font-weight:800;}
.hero-row{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:48px; flex-wrap:wrap; margin-top:40px;
}
.hero p.lead{
  font-size:clamp(16px,1.6vw,19px); color:var(--paper-70);
  max-width:42ch;
}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap;}
.scroll-cue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--paper-35);
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scroll-cue .line{width:1px; height:38px; background:linear-gradient(var(--tan), transparent); animation:cue 2.2s var(--ease) infinite;}
@keyframes cue{0%{transform:scaleY(0); transform-origin:top;}40%{transform:scaleY(1); transform-origin:top;}60%{transform:scaleY(1); transform-origin:bottom;}100%{transform:scaleY(0); transform-origin:bottom;}}

/* ---------- Marquee ---------- */
.marquee{
  border-top:1px solid var(--hair); border-bottom:1px solid var(--hair);
  padding:30px 0; overflow:hidden; position:relative;
}
.marquee::before, .marquee::after{
  content:""; position:absolute; top:0; bottom:0; width:140px; z-index:2;
}
.marquee::before{left:0; background:linear-gradient(90deg, var(--black), transparent);}
.marquee::after{right:0; background:linear-gradient(270deg, var(--black), transparent);}
.marquee-track{display:flex; gap:64px; width:max-content; animation:scroll 32s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.m-logo{display:flex; align-items:center; gap:12px; color:var(--paper-35); transition:color .3s var(--ease);}
.m-logo:hover{color:var(--paper);}
.m-logo svg{width:26px; height:26px; flex:none;}
.m-logo span{font-family:'Bricolage Grotesque',sans-serif; font-weight:600; font-size:19px; letter-spacing:-.01em; white-space:nowrap;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---------- Section scaffolding ---------- */
.section{padding:130px 0;}
.section-lead{max-width:62ch; margin-bottom:72px;}
.section-lead h2{font-size:clamp(34px,5vw,64px); font-weight:700;}
.section-lead h2 em{font-style:italic; color:var(--tan);}
.section-lead p{margin-top:22px; color:var(--paper-55); font-size:17px; max-width:48ch;}

/* ---------- Services: asymmetric bento + double-bezel ---------- */
.bento{
  display:grid; grid-template-columns:repeat(6,1fr); gap:18px;
}
/* double-bezel shell */
.cell{
  background:rgba(244,241,234,.04);
  border:1px solid var(--hair);
  border-radius:var(--r-lg);
  padding:7px;
  transition:transform .6s var(--ease), border-color .5s var(--ease);
}
.cell:hover{transform:translateY(-6px); border-color:var(--hair-strong);}
.cell-inner{
  position:relative; height:100%;
  background:var(--surface);
  border-radius:calc(var(--r-lg) - 7px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  padding:34px; overflow:hidden;
  display:flex; flex-direction:column;
}
.cell .num{font-family:'Bricolage Grotesque',sans-serif; font-style:italic; font-weight:600; color:var(--tan); font-size:15px;}
.cell h3{font-size:clamp(22px,2.2vw,30px); margin-top:auto; padding-top:60px;}
.cell p{color:var(--paper-55); font-size:14.5px; margin-top:12px; max-width:34ch;}

.cell.span-4{grid-column:span 4;}
.cell.span-3{grid-column:span 3;}
.cell.span-2{grid-column:span 2;}
.cell.tall{grid-row:span 2;}

/* image-backed cell */
.cell.media .cell-inner{padding:0; min-height:300px; justify-content:flex-end;}
.cell.media img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(.85) contrast(1.05) brightness(.85); transition:transform 1s var(--ease);}
.cell.media:hover img{transform:scale(1.05);}
.cell.media .cell-inner::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 35%, rgba(12,12,10,.9));}
.cell.media .overlay{position:relative; z-index:2; padding:34px;}
.cell.media .overlay h3{padding-top:0; margin-top:0;}

/* tan tinted cell */
.cell.accent{background:var(--tan-soft);}
.cell.accent .cell-inner{background:linear-gradient(160deg, rgba(232,162,74,.22), rgba(232,162,74,.05)); box-shadow:inset 0 1px 0 rgba(255,255,255,.12);}
.cell.accent .num{color:var(--paper);}

/* ---------- Work: horizontal scroll gallery ---------- */
.work-head{display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:54px; flex-wrap:wrap;}
.work-head h2{font-size:clamp(34px,5vw,60px);}
.work-controls{display:flex; align-items:center; gap:22px; padding-bottom:8px;}
.drag-hint{display:inline-flex; align-items:center; gap:10px; color:var(--paper-35); font-size:13px; letter-spacing:.04em; white-space:nowrap;}
.drag-hint svg{width:20px; height:20px;}
.gallery-nav{display:flex; gap:10px;}
.gnav-btn{
  width:48px; height:48px; border-radius:50%;
  background:rgba(244,241,234,.04); border:1px solid var(--hair-strong);
  color:var(--paper); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .35s var(--ease), transform .5s var(--ease-spring), border-color .35s var(--ease);
}
.gnav-btn svg{width:18px; height:18px;}
.gnav-btn:hover{background:var(--tan-soft); border-color:var(--tan); color:var(--tan); transform:translateY(-2px);}
.gnav-btn:active{transform:scale(.94);}
.gnav-btn:disabled{opacity:.3; cursor:default; transform:none; border-color:var(--hair-strong); background:transparent; color:var(--paper);}
.gallery{
  display:flex; gap:22px;
  overflow-x:auto; scroll-snap-type:x mandatory;
  padding:4px 40px 24px; margin:0 -40px;
  cursor:grab; scrollbar-width:none;
}
.gallery::-webkit-scrollbar{display:none;}
.gallery.dragging{cursor:grabbing; scroll-snap-type:none;}
.shot{
  flex:0 0 clamp(280px, 42vw, 560px); scroll-snap-align:center;
  border-radius:var(--r-md); overflow:hidden; position:relative;
  aspect-ratio:4/5; background:var(--surface); cursor:pointer;
}
.shot img{width:100%; height:100%; object-fit:cover; filter:saturate(.82) contrast(1.05) brightness(.78); transition:transform 1s var(--ease), filter .6s var(--ease); pointer-events:none;}
.shot:hover img{transform:scale(1.05); filter:saturate(1) contrast(1.05) brightness(.88);}
.shot .info{position:absolute; left:24px; right:24px; bottom:22px; z-index:2;}
.shot::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 45%, rgba(12,12,10,.88));}
.shot .info{z-index:3;}
.shot .cat{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--tan);}
.shot .info h3{font-size:24px; margin-top:6px; color:var(--paper);}
.shot .play{
  position:absolute; top:50%; left:50%; z-index:3;
  width:64px; height:64px; border-radius:50%;
  background:rgba(244,241,234,.12); backdrop-filter:blur(10px);
  border:1px solid var(--hair-strong);
  display:flex; align-items:center; justify-content:center;
  color:var(--paper);
  transform:translate(-50%,-50%) scale(.8); opacity:0;
  transition:transform .5s var(--ease-spring), opacity .4s var(--ease), background .35s var(--ease);
}
.shot .play svg{width:22px; height:22px; margin-left:3px;}
.shot:hover .play, .shot:focus-visible .play{opacity:1; transform:translate(-50%,-50%) scale(1);}
.shot:hover .play{background:var(--tan); color:#1a1305; border-color:var(--tan);}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(7,7,5,.92); backdrop-filter:blur(24px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; padding:60px 24px;
  transition:opacity .5s var(--ease), visibility .5s;
}
.lightbox.open{opacity:1; visibility:visible;}
.lb-stage{
  max-width:760px; width:100%; text-align:center;
  transform:translateY(24px) scale(.98); opacity:0;
  transition:transform .55s var(--ease), opacity .55s var(--ease);
}
.lightbox.open .lb-stage{transform:none; opacity:1;}
.lb-stage img{
  width:100%; max-height:62vh; object-fit:cover;
  border-radius:var(--r-md); border:1px solid var(--hair-strong);
}
.lb-caption{margin-top:24px;}
.lb-caption .cat{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--tan);}
.lb-caption h3{font-family:'Bricolage Grotesque',sans-serif; font-size:clamp(24px,3vw,34px); margin-top:8px;}
.lb-note{color:var(--paper-35); font-size:13px; margin-top:10px; min-height:1px;}
.lb-close, .lb-arrow{
  position:fixed; z-index:201;
  width:52px; height:52px; border-radius:50%;
  background:rgba(244,241,234,.06); border:1px solid var(--hair-strong);
  color:var(--paper); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .35s var(--ease), border-color .35s var(--ease), transform .4s var(--ease-spring);
}
.lb-close svg, .lb-arrow svg{width:18px; height:18px;}
.lb-close:hover, .lb-arrow:hover{background:var(--tan-soft); border-color:var(--tan); color:var(--tan);}
.lb-close{top:30px; right:30px;}
.lb-prev{top:50%; left:30px; transform:translateY(-50%);}
.lb-next{top:50%; right:30px; transform:translateY(-50%);}
.lb-prev:hover{transform:translateY(-50%) translateX(-3px);}
.lb-next:hover{transform:translateY(-50%) translateX(3px);}
@media (max-width:760px){
  .lb-prev{left:12px;} .lb-next{right:12px;} .lb-close{top:16px; right:16px;}
  .lb-close, .lb-arrow{width:44px; height:44px;}
}

/* ---------- Process ---------- */
.process .step{
  display:grid; grid-template-columns:120px 1fr auto; gap:40px; align-items:baseline;
  padding:40px 0; border-top:1px solid var(--hair);
}
.process .step:last-child{border-bottom:1px solid var(--hair);}
.process .step .idx{font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:clamp(40px,5vw,68px); color:var(--surface-2); -webkit-text-stroke:1px var(--hair-strong); line-height:.9;}
.process .step:hover .idx{color:var(--tan); -webkit-text-stroke:0;}
.process .step .body h3{font-size:clamp(24px,3vw,34px);}
.process .step .body p{color:var(--paper-55); margin-top:12px; max-width:52ch; font-size:15.5px;}
.process .step .tag{font-size:12px; color:var(--paper-35); letter-spacing:.1em; text-transform:uppercase; white-space:nowrap;}

/* ---------- Team ---------- */
.team-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.team-card{
  background:rgba(244,241,234,.04); border:1px solid var(--hair);
  border-radius:var(--r-lg); padding:7px;
  transition:transform .6s var(--ease), border-color .5s var(--ease);
}
.team-card:hover{transform:translateY(-6px); border-color:var(--hair-strong);}
.team-photo{position:relative; border-radius:calc(var(--r-lg) - 7px); overflow:hidden; aspect-ratio:4/5;}
.team-photo img{width:100%; height:100%; object-fit:cover; filter:saturate(.82) contrast(1.05) brightness(.85); transition:transform 1s var(--ease);}
.team-card:hover .team-photo img{transform:scale(1.05);}
.team-photo::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 60%, rgba(12,12,10,.55));}
.team-info{padding:26px 18px 20px;}
.team-info h3{font-size:26px;}
.team-info .role{display:block; color:var(--tan); font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; margin:8px 0 14px;}
.team-info p{color:var(--paper-55); font-size:14.5px; line-height:1.6;}


/* ---------- CTA ---------- */
.cta-wrap{padding:40px 0 130px;}
.cta{
  position:relative; overflow:hidden;
  border-radius:40px; padding:7px;
  background:rgba(232,162,74,.16); border:1px solid var(--hair);
}
.cta-inner{
  position:relative;
  background:linear-gradient(150deg, #1a1611, #0f0e0b);
  border-radius:34px; padding:clamp(48px,8vw,110px) clamp(28px,6vw,90px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  text-align:center;
}
.cta-inner::before{content:""; position:absolute; inset:0; background:radial-gradient(80% 120% at 50% 120%, rgba(232,162,74,.22), transparent 60%);}
.cta-inner > *{position:relative; z-index:2;}
.cta h2{font-size:clamp(38px,7vw,86px); font-weight:800; line-height:1;}
.cta h2 em{font-style:italic; color:var(--tan);}
.cta p{color:var(--paper-55); max-width:40ch; margin:26px auto 38px; font-size:17px;}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--hair); padding:80px 0 0;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; padding-bottom:64px;}
.footer-grid .brand{font-size:30px; margin-bottom:18px;}
.footer-grid p{color:var(--paper-55); font-size:14.5px; max-width:30ch;}
.fcol h4{font-size:12px; text-transform:uppercase; letter-spacing:.16em; color:var(--paper-35); margin-bottom:18px; font-family:'Geist',sans-serif; font-weight:600;}
.fcol a{display:block; color:var(--paper-55); font-size:14.5px; margin-bottom:12px; transition:color .3s var(--ease);}
.fcol a:hover{color:var(--tan);}
.footer-word{
  font-family:'Bricolage Grotesque',sans-serif; font-weight:800;
  font-size:clamp(80px, 22vw, 340px); line-height:.78; letter-spacing:-.04em;
  color:var(--surface-2); -webkit-text-stroke:1px var(--hair);
  text-align:center; padding:20px 0 0; user-select:none;
}
.footer-word .dot{color:var(--tan); -webkit-text-stroke:0;}
.footer-bottom{display:flex; justify-content:space-between; padding:28px 0; border-top:1px solid var(--hair); font-size:13px; color:var(--paper-35); flex-wrap:wrap; gap:12px;}

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .nav-links, .nav .btn{display:none;}
  .nav-burger{display:block;}
  .team-grid{grid-template-columns:1fr; max-width:420px; margin-left:auto; margin-right:auto;}
}
@media (max-width:760px){
  .wrap{padding:0 22px;}
  .section{padding:88px 0;}
  .hero-top{padding-top:130px;}
  .bento{grid-template-columns:1fr; gap:14px;}
  .cell.span-4,.cell.span-3,.cell.span-2{grid-column:span 1;}
  .cell.tall{grid-row:span 1;}
  .cell.media .cell-inner{min-height:260px;}
  .process .step{grid-template-columns:1fr; gap:14px;}
  .process .step .tag{order:-1;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px;}
  .footer-grid .brand-col{grid-column:span 2;}
  .gallery{margin:0 -22px; padding:4px 22px 24px;}
}
