/* ============ TOKENS ============ */
:root{
  --bg:        #0a0a0c;
  --bg-2:      #111114;
  --surface:   rgba(255,255,255,.04);
  --surface-2: rgba(255,255,255,.07);
  --border:    rgba(255,255,255,.10);
  --border-2:  rgba(255,255,255,.18);
  --text:      #f4f2ee;
  --muted:     #a4a09a;
  --muted-2:   #75726d;
  --gold:      #d4a857;
  --gold-soft: #e8c98a;
  --gold-dim:  rgba(212,168,87,.14);

  --maxw: 1180px;
  --radius: 18px;
  --radius-sm: 12px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --shadow: 0 24px 60px -20px rgba(0,0,0,.7);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:'Heebo',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* Fixed gallery background for all sections below the hero (parallax) */
body::before{
  content:''; position:fixed; inset:0; z-index:-2;
  background:url('6ed374471806a8c802d1012bc06ab766.jpg') center center / cover no-repeat;
}
body::after{
  content:''; position:fixed; inset:0; z-index:-1;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(10,10,12,.7) 0%, rgba(10,10,12,.9) 60%, rgba(10,10,12,.96) 100%),
    linear-gradient(180deg, rgba(10,10,12,.82) 0%, rgba(12,11,9,.8) 50%, rgba(10,10,12,.9) 100%);
}
img,svg,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold); color:#1a1408; }

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font:600 1rem/1 'Heebo',sans-serif;
  padding:.95rem 1.7rem; border-radius:999px;
  cursor:pointer; border:1px solid transparent;
  transition:transform .2s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
}
.btn:active{ transform:scale(.97); }
.btn--solid{ background:var(--gold); color:#1a1408; box-shadow:0 10px 30px -10px rgba(212,168,87,.5); }
.btn--solid:hover{ background:var(--gold-soft); box-shadow:0 14px 38px -10px rgba(212,168,87,.65); }
.btn--ghost{ background:rgba(255,255,255,.06); color:var(--text); border-color:var(--border-2); backdrop-filter:blur(8px); }
.btn--ghost:hover{ background:rgba(255,255,255,.12); }
.btn--full{ width:100%; }

/* ============ INTRO SPLASH ============ */
.intro{
  position:fixed; inset:0; z-index:1000;
  background:radial-gradient(120% 120% at 50% 40%, #16140f 0%, #0a0a0c 70%);
  display:grid; place-items:center;
  transition:opacity .7s var(--ease), visibility .7s;
}
.intro--hide{ opacity:0; visibility:hidden; }
.intro__inner{ text-align:center; }
.intro__mark{ display:flex; flex-direction:column; gap:.1em; font-weight:900; letter-spacing:.14em; }
.intro__word{
  font-size:clamp(2.2rem,9vw,5.5rem); line-height:.95;
  opacity:0; transform:translateY(40px);
  animation:introUp .9s var(--ease) forwards;
  animation-delay:calc(.15s * var(--d));
}
.intro__word--accent{ color:var(--gold); }
.intro__line{ height:2px; width:0; margin:1.6rem auto 0; background:var(--gold);
  animation:introLine 1s var(--ease) .55s forwards; }
.intro__tag{
  margin-top:1.2rem; color:var(--muted); letter-spacing:.4em; font-size:.85rem; font-weight:500;
  opacity:0; animation:introFade .8s ease .9s forwards;
}
.intro__skip{
  position:absolute; bottom:2rem; inset-inline-start:50%; transform:translateX(50%);
  background:none; border:1px solid var(--border); color:var(--muted);
  padding:.5rem 1.1rem; border-radius:999px; cursor:pointer; font-family:inherit; font-size:.85rem;
  opacity:0; animation:introFade .6s ease 1.4s forwards; transition:border-color .2s, color .2s;
}
.intro__skip:hover{ color:var(--text); border-color:var(--border-2); }
@keyframes introUp{ to{ opacity:1; transform:none; } }
@keyframes introLine{ to{ width:min(280px,60vw); } }
@keyframes introFade{ to{ opacity:1; } }

/* ============ NAV ============ */
.nav{
  position:fixed; top:0; inset-inline:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.1rem clamp(1rem,4vw,2.5rem);
  transition:background .3s var(--ease), backdrop-filter .3s, padding .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.nav--scrolled{
  background:rgba(10,10,12,.72); backdrop-filter:blur(14px);
  border-bottom-color:var(--border); padding-top:.7rem; padding-bottom:.7rem;
}
.nav__brand{ display:flex; align-items:center; gap:.6rem; font-weight:800; font-size:1.15rem; }
.nav__logo{
  width:34px; height:34px; display:grid; place-items:center; border-radius:10px;
  background:var(--gold); color:#1a1408; font-weight:900;
}
.nav__name em{ color:var(--gold); font-style:normal; }
.nav__links{ display:flex; gap:2rem; }
.nav__links a{ color:var(--muted); font-weight:500; position:relative; transition:color .2s; }
.nav__links a::after{
  content:''; position:absolute; inset-inline-start:0; bottom:-6px; height:2px; width:0;
  background:var(--gold); transition:width .25s var(--ease);
}
.nav__links a:hover{ color:var(--text); }
.nav__links a:hover::after{ width:100%; }
.nav__cta{ padding:.6rem 1.3rem; font-size:.92rem; }
.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__burger span{ width:24px; height:2px; background:var(--text); transition:.3s var(--ease); }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============ HERO ============ */
.hero{ position:relative; isolation:isolate; min-height:100svh; display:grid; align-items:center; overflow:hidden; }
.hero__video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2;
}
.hero__scrim{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(10,10,12,.55) 0%, rgba(10,10,12,.35) 35%, rgba(10,10,12,.85) 100%),
    radial-gradient(80% 60% at 70% 30%, transparent 0%, rgba(10,10,12,.4) 100%);
}
.hero__content{ max-width:var(--maxw); width:100%; margin:0 auto; padding:6rem clamp(1.2rem,4vw,2.5rem) 0; }
.hero__eyebrow{
  display:inline-block; color:var(--gold-soft); font-weight:600; letter-spacing:.05em;
  padding:.4rem .9rem; border:1px solid var(--gold-dim); border-radius:999px;
  background:var(--gold-dim); margin-bottom:1.4rem; font-size:.9rem;
}
.hero__title{
  font-size:clamp(2.4rem,7vw,5.3rem); font-weight:900; line-height:1.04; letter-spacing:-.01em;
  max-width:18ch;
}
.hero__title span{ display:block; }
.hero__title em{ color:var(--gold); font-style:normal; }
.hero__sub{ margin-top:1.6rem; max-width:46ch; color:#d9d5cf; font-size:clamp(1rem,1.6vw,1.22rem); font-weight:300; }
.hero__actions{ margin-top:2.2rem; display:flex; gap:1rem; flex-wrap:wrap; }
.hero__scroll{ position:absolute; bottom:2rem; inset-inline-start:50%; transform:translateX(50%); z-index:2; }
.hero__mouse{ width:26px; height:42px; border:2px solid var(--border-2); border-radius:14px; display:block; position:relative; }
.hero__mouse span{
  position:absolute; top:8px; inset-inline-start:50%; transform:translateX(-50%);
  width:4px; height:8px; background:var(--gold); border-radius:2px; animation:scrollDot 1.6s infinite var(--ease);
}
@keyframes scrollDot{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 80%{opacity:0;transform:translate(-50%,14px)} 100%{opacity:0} }

/* ============ MARQUEE ============ */
.marquee{ background:var(--gold); color:#1a1408; padding:.85rem 0; overflow:hidden; white-space:nowrap; }
.marquee__track{ display:inline-flex; align-items:center; gap:2.5rem; animation:scrollX 24s linear infinite; font-weight:800; font-size:1.25rem; letter-spacing:.02em; }
.marquee__track i{ font-style:normal; opacity:.5; }
@keyframes scrollX{ to{ transform:translateX(50%); } } /* RTL: move right */

/* ============ SECTIONS ============ */
.section{ max-width:var(--maxw); margin:0 auto; padding:clamp(4rem,9vw,7.5rem) clamp(1.2rem,4vw,2.5rem); }
.section__head{ max-width:42rem; margin-bottom:3rem; }
.section__kicker{ color:var(--gold); font-weight:700; letter-spacing:.16em; text-transform:uppercase; font-size:.8rem; margin-bottom:.7rem; }
.section__title{ font-size:clamp(1.9rem,4.5vw,3rem); font-weight:800; line-height:1.1; letter-spacing:-.01em; }
.section__lead{ margin-top:1rem; color:var(--muted); font-size:1.1rem; }

/* ============ SERVICES ============ */
.services__grid{ display:flex; flex-wrap:wrap; justify-content:center; --gap:1.2rem; gap:var(--gap); }
.card{
  flex:0 1 calc((100% - 2 * var(--gap)) / 3);
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:2rem 1.7rem; transition:transform .3s var(--ease), background .3s, border-color .3s;
  position:relative; overflow:hidden;
}
.card::before{
  content:''; position:absolute; inset:0; opacity:0; transition:opacity .3s;
  background:radial-gradient(120% 80% at 50% 0%, var(--gold-dim) 0%, transparent 60%);
}
.card:hover{ transform:translateY(-6px); border-color:var(--border-2); background:var(--surface-2); }
.card:hover::before{ opacity:1; }
.card__icon{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:var(--gold-dim); color:var(--gold); margin-bottom:1.3rem;
}
.card__icon svg{ width:26px; height:26px; }
.card h3{ font-size:1.3rem; font-weight:700; margin-bottom:.5rem; }
.card p{ color:var(--muted); font-size:.98rem; }

/* ============ WORK / UPLOAD ============ */
.uploader{
  border:2px dashed var(--border-2); border-radius:var(--radius);
  padding:2.6rem 1.5rem; text-align:center; background:var(--surface);
  transition:border-color .25s, background .25s, transform .25s; cursor:pointer; margin-bottom:2.2rem;
}
.uploader:hover{ border-color:var(--gold); background:var(--gold-dim); }
.uploader.is-drag{ border-color:var(--gold); background:var(--gold-dim); transform:scale(1.01); }
.uploader__icon{ width:60px; height:60px; margin:0 auto 1rem; border-radius:50%; display:grid; place-items:center; background:var(--gold-dim); color:var(--gold); }
.uploader__icon svg{ width:28px; height:28px; }
.uploader__title{ font-weight:700; font-size:1.15rem; }
.uploader__hint{ color:var(--muted-2); font-size:.9rem; margin:.4rem 0 1.3rem; }

/* curated showcase — balanced matrix, last row centered when count is odd */
.showcase{ display:flex; flex-wrap:wrap; justify-content:center; --gap:1.4rem; gap:var(--gap); margin-bottom:1rem; }
.show-item{
  flex:0 1 calc((100% - 2 * var(--gap)) / 3);
  position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:16/11;
  background:#000; border:1px solid var(--border); cursor:pointer;
  transition:transform .35s var(--ease), border-color .35s, box-shadow .35s;
  animation:popIn .5s var(--ease) both; animation-delay:calc(.08s * var(--i,0));
}
.show-item:hover{ transform:translateY(-6px); border-color:var(--gold); box-shadow:var(--shadow); }
.show-item video{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.show-item:hover video{ transform:scale(1.04); }
.show-item__tag{
  position:absolute; top:.9rem; inset-inline-start:.9rem; z-index:3;
  background:rgba(212,168,87,.92); color:#1a1408; font-weight:700; font-size:.78rem;
  padding:.3rem .8rem; border-radius:999px; backdrop-filter:blur(4px);
}
.show-item__play{
  position:absolute; inset:0; margin:auto; width:62px; height:62px; border-radius:50%;
  background:rgba(212,168,87,.94); color:#1a1408; display:grid; place-items:center;
  pointer-events:none; opacity:0; transform:scale(.8); transition:opacity .3s, transform .3s;
}
.show-item:hover .show-item__play{ opacity:1; transform:scale(1); }
.show-item__meta{
  position:absolute; inset-inline:0; bottom:0; z-index:2; padding:1.4rem 1.2rem 1.1rem;
  background:linear-gradient(0deg, rgba(0,0,0,.88) 0%, rgba(0,0,0,.4) 60%, transparent 100%);
}
.show-item__title{ font-size:1.15rem; font-weight:700; }
.show-item__desc{ color:#cfcbc4; font-size:.92rem; margin-top:.25rem; }

/* divider */
.work__divider{ display:flex; align-items:center; gap:1rem; color:var(--muted); margin:0 0 2rem; }
.work__divider::before, .work__divider::after{ content:''; height:1px; flex:1; background:var(--border); }
.work__divider span{ font-size:.9rem; font-weight:500; letter-spacing:.04em; }

.work__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.work__grid:empty{ display:none; }
.work-item{
  position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:16/10;
  background:#000; border:1px solid var(--border); cursor:pointer; transition:transform .3s var(--ease), border-color .3s;
  animation:popIn .4s var(--ease) both;
}
.work-item:hover{ transform:translateY(-4px); border-color:var(--gold); }
.work-item video{ width:100%; height:100%; object-fit:cover; }
.work-item__overlay{
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding:1rem; gap:.3rem;
  background:linear-gradient(0deg, rgba(0,0,0,.8) 0%, transparent 55%);
  opacity:0; transition:opacity .3s;
}
.work-item:hover .work-item__overlay{ opacity:1; }
.work-item__name{ font-weight:600; font-size:.95rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.work-item__play{
  position:absolute; inset:0; margin:auto; width:58px; height:58px; border-radius:50%;
  background:rgba(212,168,87,.92); color:#1a1408; display:grid; place-items:center;
  pointer-events:none; transition:transform .3s, opacity .3s; opacity:.92;
}
.work-item:hover .work-item__play{ transform:scale(1.1); }
.work-item__del{
  position:absolute; top:.6rem; inset-inline-end:.6rem; z-index:3;
  width:32px; height:32px; border-radius:50%; border:0; cursor:pointer;
  background:rgba(0,0,0,.6); color:#fff; font-size:1rem; line-height:1; backdrop-filter:blur(6px);
  opacity:0; transition:opacity .25s, background .25s;
}
.work-item:hover .work-item__del{ opacity:1; }
.work-item__del:hover{ background:#c0392b; }
@keyframes popIn{ from{ opacity:0; transform:translateY(16px) scale(.98); } to{ opacity:1; transform:none; } }

.work__empty{ text-align:center; color:var(--muted-2); padding:1.5rem; }
.work__empty.is-hidden{ display:none; }

/* ============ ABOUT ============ */
.about{ position:relative; }
.about__grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:3rem; align-items:center; }
.about__text p{ color:var(--muted); margin:1.2rem 0 2rem; font-size:1.08rem; }
.about__stats{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.stat{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.8rem 1.4rem; text-align:center; }
.stat strong{ display:block; font-size:clamp(2.2rem,5vw,3rem); font-weight:900; color:var(--gold); line-height:1; font-variant-numeric:tabular-nums; }
.stat span{ color:var(--muted); font-size:.95rem; margin-top:.4rem; display:block; }

/* ============ CONTACT ============ */
.contact{ }
.contact__inner{
  background:linear-gradient(180deg, var(--bg-2), #0c0c0f);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:clamp(2rem,5vw,3.5rem); display:grid; grid-template-columns:1.4fr 1fr; gap:3rem; align-items:start;
}
.contact .section__head{ grid-column:1/-1; margin-bottom:1rem; }
.form{ display:flex; flex-direction:column; gap:1.1rem; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field label{ font-weight:500; font-size:.95rem; }
.field input, .field textarea{
  background:rgba(255,255,255,.04); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:.85rem 1rem; color:var(--text); font:400 1rem 'Heebo',sans-serif; resize:vertical;
  transition:border-color .2s, background .2s;
}
.field input::placeholder, .field textarea::placeholder{ color:var(--muted-2); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold); background:rgba(255,255,255,.06); }
.field--invalid input, .field--invalid textarea{ border-color:#e0564a; }
.field__error{ color:#f0897e; font-size:.82rem; min-height:1em; }
.form__success{ color:var(--gold-soft); font-weight:600; text-align:center; }

.contact__side{ display:flex; flex-direction:column; gap:1rem; padding-top:.5rem; }
.contact__link{ font-size:1.1rem; font-weight:500; color:var(--muted); transition:color .2s; width:fit-content; }
.contact__link:hover{ color:var(--gold); }
.contact__social{ display:flex; gap:.8rem; margin-top:.5rem; }
.contact__social a{ width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:var(--surface); border:1px solid var(--border); color:var(--muted); transition:.25s var(--ease); }
.contact__social a svg{ width:20px; height:20px; }
.contact__social a:hover{ color:var(--gold); border-color:var(--gold); transform:translateY(-3px); }

/* ============ FOOTER ============ */
.footer{ text-align:center; padding:3rem 1.5rem; border-top:1px solid var(--border); }
.footer__brand{ font-weight:800; font-size:1.2rem; }
.footer__brand em{ color:var(--gold); font-style:normal; }
.footer p{ color:var(--muted-2); font-size:.9rem; margin-top:.5rem; }

/* ============ LIGHTBOX ============ */
.lightbox{
  position:fixed; inset:0; z-index:500; background:rgba(5,5,7,.92); backdrop-filter:blur(10px);
  display:grid; place-items:center; padding:1.5rem;
  opacity:0; visibility:hidden; transition:opacity .3s var(--ease), visibility .3s;
}
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__video{ max-width:min(960px,92vw); max-height:84vh; border-radius:var(--radius); box-shadow:var(--shadow); background:#000; }
.lightbox__close{
  position:absolute; top:1.4rem; inset-inline-end:1.4rem; width:46px; height:46px; border-radius:50%;
  background:var(--surface-2); border:1px solid var(--border-2); color:var(--text); font-size:1.2rem; cursor:pointer;
  transition:background .2s, transform .2s;
}
.lightbox__close:hover{ background:rgba(255,255,255,.16); transform:rotate(90deg); }

/* ============ REVEAL ON SCROLL ============ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); transition-delay:calc(.08s * var(--d,0)); }
.reveal.is-in{ opacity:1; transform:none; }

/* ============ RESPONSIVE ============ */
@media (max-width:960px){
  /* 2-column matrix on tablet/phone */
  .card, .show-item{ flex-basis:calc((100% - var(--gap)) / 2); }
  .about__grid{ grid-template-columns:1fr; gap:2rem; }
}
@media (max-width:680px){
  .nav__links, .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  .nav__links.is-open{
    display:flex; flex-direction:column; gap:1.5rem; position:absolute; top:100%; inset-inline:0;
    background:rgba(10,10,12,.96); backdrop-filter:blur(14px); padding:2rem; border-bottom:1px solid var(--border);
  }
  .nav__links.is-open a{ font-size:1.2rem; }
  /* services: keep a compact 2-up grid (short text cards) */
  .services__grid{ --gap:0.8rem; }
  .card{ padding:1.4rem 1.1rem; }
  /* videos: ONE per row on phone so each plays large & clear, framed by orientation */
  .showcase{ --gap:1.1rem; }
  .show-item{ flex-basis:100%; aspect-ratio:16/9; }
  .show-item--portrait{ aspect-ratio:3/4; }
  .show-item__tag{ top:.85rem; inset-inline-start:.85rem; font-size:.8rem; padding:.32rem .85rem; }
  .show-item__title{ font-size:1.25rem; }
  .show-item__desc{ font-size:.95rem; }
  .show-item__meta{ padding:1.6rem 1.2rem 1.2rem; }
  .show-item__play{ width:66px; height:66px; }
  .about__stats{ grid-template-columns:1fr 1fr; }
  .hero__actions{ flex-direction:column; align-items:stretch; }
  .hero__actions .btn{ width:100%; }
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .hero__video{ display:none; }
  .marquee__track{ animation:none; }
}
