:root{
  --bg:#0f1013;
  --bg-soft:#15171b;
  --panel:rgba(255,255,255,0.05);
  --panel-strong:rgba(255,255,255,0.08);
  --line:rgba(255,255,255,0.10);
  --text:#f0e7de;
  --muted:rgba(240,231,222,0.74);
  --gold:#c99b72;
  --sage:#6f8d7b;
  --shadow:0 28px 80px rgba(0,0,0,0.42);
  --radius-xl:32px;
  --radius-lg:24px;
  --radius-md:16px;
  --shell:min(1160px, 92vw);
  color-scheme:dark;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100%;
  background:
    radial-gradient(1000px 700px at 10% 0%, rgba(111,141,123,0.16), transparent 60%),
    radial-gradient(900px 760px at 100% 15%, rgba(201,155,114,0.14), transparent 58%),
    linear-gradient(180deg, #111216 0%, #0d0e10 100%);
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height:1.55;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}
button,input,textarea,select{color:inherit}

.srOnly{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skipLink{
  position:absolute;
  top:-48px;
  left:16px;
  z-index:999;
  background:#fff;
  color:#111;
  padding:10px 14px;
  border-radius:999px;
}
.skipLink:focus{top:16px}

.shell{width:var(--shell);margin:0 auto}
.section{padding:clamp(64px, 10vw, 112px) 0;position:relative}
.sectionHead{max-width:760px;margin-bottom:28px}
.sectionKicker,
.eyebrow,
.noteLabel,
.galleryTag,
.lightboxEyebrow{
  margin:0 0 10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(240,231,222,0.70);
}
.sectionTitle{
  margin:0;
  font-size:clamp(34px, 5vw, 58px);
  line-height:1.02;
  letter-spacing:-0.03em;
}
.sectionText,
.lead,
.helperText,
.storyCard p,
.capabilityCard p,
.contactCard p,
.noteCard p{
  color:var(--muted);
}
.sectionText{margin:14px 0 0;max-width:60ch;font-size:17px}

.siteGlow{position:fixed;inset:auto;pointer-events:none;filter:blur(22px);opacity:0.55;z-index:0}
.siteGlowA{top:8%;left:-120px;width:260px;height:260px;background:rgba(111,141,123,0.14);border-radius:50%}
.siteGlowB{top:24%;right:-80px;width:200px;height:200px;background:rgba(201,155,114,0.14);border-radius:50%}

.topbar{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:linear-gradient(180deg, rgba(12,13,16,0.88), rgba(12,13,16,0.52));
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.navRow{
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-size:12px;
  font-weight:700;
}
.brandMark{
  width:12px;
  height:12px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--gold), var(--sage));
  box-shadow:0 0 24px rgba(201,155,114,0.45);
}
.siteNav{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.siteNav a{font-size:14px;color:rgba(240,231,222,0.84)}
.siteNav a:hover,
.siteNav a:focus-visible{color:#fff}

.navToggle{
  display:none;
  width:48px;
  height:48px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.04);
  align-items:center;
  justify-content:center;
  gap:4px;
  flex-direction:column;
}
.navToggle span:not(.srOnly){display:block;width:18px;height:2px;background:#fff;border-radius:999px}

.hero{padding-top:clamp(34px, 5vw, 56px)}
.heroGrid{display:grid;grid-template-columns:minmax(320px, 0.95fr) minmax(320px, 1.05fr);gap:clamp(28px, 4vw, 44px);align-items:center}
.heroVisual{
  position:relative;
  border-radius:clamp(28px, 4vw, 42px);
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow);
  background:#0a0b0d;
}
.heroVisual img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.heroVisual::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.54) 100%);
}
.heroGrain{
  position:absolute;
  inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.08) 0.7px, transparent 0.7px);
  background-size:8px 8px;
  opacity:0.08;
  mix-blend-mode:soft-light;
}
.heroCaption{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  z-index:2;
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.82);
}
.display{
  margin:0;
  font-size:clamp(56px, 11vw, 112px);
  line-height:0.92;
  letter-spacing:-0.06em;
}
.lead{margin:18px 0 0;max-width:24ch;font-size:clamp(18px, 2.2vw, 24px)}
.statusRow,
.ctaRow,
.heroNotes,
.contactActions,
.footerRow,
.stackLinks{display:flex;gap:12px;flex-wrap:wrap}
.statusRow{margin-top:22px}
.statusPill,
.mailBadge{
  display:inline-flex;
  align-items:center;
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  color:rgba(240,231,222,0.92);
}
.statusPill strong{font-weight:700}
.ctaRow{margin-top:24px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid transparent;
  transition:transform .22s ease, background-color .22s ease, border-color .22s ease, color .22s ease;
  cursor:pointer;
}
.btn:hover,
.btn:focus-visible{transform:translateY(-1px)}
.btnPrimary{background:linear-gradient(135deg, var(--gold), #d4af8d);color:#14110e}
.btnGhost{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.12)}
.btnSoft{background:rgba(111,141,123,0.12);border-color:rgba(111,141,123,0.24)}
.heroNotes{margin-top:24px}
.noteCard{
  flex:1 1 240px;
  padding:18px;
  border-radius:var(--radius-lg);
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
}
.noteCard p{margin:0;max-width:40ch}

.showreelCard{
  position:relative;
  aspect-ratio:16/9;
  border-radius:clamp(24px, 4vw, 34px);
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:#090909;
  box-shadow:var(--shadow);
  cursor:pointer;
}
.showreelCard iframe,
.showreelPoster{width:100%;height:100%;display:block;object-fit:cover}
.showreelPoster{filter:contrast(1.04) saturate(1.02)}
.showreelOverlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  background:linear-gradient(180deg, rgba(0,0,0,0.16), rgba(0,0,0,0.58));
  text-align:center;
}
.playOrb{
  width:90px;
  height:90px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(10px);
  font-size:30px;
}
.showreelMeta{margin-top:14px}
.showreelMeta span{display:block;font-size:13px;letter-spacing:0.18em;text-transform:uppercase}
.showreelMeta small{display:block;margin-top:6px;color:rgba(255,255,255,0.82)}
.noscriptBox{padding:16px;background:#111}

.galleryGrid{display:grid;grid-template-columns:repeat(12, 1fr);gap:16px}
.galleryCard{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius-xl);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:0 16px 56px rgba(0,0,0,0.30);
  background:#090909;
  cursor:pointer;
  min-height:260px;
}
.galleryCard::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0.03) 30%, rgba(0,0,0,0.60) 100%);
}
.galleryCard img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.galleryCard:hover img,
.galleryCard:focus-visible img{transform:scale(1.03)}
.galleryCard figcaption{position:absolute;left:16px;right:16px;bottom:14px;z-index:2}
.galleryCard figcaption p{margin:8px 0 0;color:rgba(255,255,255,0.88);max-width:28ch}
.galleryCard.tall{grid-column:span 6;aspect-ratio:4/5}
.galleryCard.wide{grid-column:span 6;aspect-ratio:16/10}

.creditPanel{
  padding:18px;
  border-radius:var(--radius-xl);
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
  display:grid;
  gap:12px;
}
.creditItem{
  display:flex;
  gap:12px;
  align-items:baseline;
  flex-wrap:wrap;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(0,0,0,0.18);
  border:1px solid rgba(255,255,255,0.05);
}
.creditItem span{color:var(--muted)}
.capabilityGrid,
.contactGrid,
.dualPanel{display:grid;gap:16px}
.capabilityGrid{grid-template-columns:repeat(3, 1fr);margin-top:18px}
.capabilityCard,
.storyCard,
.contactCard{
  padding:22px;
  border-radius:var(--radius-xl);
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
}
.capabilityCard h3,
.contactCard h3{margin:0 0 10px;font-size:20px}
.dualPanel{grid-template-columns:1.15fr 0.85fr}
.storyCard .sectionTitle{font-size:clamp(28px, 4vw, 44px);margin-bottom:14px}
.profileList{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.profileList li{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(0,0,0,0.18);
  border:1px solid rgba(255,255,255,0.05);
}
.profileList span{font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(240,231,222,0.64)}
.profileList strong{font-size:16px}
.contactGrid{grid-template-columns:repeat(2, 1fr)}
.contactActions{margin-top:16px;align-items:center}
.mailBadge{font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}
.helperText{min-height:1.4em;margin:10px 0 0}
.stackLinks{align-items:flex-start;flex-direction:column}
.stackLinks .btn{width:100%;justify-content:flex-start}

.footer{
  padding:28px 0 46px;
  border-top:1px solid rgba(255,255,255,0.06);
}
.footerRow{justify-content:space-between;align-items:center;color:rgba(240,231,222,0.60);font-size:14px}
.footerRow p{margin:0}
.footerMeta{display:flex;flex-direction:column;gap:6px}
.footerCredit{font-size:12px;letter-spacing:0.04em;color:rgba(240,231,222,0.72)}
.footerCredit a{text-decoration:none;color:rgba(240,231,222,0.92);border-bottom:1px solid rgba(240,231,222,0.18);padding-bottom:1px}
.footerCredit a:hover{color:#fff;border-bottom-color:rgba(240,231,222,0.42)}

.lightbox{
  position:fixed;
  inset:0;
  z-index:200;
  background:rgba(3,3,5,0.82);
  backdrop-filter:blur(14px);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.lightbox.isOpen{display:flex}
.lightboxDialog{
  width:min(1080px, 96vw);
  max-height:calc(100vh - 40px);
  overflow:auto;
  border-radius:30px;
  border:1px solid rgba(255,255,255,0.10);
  background:#121318;
  box-shadow:var(--shadow);
}
.lightboxTop{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding:18px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.lightboxTop h2{margin:4px 0 0;font-size:30px}
.lightboxClose{
  min-width:46px;
  height:46px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.05);
  cursor:pointer;
}
.lightboxDialog img{width:100%;height:auto;display:block}
.lightboxCopy{margin:0;padding:18px;color:var(--muted)}

.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease, transform .7s ease}
.reveal.isVisible{opacity:1;transform:none}

:focus-visible{
  outline:2px solid rgba(201,155,114,0.9);
  outline-offset:3px;
}

@media (max-width: 980px){
  .heroGrid,
  .dualPanel,
  .contactGrid,
  .capabilityGrid{grid-template-columns:1fr}
  .galleryCard.tall,
  .galleryCard.wide{grid-column:span 12}
  .heroCopy{order:2}
  .heroVisual{order:1}
}

@media (max-width: 760px){
  .topbar{position:sticky}
  .navToggle{display:inline-flex}
  .siteNav{
    position:absolute;
    top:72px;
    left:16px;
    right:16px;
    padding:14px;
    border-radius:20px;
    border:1px solid rgba(255,255,255,0.08);
    background:rgba(15,16,19,0.96);
    box-shadow:var(--shadow);
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }
  .siteNav.isOpen{display:flex}
  .hero{padding-top:24px}
  .display{font-size:clamp(52px, 20vw, 92px)}
  .footerRow{flex-direction:column;align-items:flex-start;gap:12px}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *, *::before, *::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

.topbar.isScrolled{border-bottom-color:rgba(255,255,255,.10);background:linear-gradient(180deg, rgba(12,13,16,0.94), rgba(12,13,16,0.72));box-shadow:0 8px 30px rgba(0,0,0,.28)}
.copyFeedback{min-height:1.2em}
