/* ============================================================
   AARON HAMPTON — Shared site styles
   ============================================================ */
:root{
  --bg:#0a0a0b;
  --bg-2:#111113;
  --ink:#f4efe6;
  --ink-dim:rgba(244,239,230,.55);
  --ink-faint:rgba(244,239,230,.18);
  --accent:#f4efe6;        /* no colored accent — keep it monochrome */
  --hairline:rgba(244,239,230,.14);
  --mono:'IBM Plex Mono', ui-monospace, Menlo, monospace; /* camera-metadata captions */
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter Tight',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body{min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* Display type */
.display{
  font-family:'Instrument Serif',Georgia,serif;
  font-weight:400;
  letter-spacing:.005em;
  text-transform:uppercase;
  line-height:.86;
}

/* ------------------------------------------------------------
   Top nav
   ------------------------------------------------------------ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:40;
  display:flex;justify-content:center;align-items:center;
  padding:28px 36px;
}
.site-nav ul{
  display:flex;gap:36px;list-style:none;
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;
}
.site-nav a{
  position:relative;color:#fff;opacity:.75;transition:opacity .2s;
  padding:6px 0;
}
.site-nav a:hover{opacity:1}
.site-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:#fff;transition:right .35s cubic-bezier(.2,.7,.2,1);
}
.site-nav a:hover::after,
.site-nav a.is-active::after{right:0}
.site-nav a.is-active{opacity:1}

/* ------------------------------------------------------------
   Page header (used on subpages)
   ------------------------------------------------------------ */
.page-head{
  position:relative;
  padding:220px 36px 64px;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;
  min-height:78vh;
  overflow:hidden;
  isolation:isolate;
  border-bottom:1px solid var(--hairline);
}
.page-head__bg{
  position:absolute;inset:-8% 0;z-index:-2;
  background-position:center;background-size:cover;background-repeat:no-repeat;
  transform:scale(1.04);
  animation:slowZoom 22s ease-in-out infinite alternate;
  will-change:transform;
}
.page-head::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(10,10,11,.55) 0%, rgba(10,10,11,.08) 24%, rgba(10,10,11,.1) 55%, rgba(10,10,11,.85) 95%, rgba(10,10,11,1) 100%),
    linear-gradient(90deg, rgba(10,10,11,.55) 0%, rgba(10,10,11,.05) 55%, rgba(10,10,11,.4) 100%);
}
/* Scanlines + faint grain ON the header image for cinematic patina */
.page-head::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.04) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;opacity:.4;
}
@keyframes slowZoom{
  from{transform:scale(1.04) translate(0,0)}
  to  {transform:scale(1.12) translate(-1%, -1%)}
}
.page-head__title{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(96px,16vw,260px);
  line-height:.84;letter-spacing:.005em;
  text-transform:uppercase;
  color:var(--ink);
  text-shadow:0 6px 40px rgba(0,0,0,.5);
  animation: focusIn 1.6s cubic-bezier(.2,.7,.2,1) both,
             refocus 11s ease-in-out 3s infinite;
  will-change:filter,opacity,transform;
}
@keyframes focusIn{
  0%   { filter: blur(40px); opacity: .25; transform: scale(1.08); }
  60%  { filter: blur(6px);  opacity: .85; }
  100% { filter: blur(0);    opacity: 1;   transform: scale(1); }
}
@keyframes refocus{
  0%, 90%, 100% { filter: blur(0); }
  92% { filter: blur(10px); }
  94% { filter: blur(2px); }
  96% { filter: blur(6px); }
  98% { filter: blur(0); }
}
.page-head__lead{
  font-size:16px;line-height:1.55;color:rgba(244,239,230,.85);
  max-width:46ch;justify-self:end;text-wrap:pretty;
  text-shadow:0 2px 18px rgba(0,0,0,.5);
}

/* ------------------------------------------------------------
   Footer
   ------------------------------------------------------------ */
.site-foot{
  border-top:1px solid var(--hairline);
  padding:60px 36px 32px;
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;
  align-items:start;
}
.site-foot__big{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(40px,7vw,96px);line-height:.9;
  text-transform:uppercase;
}
.site-foot__big a{
  display:inline-block;
  border-bottom:2px solid var(--ink-faint);
  padding-bottom:6px;
  transition:border-color .25s;
}
.site-foot__big a:hover{border-color:var(--ink)}
.site-foot h4{
  font-family:var(--mono);
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-dim);font-weight:500;margin-bottom:14px;
}
.site-foot ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.site-foot ul a{font-family:var(--mono);font-size:12px;letter-spacing:.06em;opacity:.85;transition:opacity .2s}
.site-foot ul a:hover{opacity:1}
.site-foot__base{
  grid-column:1 / -1;display:flex;justify-content:space-between;
  font-family:var(--mono);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);
  padding-top:32px;margin-top:24px;
  border-top:1px solid var(--hairline);
}

/* ------------------------------------------------------------
   Site-wide cinema patina
   ------------------------------------------------------------ */
.patina{position:fixed;inset:0;z-index:50;pointer-events:none}
.patina .scan{
  position:absolute;inset:0;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.035) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;opacity:.6;
}
.patina .vig{
  position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 50%, transparent 60%, rgba(0,0,0,.55) 100%);
}
.patina .grain{
  position:absolute;inset:0;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ------------------------------------------------------------
   Reusable cinematic placeholder backgrounds
   ------------------------------------------------------------ */
.frame{position:relative;overflow:hidden;background:#000;isolation:isolate}
.frame__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.frame__grade{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.05) 30%, rgba(0,0,0,.05) 70%, rgba(0,0,0,.6) 100%);
}
.frame__placeholder{
  position:absolute;inset:0;
}
.frame__placeholder--warm{background:radial-gradient(120% 80% at 30% 40%, #2a2418 0%, #0a0a0b 55%, #000 100%);animation:drift 18s ease-in-out infinite alternate}
.frame__placeholder--cool{background:radial-gradient(120% 80% at 70% 50%, #1a2230 0%, #07090c 60%, #000 100%);animation:drift2 22s ease-in-out infinite alternate}
.frame__placeholder--green{background:radial-gradient(80% 70% at 40% 50%, #1a2a20 0%, #060a08 60%, #000 100%);animation:drift 16s ease-in-out infinite alternate}
.frame__placeholder--ember{background:radial-gradient(80% 70% at 60% 60%, #2a1208 0%, #100604 60%, #000 100%);animation:drift2 20s ease-in-out infinite alternate}
.frame__placeholder--mono{background:radial-gradient(80% 70% at 50% 40%, #1a1a1c 0%, #0a0a0b 60%, #000 100%);animation:drift 14s ease-in-out infinite alternate}
@keyframes drift  {from{transform:scale(1.05)} to{transform:scale(1.12) translate(-1.5%,-1%)}}
@keyframes drift2 {from{transform:translate(0,0)} to{transform:translate(2%,-2%)}}

/* ------------------------------------------------------------
   Light-leak divider (animated, reusable across pages)
   ------------------------------------------------------------ */
.light-leak{
  position:relative;height:120px;width:100%;overflow:hidden;
  background:transparent;isolation:isolate;
  /* fade the divider edges into the surrounding sections */
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 28%, #000 72%, transparent 100%);
          mask-image:linear-gradient(180deg, transparent 0%, #000 28%, #000 72%, transparent 100%);
  margin-top:-1px;margin-bottom:-1px; /* kill hairline seams */
}

.light-leak::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 0%, rgba(255,255,255,.04) 50%, transparent 100%);
  pointer-events:none;
}
.light-leak span{
  position:absolute;top:50%;left:-30%;
  width:160%;height:300px;transform:translateY(-50%) rotate(-4deg);
  background:
    radial-gradient(60% 50% at 20% 50%, rgba(255,140,60,.55) 0%, rgba(255,90,50,.25) 30%, transparent 65%),
    radial-gradient(45% 50% at 55% 50%, rgba(255,200,90,.35) 0%, transparent 60%),
    radial-gradient(35% 50% at 85% 50%, rgba(220,40,40,.35) 0%, transparent 65%);
  filter:blur(28px);mix-blend-mode:screen;opacity:0;
  animation:leakSweep 9s ease-in-out infinite;
}
.light-leak--alt span{
  animation-delay:-4.5s;
  background:
    radial-gradient(50% 50% at 25% 50%, rgba(255,90,40,.55) 0%, transparent 60%),
    radial-gradient(45% 50% at 70% 50%, rgba(255,180,80,.45) 0%, transparent 65%);
}
.light-leak::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.25;mix-blend-mode:overlay;
}
@keyframes leakSweep{
  0%   { transform:translate(-40%, -50%) rotate(-4deg); opacity:0; }
  20%  { opacity:.85; }
  50%  { transform:translate(10%, -50%) rotate(-3deg); opacity:.95; }
  80%  { opacity:.7; }
  100% { transform:translate(45%, -50%) rotate(-5deg); opacity:0; }
}
@media (max-width:760px){
  .light-leak{height:80px}
  .light-leak span{height:200px}
}

/* ------------------------------------------------------------
   Trusted by / clients marquee
   ------------------------------------------------------------ */
.trusted{
  padding:120px 36px;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  background:var(--bg);
}
.trusted__inner{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:auto 1fr;gap:80px;align-items:center;
}
.trusted__label{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(48px,6vw,96px);
  letter-spacing:.005em;text-transform:uppercase;
  line-height:.9;color:var(--ink);
  display:flex;flex-direction:column;
}
.trusted__label .num{
  font-family:'Instrument Serif',Georgia,serif;font-size:42px;letter-spacing:.04em;color:var(--ink);
  line-height:1;
}
.trusted__logos{
  display:flex;align-items:center;gap:64px;flex-wrap:wrap;justify-content:flex-end;
}
.trusted__logo{
  display:flex;align-items:center;gap:14px;flex:0 0 auto;
  opacity:.95;
  transition:opacity .25s, transform .25s;
}
.trusted__logo:hover{opacity:1;transform:translateY(-2px)}
.trusted__logo img{height:96px;width:auto;display:block}
.trusted__logo .pill{
  display:flex;align-items:center;justify-content:center;
  height:54px;padding:0 22px;
  border:1px solid var(--hairline);
  font-family:'Instrument Serif',Georgia,serif;font-size:20px;letter-spacing:.06em;
  color:var(--ink-dim);
}
@media (max-width:800px){
  .trusted{padding:64px 20px}
  .trusted__inner{grid-template-columns:1fr;gap:32px}
  .trusted__logos{justify-content:flex-start;gap:32px}
  .trusted__logo img{height:64px}
  .trusted__logo .pill{height:48px;font-size:18px;padding:0 18px}
}

/* ------------------------------------------------------------
   Social icons (footer + about page) — bare, blend into background
   ------------------------------------------------------------ */
.socials{display:flex;align-items:center;gap:18px}
.socials a{
  display:flex;align-items:center;justify-content:center;
  width:56px;height:56px;
  background:transparent;
  transition:transform .2s, opacity .2s;
  opacity:.92;
}
.socials a:hover{transform:translateY(-3px);opacity:1}
.socials a img{width:52px;height:52px;object-fit:contain}

/* ------------------------------------------------------------
   Buttons / links
   ------------------------------------------------------------ */
.link-line{
  display:inline-block;
  font-family:var(--mono);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  padding-bottom:4px;border-bottom:1px solid var(--ink-faint);
  transition:border-color .2s, padding .25s;
}
.link-line:hover{border-color:var(--ink);padding-bottom:8px}

/* ------------------------------------------------------------
   Responsive
   ------------------------------------------------------------ */
@media (max-width: 800px){
  .site-nav{padding:16px 20px}
  .site-nav ul{gap:14px;font-size:10px;letter-spacing:.18em}
  .page-head{grid-template-columns:1fr;padding:140px 20px 40px;gap:24px;min-height:60vh}
  .page-head__title{font-size:clamp(72px,18vw,140px)}
  .page-head__lead{justify-self:start;font-size:14px}
  .site-foot{grid-template-columns:1fr;padding:48px 20px 24px;gap:32px}
  .site-foot__base{flex-direction:column;gap:10px}
}

/* ------------------------------------------------------------
   Photographer/filmmaker micro-copy — route all small uppercase
   metadata captions to mono (contact-sheet vibe)
   ------------------------------------------------------------ */
.eyebrow,
.count,
.cat,
.filters__group,
.filters__view,
.work-row__cat,
.work-row__num,
.year,
.quote h3,
.quote__cite,
.partner__eyebrow,
.roster__row .n,
.roster__head .count{
  font-family: var(--mono) !important;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
}

/* Work-row client/title stay serif display, but small year/num caption mono */
.work-row__client,
.contact__email,
.about-body p{
  /* leave as-is — these are body/display */
}


/* ------------------------------------------------------------
   Preloader — minimal black overlay, rotating dot + orbiting bubbles,
   light-leak sweep, fades out on window load
   ------------------------------------------------------------ */
.preloader{
  position:fixed;inset:0;z-index:9999;background:#000;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;isolation:isolate;
  transition:opacity .7s ease, visibility 0s linear .7s;
}
.preloader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader__leak{
  position:absolute;inset:0;pointer-events:none;
}
.preloader__leak span{
  position:absolute;top:50%;left:-30%;
  width:160%;height:60%;transform:translateY(-50%) rotate(-4deg);
  background:
    radial-gradient(60% 50% at 20% 50%, rgba(255,140,60,.35) 0%, rgba(255,90,50,.15) 30%, transparent 65%),
    radial-gradient(45% 50% at 60% 50%, rgba(255,200,90,.25) 0%, transparent 60%),
    radial-gradient(35% 50% at 85% 50%, rgba(220,40,40,.25) 0%, transparent 65%);
  filter:blur(40px);mix-blend-mode:screen;opacity:0;
  animation:leakSweep 6s ease-in-out infinite;
}
.preloader__orbit{
  position:relative;width:64px;height:64px;
  animation:preSpin 1.6s linear infinite;
}
.preloader__orbit .dot{
  position:absolute;top:50%;left:50%;
  width:8px;height:8px;margin:-4px 0 0 -4px;border-radius:50%;
  background:rgba(244,239,230,.95);
  box-shadow:0 0 12px rgba(244,239,230,.5);
}
.preloader__orbit .bubble{
  position:absolute;top:50%;left:50%;border-radius:50%;
  background:rgba(244,239,230,.85);
  transform-origin:0 0;
}
.preloader__orbit .b1{width:6px;height:6px;margin:-3px 0 0 -3px;
  transform:rotate(0deg) translateX(28px);
  animation:preBubble 1.6s ease-in-out infinite}
.preloader__orbit .b2{width:5px;height:5px;margin:-2.5px 0 0 -2.5px;
  transform:rotate(120deg) translateX(28px);
  animation:preBubble 1.6s ease-in-out infinite .2s}
.preloader__orbit .b3{width:4px;height:4px;margin:-2px 0 0 -2px;
  transform:rotate(240deg) translateX(28px);
  animation:preBubble 1.6s ease-in-out infinite .4s}
@keyframes preSpin{to{transform:rotate(360deg)}}
@keyframes preBubble{
  0%,100%{opacity:.35;}
  50%{opacity:1;}
}

/* ------------------------------------------------------------
   Mobile polish — tighter spacing, safer touch targets,
   prevent any accidental horizontal overflow
   ------------------------------------------------------------ */
html,body{max-width:100%;overflow-x:hidden}
img,video,iframe,svg{max-width:100%;height:auto}

@media (max-width:760px){
  /* Nav — tighter so 5 items always fit */
  .site-nav{padding:14px 16px}
  .site-nav ul{gap:12px;font-size:10px;letter-spacing:.16em;flex-wrap:wrap;justify-content:center}
  .site-nav a{padding:8px 2px} /* bigger tap target */

  /* Page headers — single column, breathable */
  .page-head{grid-template-columns:1fr;padding:120px 18px 36px;gap:18px;min-height:auto}
  .page-head__title{font-size:clamp(56px,16vw,120px);line-height:.9}
  .page-head__lead{font-size:14px;line-height:1.55;max-width:100%}

  /* Footer — single column, readable */
  .site-foot{grid-template-columns:1fr;padding:48px 18px 24px;gap:28px}
  .site-foot__big{font-size:clamp(36px,10vw,56px)}
  .site-foot__base{flex-direction:column;align-items:flex-start;gap:8px;font-size:9px}
  .socials a{width:44px;height:44px}
  .socials a img{width:38px;height:38px}

  /* Trusted marquee — stack */
  .trusted{padding:56px 18px}
  .trusted__inner{grid-template-columns:1fr;gap:24px}
  .trusted__logos{gap:24px;justify-content:flex-start}
  .trusted__logo img{height:48px}

  /* Section spacing global */
  .quote-block{padding:64px 18px}
  .quote-block__mark{font-size:clamp(120px,28vw,200px)}
  .quote-block__text{font-size:clamp(28px,7.5vw,56px)}

  /* Light-leak divider — smaller on phones */
  .light-leak{height:70px}

  /* Preloader orbit slightly smaller */
  .preloader__orbit{width:52px;height:52px}
  .preloader__orbit .b1,.preloader__orbit .b2,.preloader__orbit .b3{
    transform-origin:0 0;
  }
  .preloader__orbit .b1{transform:rotate(0deg)   translateX(22px)}
  .preloader__orbit .b2{transform:rotate(120deg) translateX(22px)}
  .preloader__orbit .b3{transform:rotate(240deg) translateX(22px)}

  /* Make audio toggle thumb-friendly */
  .audio{right:14px;bottom:14px;padding:10px 14px;font-size:10px}
}

@media (max-width:420px){
  .site-nav ul{gap:10px;font-size:9.5px}
  .page-head{padding:108px 16px 28px}
}

/* Kill hairline borders directly adjacent to a light-leak so only the
   animation remains — no visible seam line above or below the divider */
.light-leak{border:0 !important}
.light-leak + *{border-top:0 !important}
*:has(> .light-leak:last-child){border-bottom:0 !important}
*:has(+ .light-leak){border-bottom:0 !important}

/* ------------------------------------------------------------
   Iris / aperture page transition overlay
   ------------------------------------------------------------ */
.iris{
  position:fixed;inset:0;z-index:9998;pointer-events:none;
  --ix:50%;--iy:50%;
}
.iris__disc{
  position:absolute;left:var(--ix);top:var(--iy);
  width:1px;height:1px;border-radius:50%;background:#000;
  transform:translate(-50%,-50%) scale(0);
  transition:transform .55s cubic-bezier(.7,0,.2,1);
  will-change:transform;
}
.iris.is-closing{pointer-events:auto}
.iris.is-closing .iris__disc{
  /* big enough to cover any viewport from any origin */
  transform:translate(-50%,-50%) scale(3200);
}
@media (prefers-reduced-motion: reduce){
  .iris__disc{transition:none}
}


/* ------------------------------------------------------------
   Multi-step contact form
   ------------------------------------------------------------ */
.form--multi{display:flex;flex-direction:column;gap:32px}
.form__progress{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-dim);
}
.form__progress .bar{
  flex:1;height:2px;background:var(--hairline);position:relative;overflow:hidden;
}
.form__progress .bar::after{
  content:"";position:absolute;left:0;top:0;bottom:0;
  width:var(--p,25%);background:var(--ink);
  transition:width .5s cubic-bezier(.2,.7,.2,1);
}
.form__steps{position:relative;min-height:240px}
.form__step{
  display:none;flex-direction:column;gap:24px;
  animation:stepIn .5s cubic-bezier(.2,.7,.2,1);
}
.form__step.is-active{display:flex}
@keyframes stepIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.form__step h3{
  font-family:'Instrument Serif',Georgia,serif;font-weight:400;
  font-size:clamp(28px,3.4vw,44px);line-height:1.1;
}
.form__chips{display:flex;flex-wrap:wrap;gap:10px}
.form__chips button{
  padding:12px 18px;border:1px solid var(--hairline);background:transparent;color:var(--ink);
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  cursor:pointer;transition:all .2s;
}
.form__chips button:hover{border-color:var(--ink)}
.form__chips button.is-active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.form__nav{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:8px}
.form__nav .back{
  background:transparent;border:0;color:var(--ink-dim);cursor:pointer;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  padding:8px 0;transition:color .2s;
}
.form__nav .back:hover{color:var(--ink)}
.form__nav .back[disabled]{opacity:.3;cursor:default}
