/* ──────────────────────────────────────────────
   Joe Eitzen — /concept
   A visual-first rebuild of the homepage.
   Dark gallery canvas · photography leads · prose recedes.
   ────────────────────────────────────────────── */

.cx {
  --ink:#0C0C0D;
  --ink-2:#141416;
  --ink-3:#1C1C20;
  --paper:#ECEBE3;
  --muted:rgba(236,235,227,.58);
  --faint:rgba(236,235,227,.34);
  --line:rgba(236,235,227,.14);
  --line-2:rgba(236,235,227,.07);
  --accent:#C7A878;            /* warm bronze — emphasis + hairlines */
  --accent-deep:#8C7350;

  --serif:"Instrument Serif","Iowan Old Style",Georgia,serif;
  --sans:"Space Grotesk",ui-sans-serif,system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;

  --wrap:1560px;
  --pad:clamp(22px,5vw,80px);
  --sp:clamp(84px,9.5vw,152px);

  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

.cx *{box-sizing:border-box;margin:0;padding:0}
.cx html,.cx body{background:var(--ink)}
.cx a{color:inherit;text-decoration:none}
.cx button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
.cx img,.cx svg,.cx video{display:block;max-width:100%}
.cx ::selection{background:var(--accent);color:var(--ink)}
.cx :focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:2px}

/* film grain over the whole canvas */
.cx::before{
  content:"";
  position:fixed;inset:0;z-index:200;
  pointer-events:none;
  opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── shared bits ───────────────────────────── */
.cx-wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}

.cx-eyebrow{
  font-family:var(--mono);
  font-size:11px;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:10px;
}
.cx-eyebrow::before{
  content:"";width:26px;height:1px;background:var(--accent);opacity:.6;
}
.cx-eyebrow--plain::before{display:none}

.cx-section{padding-block:var(--sp);position:relative}
.cx-section + .cx-section{padding-top:0}
.cx-section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:40px;flex-wrap:wrap;
  margin-bottom:clamp(40px,5vw,76px);
}
.cx-h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(38px,5.6vw,86px);
  line-height:.98;letter-spacing:-.025em;
  max-width:14ch;
}
.cx-h2 em{font-style:italic;color:var(--accent)}
.cx-kicker{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--faint);
}

.cx-reveal{
  opacity:0;transform:translateY(34px);
  transition:opacity 1s cubic-bezier(.2,.75,.2,1),transform 1s cubic-bezier(.2,.75,.2,1);
}
.cx-reveal.in{opacity:1;transform:none}
.cx-reveal[data-d="1"]{transition-delay:.08s}
.cx-reveal[data-d="2"]{transition-delay:.16s}
.cx-reveal[data-d="3"]{transition-delay:.24s}

/* ── scroll progress + topbar ──────────────── */
.cx-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:90;
  background:var(--accent);transform-origin:left;
  transform:scaleX(var(--p,0));
}
.cx-topbar{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:18px var(--pad);
  transition:background .4s ease,border-color .4s ease,padding .4s ease;
  border-bottom:1px solid transparent;
}
.cx-topbar.is-scrolled{
  background:rgba(12,12,13,.78);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  padding-block:13px;
}
.cx-mark{
  font-family:"Inter Tight",var(--sans);
  font-weight:500;font-size:16px;letter-spacing:-.005em;line-height:1;
  display:inline-flex;align-items:center;justify-self:start;
}

/* numbered section nav — ported from the homepage */
.cx-nav{display:flex;justify-content:center;gap:20px;align-items:center}
.cx-nv{
  position:relative;display:inline-flex;align-items:baseline;gap:8px;
  padding:6px 2px;color:var(--muted);transition:color .22s;
}
.cx-nv .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  opacity:.55;transition:opacity .22s;
}
.cx-nv .lbl{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  max-width:0;opacity:0;overflow:hidden;white-space:nowrap;
  transition:max-width .34s cubic-bezier(.2,.8,.2,1),opacity .22s ease;
}
.cx-nv:hover{color:var(--paper)}
.cx-nv:hover .num{opacity:1}
.cx-nv:hover .lbl,
.cx-nv:focus-visible .lbl,
.cx-nv.active .lbl{max-width:170px;opacity:1}
.cx-nv.active{color:var(--paper)}
.cx-nv.active .num{opacity:1}
.cx-nv.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--accent);
}
.cx-topbar-end{grid-column:3;justify-self:end;display:inline-flex;align-items:center;gap:12px}
.cx-topbar-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:.13em;
  text-transform:uppercase;
  border:1px solid var(--line);border-radius:100px;
  padding:9px 18px;color:var(--paper);
  transition:background .25s,border-color .25s,color .25s;
}
.cx-topbar-cta:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ── MOBILE MENU ──────────────────────────── */
.cx-burger{display:none}
.cx-mmenu,.cx-mmenu-overlay{display:none}
@media (max-width:860px){
  .cx-topbar-cta{display:none}
  .cx-burger{
    display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
    gap:5px;width:40px;height:40px;
    background:transparent;border:1px solid var(--line);border-radius:100px;
    cursor:pointer;padding:0;color:var(--paper);
  }
  .cx-burger span{
    display:block;width:18px;height:1px;background:var(--paper);
    transition:transform .3s cubic-bezier(.22,.61,.36,1),opacity .25s ease;
  }
  .cx-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .cx-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .cx-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  .cx-mmenu,.cx-mmenu-overlay{display:block}
  .cx-mmenu-overlay{
    position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.55);
    -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
    opacity:0;pointer-events:none;
    transition:opacity .25s ease;
  }
  .cx-mmenu-overlay.open{opacity:1;pointer-events:auto}
  .cx-mmenu{
    position:fixed;top:0;right:0;bottom:0;left:0;z-index:91;
    width:100%;background:var(--ink-2);color:var(--paper);
    display:flex;flex-direction:column;
    transform:translateY(-100%);
    transition:transform .4s cubic-bezier(.2,.8,.2,1);
    padding:20px clamp(20px,5vw,28px) 28px;overflow-y:auto;
  }
  .cx-mmenu.open{transform:none}
  .cx-mmenu-head{
    display:flex;align-items:center;justify-content:space-between;
    padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:6px;
  }
  .cx-mmenu-title{
    font-family:var(--mono);font-size:11px;letter-spacing:.22em;
    text-transform:uppercase;color:var(--muted);
  }
  .cx-mmenu-close{
    background:transparent;border:1px solid var(--line);border-radius:100px;
    width:36px;height:36px;color:var(--paper);font-size:20px;line-height:1;
    cursor:pointer;padding:0;
  }
  .cx-mmenu-nav{display:flex;flex-direction:column}
  .cx-mmenu-nav a{
    display:flex;align-items:baseline;gap:14px;
    padding:14px 4px;border-bottom:1px solid var(--line);
    color:var(--paper);text-decoration:none;
  }
  .cx-mmenu-nav a .n{
    font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--accent)
  }
  .cx-mmenu-nav a .l{
    font-family:"Inter Tight",var(--sans);font-weight:500;font-size:22px;
    line-height:1;letter-spacing:-.005em;
  }
  .cx-mmenu-group{margin-top:22px;display:flex;flex-direction:column}
  .cx-mmenu-group-title{
    font-family:var(--mono);font-size:11px;letter-spacing:.22em;
    text-transform:uppercase;color:var(--muted);margin-bottom:6px;
  }
  .cx-mmenu-group a{
    display:flex;align-items:center;justify-content:space-between;gap:14px;
    padding:14px 4px;border-top:1px solid var(--line);color:var(--paper);
    font-family:"Inter Tight",var(--sans);font-weight:500;font-size:16px;
    letter-spacing:-.005em;text-decoration:none;
  }
  .cx-mmenu-group a:last-child{border-bottom:1px solid var(--line)}
  .cx-mmenu-group a .arr{color:var(--accent);font-family:var(--mono);font-size:14px}
}
@media (prefers-reduced-motion: reduce){
  .cx-mmenu,.cx-mmenu-overlay{transition:none !important}
}

/* ── CUSTOM CURSOR ─────────────────────────── */
.cx-cur,.cx-crosshair{display:none}
html.cx-cursor-on .cx-cur,
html.cx-cursor-on .cx-crosshair{display:block}
html.cx-cursor-on,
html.cx-cursor-on *{cursor:none}
.cx-crosshair{
  position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.15;
}
.cx-crosshair .h{position:absolute;left:0;right:0;height:1px;background:var(--paper)}
.cx-crosshair .v{position:absolute;top:0;bottom:0;width:1px;background:var(--paper)}
.cx-cur{
  position:fixed;left:0;top:0;z-index:9999;pointer-events:none;
  color:var(--paper);transform:translate(-50%,-50%);
}
.cx-cur .ring{
  width:13px;height:13px;border-radius:50%;border:1px solid currentColor;
  transition:width .24s cubic-bezier(.2,.8,.2,1),height .24s cubic-bezier(.2,.8,.2,1),background .24s;
}
.cx-cur .read{
  position:absolute;top:17px;left:17px;
  font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  white-space:nowrap;opacity:.7;transition:opacity .18s;
}
.cx-cur.is-link .read{opacity:0}
.cx-cur.is-link .ring{width:50px;height:50px;background:rgba(236,235,227,.08)}
.cx-cur.is-link::after{
  content:attr(data-label);
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  white-space:nowrap;color:currentColor;
}

/* ── HERO ──────────────────────────────────── */
.cx-hero{
  position:relative;min-height:100svh;
  display:flex;overflow:hidden;background:var(--ink);
}
.cx-hero-media{
  position:absolute;inset:-8% 0 -8% 0;will-change:transform;z-index:0;
}
.cx-hero-media img{
  width:100%;height:100%;object-fit:cover;object-position:50% 42%;
  opacity:0;transform:scale(1.06);
  transition:opacity 1.4s ease,transform 2.4s cubic-bezier(.2,.7,.2,1);
}
.cx-hero-media img.loaded{opacity:1;transform:scale(1)}
.cx-hero-scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(12,12,13,.62) 0%,rgba(12,12,13,.12) 26%,rgba(12,12,13,.10) 55%,rgba(12,12,13,.86) 100%),
    radial-gradient(120% 80% at 50% 36%,transparent 40%,rgba(12,12,13,.5) 100%);
}
.cx-hero-inner{
  position:relative;z-index:2;width:100%;
  max-width:var(--wrap);margin-inline:auto;
  padding:104px var(--pad);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.cx-hero-center{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:clamp(22px,3vw,38px);
}
.cx-hero-q{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(52px,11vw,196px);
  line-height:.9;letter-spacing:-.04em;
}
.cx-hero-q em{font-style:italic;color:var(--accent)}
.cx-hero-lede{
  font-size:clamp(15px,1.5vw,20px);
  font-weight:300;color:var(--paper);
  max-width:min(100ch,92vw);line-height:1.55;
  text-wrap:balance;
}
.cx-hero-lede a{
  color:var(--paper);border-bottom:1px solid var(--accent);
  padding-bottom:1px;transition:color .2s;
}
.cx-hero-lede a:hover{color:var(--accent)}
.cx-hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.cx-btn{
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;padding:15px 26px;border-radius:100px;
  transition:transform .3s,background .3s,color .3s,border-color .3s;
}
.cx-btn .arr{transition:transform .3s}
.cx-btn:hover .arr{transform:translateX(5px)}
.cx-btn.cx-btn--solid{background:var(--paper);color:var(--ink)}
.cx-btn.cx-btn--solid:hover{background:var(--accent);color:var(--ink)}
.cx-btn--ghost{border:1px solid var(--line);color:var(--paper)}
.cx-btn--ghost:hover{border-color:var(--paper);background:rgba(236,235,227,.06)}
.cx-hero-foot{
  position:absolute;right:var(--pad);bottom:clamp(28px,4vw,52px);
  display:flex;align-items:flex-end;
  font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
.cx-hero-foot a:hover{color:var(--paper)}
.cx-scroll-cue{display:flex;align-items:center;gap:12px}
.cx-scroll-cue .line{
  width:1px;height:48px;background:var(--line);position:relative;overflow:hidden;
}
.cx-scroll-cue .line::after{
  content:"";position:absolute;left:0;top:0;width:100%;height:40%;
  background:var(--accent);animation:cxScroll 2.1s ease-in-out infinite;
}
@keyframes cxScroll{
  0%{transform:translateY(-100%)}
  60%,100%{transform:translateY(260%)}
}

/* ── INTRO / STUDIO ────────────────────────── */
.cx-intro-grid{
  display:grid;grid-template-columns:1.15fr .85fr;
  gap:clamp(36px,5vw,90px);align-items:center;
}
.cx-intro-statement{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3.5vw,56px);
  line-height:1.08;letter-spacing:-.02em;
  margin:22px 0 26px;
}
.cx-intro-statement em{font-style:italic;color:var(--accent)}
.cx-intro-body{
  font-size:clamp(15px,1.25vw,18px);line-height:1.62;
  color:var(--muted);max-width:50ch;
}
.cx-intro-body a{color:var(--paper);border-bottom:1px solid var(--accent);
  padding-bottom:1px;transition:color .2s}
.cx-intro-body a:hover{color:var(--accent)}
.cx-intro-body--break{margin-top:clamp(20px,2.4vw,32px)}
.cx-portrait{
  position:relative;border-radius:4px;overflow:hidden;
  aspect-ratio:2/3;background:var(--ink-2);
}
.cx-portrait img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1);
}
.cx-portrait:hover img{transform:scale(1.04)}
.cx-portrait-tag{
  position:absolute;left:18px;bottom:16px;right:18px;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-end;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--paper);
}
.cx-portrait::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(12,12,13,.7));
}

/* ── VENTURES — view toggle ────────────────── */
.cx-work-ctrl{
  display:flex;flex-direction:column;align-items:flex-end;gap:16px;
}
.cx-work-ctrl .cx-kicker{text-align:right}
.cx-toggle{
  display:inline-flex;
  border:1px solid var(--line);border-radius:999px;
  padding:3px;background:var(--ink-2);
}
.cx-toggle button{
  font-family:var(--mono);
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  padding:9px 17px;border-radius:999px;color:var(--muted);
  transition:background .3s,color .3s;
}
.cx-toggle button.on{background:var(--accent);color:var(--ink)}
.cx-toggle button:not(.on):hover{color:var(--paper)}

/* shared entrance for toggled work content */
@keyframes cx-rise{
  from{opacity:0;translate:0 26px}
  to{opacity:1;translate:0 0}
}

/* ── VENTURES — index list ─────────────────── */
.cx-work-list{
  display:flex;flex-direction:column;
  border-top:1px solid var(--line);
}
.cx-work-row{
  display:grid;
  grid-template-columns:114px minmax(0,1.15fr) minmax(0,1.55fr) 162px 56px;
  gap:30px;align-items:center;
  padding:30px 16px;
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
  animation:cx-rise .75s cubic-bezier(.2,.75,.2,1) both;
  animation-delay:calc(var(--i,0) * .07s);
}
.cx-work-row::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:rgba(236,235,227,.04);
  transform:scaleX(0);transform-origin:left;
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
}
.cx-work-row:hover::before,
.cx-work-row:focus-visible::before{transform:scaleX(1)}
.cx-work-row>*{position:relative;z-index:1;transition:color .35s}
.cx-work-row:focus-visible{outline:none}
.cx-work-ix{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--faint);
}
.cx-work-row:hover .cx-work-ix,
.cx-work-row:focus-visible .cx-work-ix{color:var(--accent)}
.cx-work-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(25px,2.4vw,40px);line-height:1;letter-spacing:-.02em;
}
.cx-work-name em{font-style:italic;color:var(--accent)}
.cx-work-desc{font-size:14px;line-height:1.55;color:var(--muted)}
.cx-work-row:hover .cx-work-desc,
.cx-work-row:focus-visible .cx-work-desc{color:var(--paper)}
.cx-work-meta{
  font-family:var(--mono);font-size:10px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--faint);
  text-align:right;line-height:1.9;
}
.cx-work-meta b{color:var(--accent);font-weight:400}
.cx-work-row:hover .cx-work-meta,
.cx-work-row:focus-visible .cx-work-meta{color:var(--muted)}
.cx-work-arr{
  justify-self:end;
  font-family:var(--mono);font-size:21px;color:var(--paper);
  transition:transform .45s,color .35s;
}
.cx-work-row:hover .cx-work-arr,
.cx-work-row:focus-visible .cx-work-arr{transform:translateX(8px);color:var(--accent)}

/* ── VENTURES — studio cards (homepage design) ── */
.cx-studio-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(16px,1.7vw,24px);
}
.cx-studio-card{
  position:relative;overflow:hidden;
  border-radius:18px;
  background:var(--ink-2);
  border:1px solid var(--line);
  aspect-ratio:4/3;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(24px,2.4vw,32px);
  animation:cx-rise .75s cubic-bezier(.2,.75,.2,1) both;
  animation-delay:calc(var(--i,0) * .08s);
  transition:transform .5s cubic-bezier(.2,.8,.2,1),border-color .4s;
}
.cx-studio-card:hover{
  transform:translateY(-4px);
  border-color:rgba(199,168,120,.4);
}
.cx-studio-vis{
  position:absolute;inset:0;z-index:0;
  transition:transform 1.2s cubic-bezier(.2,.8,.2,1),filter .6s;
}
.cx-studio-vis img{width:100%;height:100%;object-fit:cover;display:block}
.cx-studio-card:hover .cx-studio-vis{transform:scale(1.04);filter:saturate(1.15)}
.cx-studio-scrim{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(0deg,rgba(12,12,13,.88) 0%,rgba(12,12,13,.55) 22%,transparent 55%);
}
.cx-studio-card>:not(.cx-studio-vis):not(.cx-studio-scrim):not(.cx-studio-medium){
  position:relative;z-index:2;color:var(--paper);
}
.cx-studio-card .cx-studio-medium{z-index:2}
.cx-studio-medium{
  position:absolute;
  right:clamp(24px,2.4vw,32px);bottom:clamp(24px,2.4vw,32px);
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent);
}
.cx-studio-card h3{
  font-family:var(--sans);font-weight:300;
  font-size:clamp(32px,3.4vw,46px);letter-spacing:-.02em;
  line-height:.96;margin-top:14px;
}
.cx-studio-card h3 em{
  font-family:var(--serif);font-style:italic;font-weight:300;color:#FFD089;
}
.cx-studio-card h3.cx-studio-logo{display:block;line-height:0}
.cx-studio-card h3.cx-studio-logo img{
  display:block;height:auto;width:auto;
  max-height:clamp(34px,3.4vw,48px);max-width:46%;
  object-fit:contain;
  filter:drop-shadow(0 2px 14px rgba(0,0,0,.3));
}
.cx-studio-card p{
  font-family:var(--serif);font-style:italic;
  font-size:15px;line-height:1.5;margin-top:10px;max-width:50ch;
  color:rgba(236,235,227,.9);
}
.cx-studio-arr{
  position:absolute;top:clamp(24px,2.4vw,32px);right:clamp(24px,2.4vw,32px);
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  display:flex;align-items:center;gap:8px;color:var(--paper);
}

/* ── PHOTOGRAPHY — uniform editorial grid ──── */
.cx-gallery{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(10px,1.2vw,18px);
}
.cx-shot{
  position:relative;display:block;
  aspect-ratio:4/5;overflow:hidden;border-radius:4px;
  background:var(--ink-2);
}
.cx-shot img{
  width:100%;height:100%;object-fit:cover;object-position:center;display:block;
  transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .6s;
}
.cx-shot-cap{
  position:absolute;inset:auto 0 0 0;z-index:2;
  padding:18px 18px 16px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
  background:linear-gradient(180deg,transparent,rgba(12,12,13,.82));
  opacity:0;transform:translateY(8px);
  transition:opacity .4s,transform .4s;
}
.cx-shot-cap b{font-family:var(--serif);font-size:19px;font-weight:400}
.cx-shot-cap span{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--accent);text-align:right;
}
.cx-shot:hover img{transform:scale(1.05)}
.cx-shot:hover .cx-shot-cap{opacity:1;transform:none}
.cx-shot-ix{
  position:absolute;top:14px;left:14px;z-index:2;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  color:var(--paper);mix-blend-mode:difference;
}
.cx-gallery-foot{
  margin-top:clamp(34px,4vw,58px);
  display:flex;justify-content:space-between;align-items:center;
  gap:24px;flex-wrap:wrap;
  padding-top:30px;border-top:1px solid var(--line);
}
.cx-gallery-foot p{
  font-family:var(--serif);font-style:italic;font-size:clamp(18px,2vw,26px);
  color:var(--muted);max-width:30ch;
}

/* ── LIGHTBOX ──────────────────────────────── */
.cx-lightbox{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(20px,4vw,60px);
  background:rgba(8,8,9,.95);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;
  transition:opacity .25s ease;
}
.cx-lightbox.open{opacity:1;pointer-events:auto}
.cx-lb-figure{
  position:relative;margin:0;
  display:flex;flex-direction:column;align-items:center;gap:18px;
  max-width:100%;max-height:100%;
}
.cx-lb-figure img{
  max-width:100%;max-height:calc(100svh - 220px);
  width:auto;height:auto;display:block;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
  background:var(--ink-2);
}
.cx-lb-figure figcaption{
  width:100%;display:flex;align-items:baseline;justify-content:space-between;gap:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);
}
.cx-lb-cap{display:inline-flex;align-items:baseline;gap:14px;min-width:0}
.cx-lb-cap b{
  font-family:var(--serif);font-weight:400;font-size:18px;letter-spacing:0;
  text-transform:none;color:var(--paper);
}
.cx-lb-counter{color:var(--accent);white-space:nowrap}
.cx-lb-close,.cx-lb-nav{
  position:absolute;z-index:2;
  background:transparent;border:1px solid var(--line);border-radius:100px;
  width:46px;height:46px;color:var(--paper);
  font-family:var(--serif);font-size:24px;line-height:1;
  cursor:pointer;padding:0;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.cx-lb-close{font-family:var(--mono);font-size:18px}
.cx-lb-close:hover,.cx-lb-nav:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.cx-lb-close{top:clamp(16px,3vw,28px);right:clamp(16px,3vw,28px)}
.cx-lb-prev{left:clamp(16px,3vw,28px);top:50%;transform:translateY(-50%)}
.cx-lb-next{right:clamp(16px,3vw,28px);top:50%;transform:translateY(-50%)}
@media (max-width:720px){
  .cx-lb-prev{left:14px;width:40px;height:40px}
  .cx-lb-next{right:14px;width:40px;height:40px}
  .cx-lb-figure img{max-height:calc(100svh - 240px)}
  .cx-lb-figure figcaption{flex-direction:column;align-items:flex-start;gap:6px}
}
@media (prefers-reduced-motion: reduce){
  .cx-lightbox{transition:none}
}

/* ── MARQUEE filmstrip ─────────────────────── */
.cx-strip{
  position:relative;padding-block:clamp(26px,3vw,46px);
  border-block:1px solid var(--line);
  background:var(--ink-2);overflow:hidden;
}
.cx-strip-label{
  position:absolute;top:14px;left:var(--pad);z-index:3;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--faint);
}
.cx-marquee{display:flex;width:max-content;animation:cxMarquee 64s linear infinite}
.cx-strip:hover .cx-marquee{animation-play-state:paused}
.cx-marquee-item{
  position:relative;height:clamp(150px,18vw,228px);
  margin-right:clamp(12px,1.3vw,20px);flex:none;
  border-radius:3px;overflow:hidden;
}
.cx-marquee-item img{height:100%;width:auto;object-fit:cover}
.cx-marquee-item figcaption{
  position:absolute;left:12px;bottom:10px;
  font-family:var(--mono);font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--paper);
  text-shadow:0 1px 6px rgba(0,0,0,.7);
}
@keyframes cxMarquee{to{transform:translateX(-50%)}}

/* ── PRINCIPLE band ────────────────────────── */
.cx-principle{
  position:relative;overflow:hidden;
  min-height:88svh;display:flex;align-items:center;
  content-visibility:auto;contain-intrinsic-size:1px 88vh;
}
.cx-principle-media{position:absolute;inset:-8% 0;z-index:0;will-change:transform}
.cx-principle-media img{width:100%;height:100%;object-fit:cover;object-position:50% 40%;transition:transform 1.2s cubic-bezier(.22,.61,.36,1),filter 1.2s ease}
.cx-principle:has(.cx-principle-item:hover) .cx-principle-media img,
.cx-principle:has(.cx-principle-item:focus-visible) .cx-principle-media img{transform:scale(1.04);filter:saturate(1.05)}
.cx-principle::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(12,12,13,.74),rgba(12,12,13,.55) 50%,rgba(12,12,13,.92));
}
.cx-principle-inner{
  position:relative;z-index:2;width:100%;
  max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad);
  text-align:center;display:flex;flex-direction:column;align-items:center;
  gap:clamp(26px,3vw,44px);
}
.cx-quote{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(38px,7vw,128px);line-height:.96;letter-spacing:-.03em;
}
.cx-quote em{display:block;font-style:italic;color:var(--accent)}
.cx-quote-mark{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
}
.cx-quote-cite{
  display:block;font-style:normal;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
  margin-top:-12px;
}
.cx-principle-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(20px,3vw,56px);
  align-items:start;
  padding-top:clamp(20px,3vw,40px);
  border-top:1px solid var(--line);
  margin-top:8px;width:min(100%,960px);
}
@media (max-width:720px){
  .cx-principle-list{grid-template-columns:1fr;gap:14px}
}
.cx-principle-item{
  position:relative;
  color:inherit;text-align:center;cursor:pointer;outline:0;
  display:flex;flex-direction:column;gap:10px;align-items:center;
  padding:8px 4px;border-radius:6px;transform-origin:50% 30%;
  transition:opacity .55s ease,transform .55s cubic-bezier(.22,.61,.36,1),filter .55s ease;
}
.cx-principle-item:focus-visible{outline:1px solid var(--accent);outline-offset:6px}
/* dim siblings when any item is hovered/focused */
.cx-principle-list:hover .cx-principle-item:not(:hover),
.cx-principle-list:focus-within .cx-principle-item:not(:focus-within):not(:hover){
  opacity:.45;filter:saturate(.7);
}
.cx-principle-list .n{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--accent);
  transition:letter-spacing .55s ease,transform .55s cubic-bezier(.22,.61,.36,1),opacity .35s ease;
  opacity:.85;
}
.cx-principle-item:hover .n,.cx-principle-item:focus-visible .n{
  letter-spacing:.34em;transform:translateY(-2px);opacity:1;
}
.cx-principle-list .t{
  font-family:var(--serif);font-size:clamp(17px,1.7vw,22px);
  position:relative;display:inline-block;padding-bottom:4px;
  transition:transform .55s cubic-bezier(.22,.61,.36,1);
}
.cx-principle-list .t em{font-style:italic;color:var(--accent)}
.cx-principle-item:hover .t,.cx-principle-item:focus-visible .t{transform:translateY(-1px)}
.cx-principle-list .t::after{
  content:"";position:absolute;left:50%;bottom:-2px;
  width:0;height:1px;background:var(--accent);
  transform:translateX(-50%);
  transition:width .65s cubic-bezier(.22,.61,.36,1);
}
.cx-principle-item:hover .t::after,.cx-principle-item:focus-visible .t::after{width:100%}
.cx-principle-body{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  display:grid;grid-template-rows:0fr;width:min(100%,360px);
  pointer-events:none;
  transition:grid-template-rows .55s cubic-bezier(.22,.61,.36,1);
}
.cx-principle-item:hover .cx-principle-body,
.cx-principle-item:focus-visible .cx-principle-body{grid-template-rows:1fr;pointer-events:auto}
.cx-principle-body .inner{
  overflow:hidden;min-height:0;
  font-family:var(--serif);font-size:15px;line-height:1.55;
  color:var(--muted);padding-top:12px;
}
.cx-principle-body .w{
  display:inline-block;opacity:0;transform:translateY(8px);
  margin-right:.27em;
  transition:opacity .5s ease,transform .55s cubic-bezier(.22,.61,.36,1);
  transition-delay:0ms;
}
.cx-principle-body .w:last-child{margin-right:0}
.cx-principle-item:hover .cx-principle-body .w,
.cx-principle-item:focus-visible .cx-principle-body .w{
  opacity:1;transform:none;
  transition-delay:calc(120ms + var(--i) * 28ms);
}
@media (max-width:720px), (hover:none){
  /* Touch / narrow: keep bodies in flow so they don't overlap. */
  .cx-principle-body{
    position:static;transform:none;grid-template-rows:1fr;pointer-events:auto;
  }
  .cx-principle-body .w{opacity:1;transform:none}
  .cx-principle-list:hover .cx-principle-item:not(:hover){opacity:1;filter:none}
}
@media (prefers-reduced-motion: reduce){
  .cx-principle-item,.cx-principle-list .n,.cx-principle-list .t,
  .cx-principle-list .t::after,.cx-principle-body,.cx-principle-body .w,
  .cx-principle-media img{transition:none !important}
  .cx-principle-body .w{opacity:1;transform:none}
}

/* ── RECOGNITION ───────────────────────────── */
.cx-press-list{display:flex;flex-direction:column}
.cx-press-row{
  display:grid;
  grid-template-columns:88px minmax(0,1.1fr) minmax(0,2fr) 40px;
  gap:24px;align-items:center;
  padding:24px 6px;border-top:1px solid var(--line);
  transition:padding-left .35s,background .35s;
}
.cx-press-row:last-child{border-bottom:1px solid var(--line)}
.cx-press-row .yr{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--accent)
}
.cx-press-row .out{
  font-family:var(--serif);font-size:clamp(20px,2vw,30px);font-weight:400
}
.cx-press-row .blurb{font-size:14px;color:var(--muted);line-height:1.5}
.cx-press-row .ext{
  justify-self:end;color:var(--faint);transition:color .3s,transform .3s;
  font-size:15px;
}
a.cx-press-row:hover{padding-left:16px;background:rgba(236,235,227,.03)}
a.cx-press-row:hover .ext{color:var(--accent);transform:translate(2px,-2px)}

/* ── CONTACT ───────────────────────────────── */
.cx-contact{
  position:relative;overflow:hidden;
  padding-block:clamp(110px,15vw,230px);
  content-visibility:auto;contain-intrinsic-size:1px 90vh;
}
.cx-contact-media{position:absolute;inset:-8% 0;z-index:0;will-change:transform}
.cx-contact-media img{width:100%;height:100%;object-fit:cover;object-position:50% 36%}
.cx-contact::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(12,12,13,.9),rgba(12,12,13,.7) 45%,rgba(12,12,13,.95));
}
.cx-contact-inner{position:relative;z-index:2}
.cx-contact-grid{
  display:grid;grid-template-columns:1.4fr .6fr;
  gap:clamp(40px,6vw,110px);align-items:end;
}
.cx-contact-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(44px,8vw,142px);line-height:.94;letter-spacing:-.035em;
}
.cx-contact-h em{font-style:italic;color:var(--accent)}
.cx-email{
  display:inline-flex;align-items:center;gap:16px;
  margin-top:clamp(28px,3.5vw,46px);
  font-family:var(--serif);font-size:clamp(24px,3vw,44px);
  border-bottom:1px solid var(--line);padding-bottom:10px;
  transition:border-color .3s,color .3s;
}
.cx-email .arr{
  font-size:.7em;transition:transform .3s;color:var(--accent)
}
.cx-email:hover{border-color:var(--accent)}
.cx-email:hover .arr{transform:translate(5px,-5px)}
.cx-elsewhere{display:flex;flex-direction:column}
.cx-elsewhere a{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:16px 0;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:11px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--muted);
  transition:color .25s,padding-left .3s;
}
.cx-elsewhere a:last-child{border-bottom:1px solid var(--line)}
.cx-elsewhere a:hover{color:var(--paper);padding-left:8px}
.cx-elsewhere a .arr{color:var(--accent)}

/* ── FOOTER ────────────────────────────────── */
.cx-footer{
  background:var(--ink);padding-block:clamp(48px,5.5vw,72px) 0;
  content-visibility:auto;contain-intrinsic-size:1px 360px;
}
.cx-footer-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  padding-bottom:34px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;
}
.cx-footer-grid h4{
  font-weight:400;margin-bottom:16px;
  font-size:11px;letter-spacing:.16em;color:var(--paper);
}
.cx-footer-grid p,.cx-footer-grid a{
  display:block;line-height:2;color:var(--muted);
}
.cx-footer-grid p a{display:inline}
.cx-footer-grid a{transition:color .25s}
.cx-footer-grid a:hover{color:var(--accent)}
.cx-footer-end{
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding-block:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--faint);
}
.cx-footer-end .wm{
  font-family:"Inter Tight",var(--sans);font-weight:500;
  font-size:16px;letter-spacing:-.005em;
  color:var(--paper);text-transform:none;
}

/* ── ANIMATION ─────────────────────────────── */
/* hero load choreography — pure CSS, plays once on load */
@keyframes cxRise{
  from{opacity:0;transform:translateY(.55em)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes cxRiseBlock{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
.cx-hero .cx-word{
  display:inline-block;
  animation:cxRise .9s cubic-bezier(.16,1,.3,1) both;
  animation-delay:calc(.34s + var(--i) * .13s);
}
.cx-hero .cx-hero-lede{animation:cxRiseBlock 1s cubic-bezier(.16,1,.3,1) .62s both}
.cx-hero .cx-hero-actions{animation:cxRiseBlock 1s cubic-bezier(.16,1,.3,1) .74s both}
.cx-hero .cx-hero-foot{animation:cxRiseBlock 1s cubic-bezier(.16,1,.3,1) .9s both}
.cx-hero-actions .cx-btn{will-change:transform}

/* media clip-reveal — images wipe up as they enter view */
.cx-reveal[data-anim="clip"]{
  opacity:1;transform:none;
  clip-path:inset(100% 0 0 0 round 4px);
  transition:clip-path 1.05s cubic-bezier(.62,0,.16,1),transform .45s ease;
}
.cx-reveal[data-anim="clip"].in{clip-path:inset(0 0 0 0 round 4px)}

/* filmstrip — soft faded edges */
.cx-marquee{position:relative;z-index:1}
.cx-strip::before,.cx-strip::after{
  content:"";position:absolute;top:0;bottom:0;width:9%;z-index:2;pointer-events:none;
}
.cx-strip::before{left:0;background:linear-gradient(90deg,var(--ink-2),transparent)}
.cx-strip::after{right:0;background:linear-gradient(270deg,var(--ink-2),transparent)}

/* ── RESPONSIVE ────────────────────────────── */
@media (max-width:1080px){
  .cx-intro-grid{grid-template-columns:1fr;gap:46px}
  .cx-portrait{max-width:440px}
  .cx-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}
  .cx-contact-grid{grid-template-columns:1fr;gap:48px;align-items:start}
  .cx-footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .cx-nav{display:none}
  .cx-studio-grid{grid-template-columns:1fr;gap:16px}
  .cx-studio-card{aspect-ratio:5/4;border-radius:14px}
  .cx-work-ctrl{align-items:flex-start}
  .cx-work-ctrl .cx-kicker{text-align:left}
  .cx-work-row{
    grid-template-columns:1fr 40px;gap:6px 16px;padding:24px 4px;
  }
  .cx-work-ix{grid-column:1;order:1}
  .cx-work-arr{grid-column:2;grid-row:1 / span 2;align-self:center}
  .cx-work-name{grid-column:1;order:2}
  .cx-work-desc{grid-column:1;order:3;margin-top:4px}
  .cx-work-meta{grid-column:1;order:4;text-align:left;margin-top:4px}
  .cx-press-row{
    grid-template-columns:1fr 28px;grid-auto-rows:auto;
    gap:6px 12px;padding-block:20px;
  }
  .cx-press-row .yr{grid-column:1;order:1}
  .cx-press-row .ext{grid-column:2;grid-row:1 / span 2;align-self:start}
  .cx-press-row .out{grid-column:1;order:2}
  .cx-press-row .blurb{grid-column:1 / -1;order:3}
}
@media (max-width:560px){
  .cx-hero-inner{padding-top:96px}
  .cx-hero-q{font-size:clamp(46px,15vw,80px)}
  .cx-hero-actions{width:100%;flex-direction:column}
  .cx-btn{width:100%;justify-content:center}
  .cx-hero-foot{font-size:9.5px;letter-spacing:.12em}
  .cx-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .cx-footer-grid{grid-template-columns:1fr}
  .cx-studio-card{padding:24px}
  /* Put the medium label back in flow on narrow cards so it doesn't sit
     over the description text. */
  .cx-studio-card .cx-studio-medium{
    position:static;order:-1;margin-bottom:10px;
  }
  .cx-studio-card{display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start}
  .cx-work-row{padding:20px 2px}
  .cx-work-name{font-size:clamp(22px,6.5vw,30px)}
}

@media (prefers-reduced-motion:reduce){
  .cx-reveal{transition:none;opacity:1;transform:none}
  .cx-marquee{animation:none}
  .cx-scroll-cue .line::after{animation:none}
  .cx-hero .cx-word,
  .cx-hero .cx-hero-lede,
  .cx-hero .cx-hero-actions,
  .cx-hero .cx-hero-foot{animation:none}
  .cx-reveal[data-anim="clip"]{clip-path:none;transition:none}
  .cx-work-row,.cx-studio-card{animation:none}
  .cx *{scroll-behavior:auto}
}
