:root{
  --dark:#1E1208; --dark-soft:#2A1B0F;
  --cream:#FAF7F2; --cream-soft:#F5ECD8;
  --gold:#B5935A; --gold-soft:#D4B989;
  --sage:#3D5E35; --sage-soft:#EBF0E9;
  --gray:#6B6056; --gray-soft:#A8A096;
  --border:rgba(30,18,8,.10);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--dark);font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased}

/* ---------- HEADER ---------- */
.hero{max-width:1180px;margin:0 auto;padding:84px 32px 40px;text-align:center}
.hero .mark{display:inline-flex;margin-bottom:26px}
.hero .eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,7vw,72px);letter-spacing:.02em;line-height:1.02;color:var(--dark)}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero .lede{max-width:560px;margin:22px auto 0;font-size:16px;line-height:1.65;color:var(--gray)}
.hero .tag{display:inline-flex;align-items:center;gap:12px;margin-top:26px;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold)}
.hero .tag::before,.hero .tag::after{content:"";width:34px;height:1px;background:var(--gold);opacity:.55}

/* ---------- FILTERS ---------- */
.filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:1180px;margin:18px auto 0;padding:0 32px}
.filters button{font-family:var(--sans);font-size:12px;letter-spacing:.08em;color:var(--gray);background:transparent;border:1px solid var(--border);padding:9px 20px;border-radius:999px;cursor:pointer;transition:all .22s ease}
.filters button:hover{border-color:var(--gold);color:var(--dark)}
.filters button.active{background:var(--dark);border-color:var(--dark);color:var(--cream)}

/* ---------- GRID ---------- */
.grid{max-width:1180px;margin:48px auto 0;padding:0 32px 100px;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:26px}
.card{cursor:pointer;border:none;background:transparent;text-align:left;padding:0;font-family:inherit}
.card .frame{position:relative;width:100%;aspect-ratio:9/16;border-radius:14px;overflow:hidden;
  background:var(--cream-soft);box-shadow:0 1px 0 var(--border);transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s}
.card:hover .frame{transform:translateY(-6px);box-shadow:0 22px 40px -20px rgba(30,18,8,.40)}
.card .frame img{width:100%;height:100%;object-fit:cover;display:block}
.card .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,var(--dark) 0%,var(--dark-soft) 55%,#3a2614 100%)}
.card .placeholder span{font-family:var(--serif);font-size:46px;color:var(--gold-soft);opacity:.85}
.card .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,18,8,.55) 0%,rgba(30,18,8,0) 42%);
  display:flex;align-items:flex-end;padding:16px;opacity:0;transition:opacity .3s}
.card:hover .overlay{opacity:1}
.card .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);
  width:54px;height:54px;border-radius:50%;background:rgba(250,247,242,.92);display:flex;align-items:center;justify-content:center;
  opacity:0;transition:all .3s}
.card:hover .play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.card .play svg{margin-left:3px}
.card .badge{position:absolute;top:12px;left:12px;font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cream);background:rgba(30,18,8,.55);backdrop-filter:blur(4px);padding:5px 10px;border-radius:999px}
.card .meta{padding:14px 4px 0}
.card .meta h3{font-family:var(--serif);font-weight:500;font-size:19px;line-height:1.2;color:var(--dark)}
.card .meta .client{font-size:11px;letter-spacing:.06em;color:var(--gold);margin-top:3px;text-transform:uppercase}
.card .meta .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.card .meta .tags span{font-size:10px;color:var(--gray);border:1px solid var(--border);padding:3px 8px;border-radius:999px}

/* ---------- LIGHTBOX ---------- */
.lightbox{position:fixed;inset:0;z-index:50;display:none;align-items:center;justify-content:center;
  background:rgba(18,10,4,.86);backdrop-filter:blur(8px);padding:24px}
.lightbox.open{display:flex}
.lightbox .stage{position:relative;width:auto;max-width:96vw}
.lightbox .player{position:relative;height:min(86vh,860px);aspect-ratio:9/16;max-width:96vw;
  background:#000;border-radius:16px;overflow:hidden;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lightbox .player.wide{aspect-ratio:16/9;height:auto;width:min(96vw,1100px)}
.lightbox .player iframe,.lightbox .player video{width:100%;height:100%;border:0;display:block}
.lightbox .cap{margin-top:14px;text-align:center;color:var(--cream)}
.lightbox .cap h3{font-family:var(--serif);font-weight:500;font-size:22px}
.lightbox .cap p{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);margin-top:4px}
.lightbox .close{position:absolute;top:-46px;right:0;width:38px;height:38px;border-radius:50%;border:1px solid rgba(250,247,242,.3);
  background:transparent;color:var(--cream);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.lightbox .close:hover{background:var(--gold);border-color:var(--gold);color:var(--dark)}

/* ---------- FOOTER ---------- */
.foot{border-top:1px solid var(--border);max-width:1180px;margin:0 auto;padding:34px 32px 70px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center}
.foot .wm{font-family:var(--serif);font-size:18px;letter-spacing:.12em;color:var(--dark)}
.foot .note{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-soft)}
.foot a{color:var(--gold);text-decoration:none}

.empty{grid-column:1/-1;text-align:center;color:var(--gray);font-family:var(--serif);font-size:22px;padding:60px 0}

@media(max-width:560px){
  .grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .hero{padding-top:56px}
}
