:root{
  --bg:#0c0c0c; --bg2:#141311; --ink:#f2efe9; --mut:#9a948a; --dim:#5f5a52;
  --gold:#c9a96a; --line:#23211d;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2rem;transition:background .35s,padding .35s;background:linear-gradient(rgba(12,12,12,.85),rgba(12,12,12,0))}
.nav.solid{background:rgba(12,12,12,.96);padding:.8rem 2rem;border-bottom:1px solid var(--line)}
.wordmark{font-family:var(--serif);font-size:1.25rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink)}
.links{display:flex;gap:1.8rem}
.links a{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mut);padding-bottom:3px;border-bottom:1px solid transparent;transition:color .25s,border-color .25s}
.links a:hover{color:var(--ink)}
.links a.active{color:var(--ink);border-color:var(--gold)}
.burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.burger span{position:absolute;left:0;width:100%;height:1.5px;background:var(--ink);transition:.3s}
.burger span:nth-child(1){top:2px}.burger span:nth-child(2){top:11px}.burger span:nth-child(3){top:20px}

/* ---------- hero ---------- */
.hero{position:relative;height:100svh;min-height:560px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:brightness(.5) saturate(.92)}
.hero-ol{position:relative;z-index:2;padding:0 1.5rem;max-width:780px}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(12,12,12,.25) 40%,var(--bg) 98%)}
.hero-ol{z-index:3}
.hero-kicker{font-size:.72rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(3rem,9vw,5.8rem);line-height:1.05;letter-spacing:.02em}
.hero-sub{color:var(--mut);max-width:520px;margin:1.4rem auto 2.2rem;font-size:.95rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:3;font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:var(--dim);animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

.btn{display:inline-block;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;padding:.85rem 1.8rem;transition:.25s}
.btn.gold{background:var(--gold);color:#0c0c0c}
.btn.gold:hover{background:#dfc188}
.btn.ghost{border:1px solid rgba(242,239,233,.35);color:var(--ink)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- bands / tiles ---------- */
.band{padding:5.5rem 2rem;max-width:1280px;margin:0 auto}
.band-kicker{font-size:.7rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:2rem}
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.tile{position:relative;overflow:hidden;aspect-ratio:3/4}
.tile img{width:100%;height:100%;object-fit:cover;filter:brightness(.75) saturate(.95);transition:transform .8s cubic-bezier(.2,.6,.2,1),filter .5s}
.tile:hover img{transform:scale(1.05);filter:brightness(.9)}
.tile-ol{position:absolute;inset:auto 0 0 0;padding:1.4rem 1.2rem;background:linear-gradient(transparent,rgba(12,12,12,.92));display:flex;flex-direction:column}
.tile-t{font-family:var(--serif);font-size:1.5rem;letter-spacing:.06em}
.tile-s{font-size:.7rem;color:var(--mut);letter-spacing:.12em;text-transform:uppercase;margin-top:.2rem}

/* ---------- about ---------- */
.about{border-top:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:4rem;align-items:center}
.about h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1.2rem}
.about-txt p{margin-bottom:1.1rem;color:var(--mut);font-size:.95rem;max-width:54ch}
.clients-line{font-size:.78rem!important;color:var(--dim)!important;letter-spacing:.06em}
.about .btn{margin-top:.6rem}
.reel video{width:100%;max-width:340px;margin:0 auto;border:1px solid var(--line);border-radius:14px;aspect-ratio:9/16;object-fit:cover;background:#000}
.reel figcaption{text-align:center;font-size:.7rem;color:var(--dim);letter-spacing:.18em;text-transform:uppercase;margin-top:.8rem}

/* ---------- category pages ---------- */
.page{padding:9rem 2rem 4rem;max-width:1280px;margin:0 auto}
.page-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,6vw,4.2rem);letter-spacing:.02em}
.page-intro{color:var(--mut);max-width:560px;margin:1rem 0 0;font-size:.95rem}
.pills{position:sticky;top:56px;z-index:40;display:flex;gap:.5rem;overflow-x:auto;padding:1.2rem 0;margin:1.6rem 0 .5rem;background:linear-gradient(var(--bg) 85%,transparent);scrollbar-width:none}
.pills::-webkit-scrollbar{display:none}
.pills a{flex:0 0 auto;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);border:1px solid var(--line);border-radius:99px;padding:.45rem 1rem;transition:.25s}
.pills a:hover,.pills a.on{color:var(--gold);border-color:var(--gold)}
.client{padding:3rem 0 1rem;scroll-margin-top:120px}
.client-head{display:flex;align-items:baseline;gap:1.2rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:2.2rem;margin-bottom:1.6rem}
.client-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.6rem,3vw,2.2rem)}
.client-sub{font-size:.72rem;color:var(--dim);letter-spacing:.16em;text-transform:uppercase}

/* ---------- galleries ---------- */
.masonry{columns:3 300px;column-gap:10px}
.ph{display:block;margin-bottom:10px;break-inside:avoid;overflow:hidden;position:relative}
.ph img{width:100%;height:auto;filter:saturate(.97);transition:transform .7s cubic-bezier(.2,.6,.2,1),filter .4s}
.ph:hover img{transform:scale(1.03);filter:saturate(1.05) brightness(1.05)}

/* ---------- video ---------- */
.vid-wide{margin:0 0 1.6rem}
.vid-wide video{width:100%;aspect-ratio:16/9;background:#000;border:1px solid var(--line)}
.vidrow{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:1.6rem}
.vid-tall{flex:1 1 200px;max-width:260px;margin:0}
.vid-tall video{width:100%;aspect-ratio:9/16;object-fit:cover;background:#000;border:1px solid var(--line);border-radius:12px}
figure figcaption{font-size:.68rem;color:var(--dim);letter-spacing:.16em;text-transform:uppercase;margin-top:.6rem}

/* ---------- contact ---------- */
.contact-page{min-height:70vh}
.contact-card{border:1px solid var(--line);padding:2.5rem;max-width:560px;margin-top:2.5rem;background:var(--bg2)}
.c-label{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.c-mail{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);color:var(--ink);border-bottom:1px solid var(--gold)}
.c-body{color:var(--mut);font-size:.92rem;margin-top:.3rem}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);text-align:center;padding:4.5rem 2rem 3rem;margin-top:4rem}
.f-serif{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.4rem);margin-bottom:1.6rem}
.f-small{font-size:.72rem;color:var(--dim);margin-top:2.2rem;letter-spacing:.08em;line-height:2}
.f-small a:hover{color:var(--gold)}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,8,8,.96);display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img,.lightbox video{max-width:92vw;max-height:86vh;object-fit:contain}
.lb-x,.lb-prev,.lb-next{position:absolute;background:none;border:0;color:var(--mut);font-size:2.4rem;cursor:pointer;line-height:1;padding:1rem;transition:color .2s;z-index:2}
.lb-x:hover,.lb-prev:hover,.lb-next:hover{color:var(--gold)}
.lb-x{top:.6rem;right:1rem}
.lb-prev{left:.5rem;top:50%;transform:translateY(-50%)}
.lb-next{right:.5rem;top:50%;transform:translateY(-50%)}
.lb-cap{position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mut)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .tiles{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .links{position:fixed;inset:0;background:rgba(12,12,12,.98);flex-direction:column;align-items:center;justify-content:center;gap:2.2rem;display:none}
  .links.open{display:flex}
  .links a{font-size:1rem}
  .burger{display:block;z-index:60}
  .burger.open span:nth-child(1){top:11px;transform:rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){top:11px;transform:rotate(-45deg)}
  .nav{padding:1rem 1.2rem}
  .page{padding:7.5rem 1.2rem 3rem}
  .band{padding:3.5rem 1.2rem}
  .pills{top:50px}
}
@media (max-width:520px){.tiles{grid-template-columns:1fr}.masonry{columns:2 150px}}
